@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Orbitron:wght@400;500;600;700;800;900&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#0f1529;--bg-tertiary:#141b2d;--bg-glass:#141b2d99;--bg-glass-hover:#19233cb3;--bg-modal-overlay:#050812e0;--cat-tech:#3b82f6;--cat-admin:#f0b940;--cat-sales:#34d399;--cat-global:#a78bfa;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-subtle:#ffffff14;--shadow-card:0 8px 32px #0000004d;--glass-blur:blur(20px);--glass-border:1px solid #ffffff14;--font-primary:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display:"Orbitron", "Inter", sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow:hidden}#root{flex-direction:column;min-height:100vh;display:flex}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 50% at 20% 40%,#3b82f60a 0%,#0000 60%),radial-gradient(60% 40% at 80% 60%,#f0b94008 0%,#0000 60%);position:fixed;inset:0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#1e40af;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--cat-tech)}.glass-card{background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--shadow-card);border-radius:16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes starTwinkle{0%,to{opacity:.3}50%{opacity:.8}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@keyframes eagleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;position:absolute;inset:0}.login-bg .star{background:var(--text-secondary);border-radius:50%;width:2px;height:2px;animation:3s infinite starTwinkle;position:absolute}.login-card{z-index:1;text-align:center;width:100%;max-width:440px;padding:3rem;animation:.6s ease-out fadeInScale;position:relative}.login-logo{filter:drop-shadow(0 0 20px #f0b9404d);width:80px;height:80px;margin:0 auto 1.5rem;animation:4s ease-in-out infinite float}.login-title{font-family:var(--font-display);letter-spacing:2px;background:linear-gradient(135deg, var(--cat-admin), #fcd34d, #60a5fa);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-size:1.8rem;font-weight:800;animation:4s linear infinite shimmer}.login-subtitle{color:var(--text-muted);letter-spacing:1px;margin-bottom:2rem;font-size:.9rem}.login-btn{width:100%;color:var(--text-primary);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border:1px solid #3b82f666;border-radius:12px;justify-content:center;align-items:center;gap:1rem;padding:1rem 2rem;font-size:1rem;font-weight:600;display:flex}.login-btn:hover{border-color:var(--cat-tech);background:linear-gradient(135deg,#3b82f633,#3b82f61a);transform:translateY(-2px);box-shadow:0 0 20px #3b82f626}.login-btn svg{width:24px;height:24px}.login-footer{color:var(--text-muted);margin-top:2rem;font-size:.8rem}.app-header{background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border-subtle);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:relative}.header-left{align-items:center;gap:.75rem;display:flex}.header-logo{filter:drop-shadow(0 0 10px #f0b9404d);width:32px;height:32px}.header-brand{font-family:var(--font-display);letter-spacing:2px;color:var(--cat-admin);font-size:1rem;font-weight:700}.header-sep{background:var(--border-subtle);width:1px;height:20px;margin:0 .25rem}.header-page-title{color:var(--text-secondary);font-size:.8rem}.header-right{align-items:center;gap:1rem;display:flex}.header-user{align-items:center;gap:.5rem;display:flex}.header-avatar{background:linear-gradient(135deg, #1e40af, var(--cat-tech));color:#fff;border:2px solid #3b82f666;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;display:flex}.header-user-info{flex-direction:column;display:flex}.header-user-name{font-size:.75rem;font-weight:600;line-height:1.2}.header-user-role{text-transform:uppercase;letter-spacing:1.5px;font-size:.6rem;font-weight:500;line-height:1.2}.header-user-role.admin{color:var(--cat-admin)}.header-user-role.viewer{color:var(--cat-tech)}.header-btn{border:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:8px;padding:.4rem .75rem;font-size:.75rem}.header-btn:hover{color:var(--text-primary);background:#f871711a;border-color:#f87171}.admin-toolbar{background:#f0b9400d;border-bottom:1px solid #f0b94026;align-items:center;gap:.75rem;padding:.4rem 1.5rem;display:flex}.admin-toolbar-label{letter-spacing:2px;text-transform:uppercase;color:var(--cat-admin);font-size:.65rem;font-weight:700;font-family:var(--font-display)}.admin-btn{color:var(--cat-admin);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast);background:#f0b94014;border:1px solid #f0b9404d;border-radius:8px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.7rem;font-weight:600;display:flex}.admin-btn:hover{background:#f0b94033;border-color:#fcd34d;box-shadow:0 0 15px #f0b9401a}.admin-btn.danger{color:#f87171;background:#f8717114;border-color:#f871714d}.admin-btn.danger:hover{background:#f8717133;border-color:#f87171}.timeline-wrapper{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.timeline-scroll{cursor:grab;flex:1;position:relative;overflow:auto hidden}.timeline-scroll:active,.timeline-scroll.is-dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.timeline-canvas{position:relative}.timeline-svg{pointer-events:none}.timeline-nav{z-index:50;background:var(--bg-glass);width:44px;height:44px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--cat-admin);cursor:pointer;transition:all var(--transition-base);border:1px solid #f0b9404d;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.timeline-nav:hover{border-color:var(--cat-admin);background:#f0b94026;box-shadow:0 0 20px #f0b94026}.timeline-nav.left{left:12px}.timeline-nav.right{right:12px}.tl-item{z-index:10;width:220px;position:absolute}.tl-dot{cursor:pointer;transition:all var(--transition-base);z-index:15;border:2.5px solid;border-radius:50%;position:absolute;left:50%}.tl-dot.large{animation:3s ease-in-out infinite pulse;transform:translate(-50%,-50%)}.tl-dot.small{transform:translate(-50%,-50%)}.tl-dot.in-progress{border-style:dashed;animation:2s ease-in-out infinite pulse}.tl-dot.planned{opacity:.5;border-style:dashed}.tl-item:hover .tl-dot{filter:brightness(1.3);transform:translate(-50%,-50%)scale(1.3)}.tl-connector{opacity:.3;z-index:5;border-left:1px solid;width:1px;position:absolute;left:50%}.tl-connector.above{height:60px;bottom:0;transform:translateY(-12px)}.tl-connector.below{height:60px;top:0;transform:translateY(12px)}.tl-content{background:var(--bg-glass);width:200px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--border-subtle);transition:all var(--transition-base);text-align:center;border-radius:10px;padding:.75rem;position:absolute;left:50%;transform:translate(-50%)}.tl-content.above{bottom:72px}.tl-content.below{top:72px}.tl-item:hover .tl-content{background:var(--bg-glass-hover);border-color:#ffffff26;transform:translate(-50%)translateY(-3px);box-shadow:0 8px 32px #0006}.tl-item.below:hover .tl-content{transform:translate(-50%)translateY(3px)}.tl-number{font-family:var(--font-display);letter-spacing:1px;margin-bottom:.15rem;font-size:1.4rem;font-weight:800;line-height:1;display:block}.tl-title{color:var(--text-primary);margin-bottom:.25rem;font-size:.7rem;font-weight:700;line-height:1.3}.tl-desc{color:var(--text-muted);font-size:.6rem;line-height:1.4}.tl-edit-btn{background:var(--bg-primary);cursor:pointer;border:1px solid;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.5rem;display:none;position:absolute;top:4px;right:4px}.tl-item:hover .tl-edit-btn{display:flex}.tl-eagle{z-index:5;filter:drop-shadow(0 0 30px #f0b94066);animation:5s ease-in-out infinite eagleFloat;position:absolute}.timeline-legend{border-top:1px solid var(--border-subtle);background:var(--bg-glass);flex-wrap:wrap;align-items:center;gap:1.5rem;padding:.5rem 1.5rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.7rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.detail-overlay{z-index:200;background:var(--bg-modal-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.detail-panel{width:90%;max-width:500px;padding:2rem;animation:.2s ease-out fadeInScale;position:relative}.detail-close{border:1px solid var(--border-subtle);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:1rem;right:1rem}.detail-close:hover{color:var(--text-primary);background:#f871711a;border-color:#f87171}.detail-cat-badge{letter-spacing:1.5px;text-transform:uppercase;border-radius:99px;align-items:center;gap:.4rem;margin-bottom:1rem;padding:.2rem .75rem;font-size:.65rem;font-weight:700;display:inline-flex}.detail-cat-badge.cat-technisch{color:var(--cat-tech);background:#3b82f61f;border:1px solid #3b82f640}.detail-cat-badge.cat-administratief{color:var(--cat-admin);background:#f0b9401f;border:1px solid #f0b94040}.detail-cat-badge.cat-sales{color:var(--cat-sales);background:#34d3991f;border:1px solid #34d39940}.detail-cat-badge.cat-globaal{color:var(--cat-global);background:#a78bfa1f;border:1px solid #a78bfa40}.detail-year{font-family:var(--font-display);letter-spacing:2px;color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.detail-title{color:var(--text-primary);margin-bottom:1rem;font-size:1.3rem;font-weight:700;line-height:1.3}.detail-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.detail-admin-actions{border-top:1px solid var(--border-subtle);gap:.5rem;margin-top:1.5rem;padding-top:1rem;display:flex}.status-badge{letter-spacing:1px;text-transform:uppercase;border-radius:99px;padding:.15rem .6rem;font-size:.65rem;font-weight:700;display:inline-block}.status-badge.status-done{color:#34d399;background:#34d3991f;border:1px solid #34d39940}.status-badge.status-in-progress{color:#60a5fa;background:#3b82f61f;border:1px solid #3b82f640}.status-badge.status-planned{color:var(--text-muted);background:#ffffff0f;border:1px solid #ffffff1a}.group-sub-item{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);align-items:center;gap:.5rem;padding:.3rem 0;font-size:.8rem;display:flex}.group-sub-item:hover{color:var(--text-primary)}.edit-overlay{z-index:300;background:var(--bg-modal-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.edit-modal{width:90%;max-width:520px;max-height:85vh;padding:2rem;animation:.2s ease-out fadeInScale;overflow-y:auto}.edit-modal h2{font-family:var(--font-display);letter-spacing:1px;color:var(--cat-admin);margin-bottom:1.5rem;font-size:1rem;font-weight:700}.edit-field{margin-bottom:1.25rem}.edit-field label{letter-spacing:1px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.4rem;font-size:.7rem;font-weight:600;display:block}.edit-field input,.edit-field select,.edit-field textarea{border:1px solid var(--border-subtle);background:var(--bg-tertiary);width:100%;color:var(--text-primary);font-family:var(--font-primary);transition:border-color var(--transition-fast);border-radius:8px;padding:.5rem .75rem;font-size:.85rem}.edit-field input:focus,.edit-field select:focus,.edit-field textarea:focus{border-color:var(--cat-tech);outline:none;box-shadow:0 0 0 3px #3b82f61a}.edit-field textarea{resize:vertical;min-height:80px}.edit-actions{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;display:flex}.edit-cancel-btn{border:1px solid var(--border-subtle);color:var(--text-secondary);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:8px;padding:.5rem 1.5rem;font-size:.8rem}.edit-cancel-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.edit-save-btn{border:1px solid var(--cat-admin);color:var(--cat-admin);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,#f0b94026,#f0b9400d);border-radius:8px;padding:.5rem 1.5rem;font-size:.8rem;font-weight:600}.edit-save-btn:hover{background:linear-gradient(135deg,#f0b9404d,#f0b9401a);box-shadow:0 0 15px #f0b9401a}.confirm-overlay{z-index:400;background:var(--bg-modal-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{text-align:center;width:90%;max-width:380px;padding:1.5rem;animation:.2s ease-out fadeInScale}.confirm-dialog h3{font-family:var(--font-display);color:#f87171;margin-bottom:.75rem;font-size:.9rem}.confirm-dialog p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.8rem}.confirm-actions{justify-content:center;gap:.75rem;display:flex}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;display:flex}.loading-spinner{border:3px solid var(--border-subtle);border-top-color:var(--cat-admin);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.loading-text{color:var(--text-muted);letter-spacing:1px;font-size:.85rem}@media (width<=768px){.app-header{padding:.5rem .75rem}.header-page-title,.header-sep{display:none}.tl-content{width:160px;padding:.5rem}.tl-number{font-size:1.1rem}.tl-title{font-size:.6rem}}
