:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;font-size:16px;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--card-bg: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e7eb;--accent-color: #000000;--hover-color: #f9fafb;--error-color: #ef4444;--success-color: #10b981;--warning-color: #f59e0b;--primary-color: #000000;--primary-hover: #1f2937;--primary-light: #f9fafb;--gradient-primary: linear-gradient(135deg, #000000 0%, #374151 100%);--gradient-secondary: linear-gradient(135deg, #f9fafb 0%, #ffffff 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--danger-color: #ef4444;--danger-bg: #fef2f2;--danger-border: #fecaca;--info-color: #3b82f6;--info-bg: #eff6ff;--info-border: #93c5fd;--success-bg: #f0fdf4;--success-border: #86efac;--warning-bg: #fffbeb;--warning-border: #fde68a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .2s ease;--mobile-max: 768px;--tablet-max: 1024px;--desktop-min: 1025px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,div,section,header,footer,nav,aside,article,main,button,input,select,textarea,a,p,h1,h2,h3,h4,h5,h6,.card,.sidebar,.modal,.dropdown{transition:background-color .3s ease,color .3s ease,border-color .3s ease}button{border-radius:var(--radius-md);border:2px solid transparent;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-sm);font-weight:600;font-family:inherit;background:var(--gradient-primary);color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.btn-small{padding:.5rem .75rem;font-size:.75rem}.hide-mobile{display:none}.show-mobile,.hide-desktop{display:block}.show-desktop{display:none}.text-center-mobile{text-align:center}.p-mobile{padding:var(--spacing-md)}.px-mobile{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.py-mobile{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.m-mobile{margin:var(--spacing-md)}@media (max-width: 768px){:root{font-size:14px}button{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-base);min-height:2.75rem;min-width:2.75rem}.btn-small{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-sm);min-height:2.25rem}h1{font-size:var(--font-2xl);line-height:1.2}h2{font-size:var(--font-xl);line-height:1.3}h3{font-size:var(--font-lg);line-height:1.4}.hide-mobile{display:none!important}.show-mobile,.hide-desktop{display:block!important}.show-desktop{display:none!important}.text-center-mobile{text-align:center!important}.container-mobile{padding-left:var(--spacing-md);padding-right:var(--spacing-md);max-width:100%}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],textarea,select{font-size:var(--font-base);padding:var(--spacing-md);min-height:2.75rem}}@media (min-width: 769px) and (max-width: 1024px){:root{font-size:15px}.hide-tablet{display:none!important}.show-tablet{display:block!important}}@media (min-width: 1025px){:root{font-size:16px}.hide-mobile{display:block!important}.show-mobile,.hide-desktop{display:none!important}.show-desktop{display:block!important}.text-center-mobile{text-align:left!important}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){button{border-width:.5px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}@media (pointer: coarse){button,input,select,textarea,a{min-height:2.75rem;min-width:2.75rem}}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid rgba(0,0,0,.1)}.status-badge.draft{background:#9ca3af;color:#fff}.status-badge.anbudsrunde{background:#6b7280;color:#fff}.status-badge.mottatt-bud{background:#bfdbfe;color:#1e40af}.status-badge.akseptert-oppdrag{background:#fbbf24;color:#92400e}.status-badge.oppstartsjekkliste{background:#c084fc;color:#7c2d12}.status-badge.avsluttingsjekkliste{background:#fda4af;color:#7f1d1d}.status-badge.ferdig-prosjekt{background:#86efac;color:#166534}.status-badge.betalt{background:#bbf7d0;color:#14532d}.status-badge.tapt,.status-badge.kansellert{background:#fecaca;color:#991b1b}table th,.projects-table th,.data-table th,.customers-table th,.contractors-table th,.users-table th,.tasks-table th{background:#f3f4f6!important;color:#374151!important;background-image:none!important;background-clip:initial!important}[data-theme=dark]{@keyframes particlesFloat{0%,to{background-position:0% 0%;opacity:.3}50%{background-position:100% 100%;opacity:.5}}@keyframes shimmer{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}@keyframes breathingGlow{0%,to{box-shadow:0 0 20px #00d4ff66,0 0 40px #7c3aed33}50%{box-shadow:0 0 40px #00d4ff99,0 0 60px #7c3aed66}}@keyframes scanLine{0%{transform:translateY(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(100vh);opacity:0}}@keyframes ripple{0%{width:0;height:0;opacity:1}to{width:400px;height:400px;opacity:0}}@keyframes dataStream{0%{transform:translateY(-100%);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(200%);opacity:0}}@keyframes pulse{0%,to{transform:translateY(-50%) scale(1);opacity:1}50%{transform:translateY(-50%) scale(1.5);opacity:.5}}@keyframes borderFlow{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}@keyframes loadingGlow{0%,to{box-shadow:0 0 20px #00d4ff66}50%{box-shadow:0 0 40px #00d4ffcc,0 0 60px #7c3aed66}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes neuralFlow{0%{background-position:0% 0%}to{background-position:200% 0%}}@keyframes glitch{0%{transform:translate(0)}20%{transform:translate(-2px,2px)}40%{transform:translate(-2px,-2px)}60%{transform:translate(2px,2px)}80%{transform:translate(2px,-2px)}to{transform:translate(0)}}@keyframes gridMove{0%{background-position:0 0,0 0}to{background-position:20px 20px,20px 20px}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes cornerGlow{0%,to{box-shadow:0 0 10px #00d4ff80}50%{box-shadow:0 0 20px #00d4ff}}@keyframes btnPulse{0%{box-shadow:0 0 #00d4ffb3}to{box-shadow:0 0 0 20px #00d4ff00}}@keyframes statusPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:0}}}[data-theme=dark] body:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(0,212,255,.3),transparent),radial-gradient(2px 2px at 60% 70%,rgba(124,58,237,.3),transparent),radial-gradient(1px 1px at 50% 50%,rgba(0,212,255,.2),transparent),radial-gradient(1px 1px at 80% 10%,rgba(124,58,237,.2),transparent),radial-gradient(2px 2px at 90% 60%,rgba(0,212,255,.25),transparent),radial-gradient(1px 1px at 33% 80%,rgba(124,58,237,.25),transparent);background-size:200% 200%;background-position:0% 0%;pointer-events:none;z-index:1;animation:particlesFloat 20s ease-in-out infinite;opacity:.4}[data-theme=dark] .card:after,[data-theme=dark] .dashboard-card:after,[data-theme=dark] .stat-card:after,[data-theme=dark] .chart-card:after,[data-theme=dark] .project-card:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(0,212,255,.1) 50%,transparent 70%);transform:rotate(45deg);animation:shimmer 8s infinite;pointer-events:none}[data-theme=dark] .btn-primary,[data-theme=dark] .primary-button,[data-theme=dark] button.primary{animation:breathingGlow 3s ease-in-out infinite}[data-theme=dark] .dashboard-page:before,[data-theme=dark] .content-with-sidebar:before{content:"";position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.8),rgba(124,58,237,.8),transparent);animation:scanLine 4s linear infinite;pointer-events:none;z-index:9999}[data-theme=dark] .card:hover:before,[data-theme=dark] .dashboard-card:hover:before,[data-theme=dark] .stat-card:hover:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;border:2px solid rgba(0,212,255,.6);transform:translate(-50%,-50%);animation:ripple 1.5s ease-out}[data-theme=dark] .sidebar:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent,rgba(0,212,255,.6),rgba(124,58,237,.6),transparent);animation:dataStream 3s linear infinite}[data-theme=dark] .nav-link.active:after,[data-theme=dark] .sidebar-links a.active:after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--accent-color);border-radius:50%;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 10px #00d4ffcc}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{position:relative;border-image:linear-gradient(45deg,#00d4ff80,#7c3aed80,#00d4ff80) 1;animation:borderFlow 3s linear infinite}[data-theme=dark] .loading,[data-theme=dark] .spinner{border:3px solid rgba(0,212,255,.1);border-top:3px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite,loadingGlow 2s ease-in-out infinite}[data-theme=dark] .badge,[data-theme=dark] .status-badge{animation:float 3s ease-in-out infinite}[data-theme=dark] .dashboard-header:before,[data-theme=dark] .page-header:before,[data-theme=dark] .section-header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(0,212,255,.5) 20%,rgba(124,58,237,.5) 40%,rgba(0,212,255,.5) 60%,rgba(124,58,237,.5) 80%,transparent);animation:neuralFlow 5s linear infinite}[data-theme=dark] h1:hover,[data-theme=dark] .dashboard-title:hover{animation:glitch .3s ease-in-out}[data-theme=dark] table,[data-theme=dark] .data-table{background-image:linear-gradient(rgba(0,212,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,212,255,.03) 1px,transparent 1px);background-size:20px 20px;background-position:0 0,0 0;animation:gridMove 20s linear infinite}[data-theme=dark] .stat-value,[data-theme=dark] .metric-value,[data-theme=dark] .kpi-value{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 5s ease infinite}[data-theme=dark] .card:before,[data-theme=dark] .dashboard-card:before{content:"";position:absolute;top:0;left:0;width:20px;height:20px;border-top:2px solid rgba(0,212,255,.5);border-left:2px solid rgba(0,212,255,.5);opacity:0;transition:opacity .3s ease}[data-theme=dark] .card:hover:before,[data-theme=dark] .dashboard-card:hover:before{opacity:1;animation:cornerGlow 1.5s ease-in-out infinite}[data-theme=dark] button:active,[data-theme=dark] .btn:active{animation:btnPulse .3s ease-out}[data-theme=dark] .status-online,[data-theme=dark] .status-active,[data-theme=dark] .online-indicator{position:relative}[data-theme=dark] .status-online:after,[data-theme=dark] .status-active:after,[data-theme=dark] .online-indicator:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;border-radius:50%;background:#00ff8880;animation:statusPulse 2s ease-out infinite}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{background:var(--bg-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.data-table tbody tr{transition:background .2s ease;cursor:pointer}.data-table tbody tr:hover{background:var(--bg-tertiary)}.search-filter-container{display:flex;align-items:center;gap:2rem;margin-bottom:2rem;padding:1rem;background:#fff;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.search-section{flex:1;max-width:500px}.filter-section{display:flex;align-items:center;gap:.75rem;flex-shrink:0;transform:translateY(-1px)}.filter-label{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap}.filter-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:#fff;color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:120px}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #0000001a}.search-input{width:100%;padding:.65rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;background:#fff;color:var(--text-primary);transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #0000001a}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1.5rem;padding:1rem;background:#fff;border-radius:6px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.pagination-info{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.pagination-controls{display:flex;align-items:center;gap:.125rem}.pagination-pages{display:flex;align-items:center;gap:.125rem;margin:0 .25rem}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 .5rem;border:1px solid #d1d5db;background:#fff;color:#374151;font-size:.8125rem;font-weight:500;border-radius:3px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.pagination-container{padding:.75rem}.pagination-controls{gap:.1rem}.pagination-pages{margin:0 .25rem;gap:.1rem}.pagination-btn{min-width:28px;height:28px;font-size:.75rem}}.login-page{min-height:100vh;background-color:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.login-container{width:100%;max-width:400px;margin:0 auto}.login-header{text-align:center;margin-bottom:2rem}.login-header h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-header p{color:var(--text-secondary);font-size:1rem}.login-form-container{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.input-wrapper{position:relative}.input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.input{width:100%;padding:.875rem .875rem .875rem 2.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s ease;background-color:var(--bg-primary);box-shadow:var(--shadow-sm)}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-md),0 0 0 3px #00000007}.input::placeholder{color:var(--text-muted)}.form-footer{display:flex;justify-content:flex-end}.forgot-password{text-align:right}.link{color:var(--text-muted);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s ease;background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:6px;display:inline-block}.link:hover{color:var(--primary-color);background:var(--bg-secondary, #101010);text-decoration:underline}.form-footer{display:flex;justify-content:center}.forgot-password{text-align:center;width:100%}.error-message{background-color:var(--danger-bg);color:var(--danger-color);padding:.875rem;border-radius:8px;border:1px solid var(--danger-border);display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}.success-message{background-color:var(--success-bg);color:var(--success-color);padding:.875rem;border-radius:8px;border:1px solid var(--success-border);display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}@media (max-width: 480px){.login-page{padding:1rem .5rem}.login-form-container{padding:1.5rem}.login-header h2{font-size:1.75rem}}.delete-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.delete-modal{background:var(--card-bg);border-radius:12px;max-width:480px;width:90%;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:1px solid var(--border-color)}.delete-modal-header{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-bottom:1px solid var(--border-color);background:#fef2f2}.delete-modal-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:#fee2e2;display:flex;align-items:center;justify-content:center;color:#dc2626}.delete-modal-title{flex:1;margin:0;font-size:1.125rem;font-weight:600;color:#111827}.delete-modal-close{flex-shrink:0;width:32px;height:32px;border:none;background:none;color:#6b7280;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.delete-modal-close:hover:not(:disabled){background:#f3f4f6;color:#374151}.delete-modal-close:disabled{cursor:not-allowed;opacity:.5}.delete-modal-content{padding:1.5rem}.delete-modal-message{margin:0 0 1rem;color:#374151;line-height:1.5}.delete-modal-item{background:#f9fafb;border:1px solid var(--border-color);border-radius:6px;padding:.75rem;margin:1rem 0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#1f2937;word-break:break-all}.delete-modal-warning{display:flex;align-items:flex-start;gap:.5rem;background:#fef3cd;border:1px solid #fbbf24;border-radius:6px;padding:.75rem;margin:1rem 0;color:#92400e;font-size:.875rem;line-height:1.4}.delete-modal-warning svg{flex-shrink:0;margin-top:.125rem}.delete-modal-actions{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-color);background:#f9fafb;justify-content:flex-end}.delete-modal-actions .btn{min-width:80px}@media (max-width: 640px){.delete-modal{width:95%;margin:1rem}.delete-modal-header,.delete-modal-content,.delete-modal-actions{padding:1rem}.delete-modal-actions{flex-direction:column-reverse}.delete-modal-actions .btn{width:100%}}[data-theme=dark] .delete-modal-overlay{background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}[data-theme=dark] .delete-modal{background:var(--card-bg);border:1px solid rgba(255,92,92,.3);box-shadow:0 0 60px #ff5c5c4d,0 20px 60px #00000080}[data-theme=dark] .delete-modal-header{background:#ff5c5c1a;border-bottom:1px solid rgba(255,92,92,.3)}[data-theme=dark] .delete-modal-icon{background:#ff5c5c33;color:var(--error-color);box-shadow:0 0 20px #ff5c5c66}[data-theme=dark] .delete-modal-title{color:var(--text-primary)}[data-theme=dark] .delete-modal-close{color:var(--text-secondary)}[data-theme=dark] .delete-modal-close:hover:not(:disabled){background:#00d4ff1a;color:var(--accent-color)}[data-theme=dark] .delete-modal-message{color:var(--text-secondary)}[data-theme=dark] .delete-modal-item{background:#00d4ff0d;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .delete-modal-warning{background:#ffb83626;border:1px solid rgba(255,184,54,.3);color:var(--warning-color)}[data-theme=dark] .delete-modal-actions{background:linear-gradient(135deg,#0f141980,#1a1f2980);border-top:1px solid rgba(255,92,92,.3)}.simple-page{max-width:1200px;margin:0 auto;padding:2rem;min-height:100vh}.simple-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.simple-header h1{font-size:2rem;font-weight:600;color:#1f2937;margin:0}.simple-message{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.simple-message.success{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.simple-message.error{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.simple-message button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:currentColor;opacity:.7}.simple-message button:hover{opacity:1}.simple-btn{padding:.75rem 1.5rem;border-radius:6px;border:none;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem}.simple-btn.primary{background-color:#2563eb;color:#fff}.simple-btn.primary:hover{background-color:#1d4ed8}.simple-btn.secondary{background-color:#6b7280;color:#fff}.simple-btn.secondary:hover{background-color:#4b5563}.simple-btn.success{background-color:#059669;color:#fff}.simple-btn.success:hover{background-color:#047857}.simple-btn.warning{background-color:#d97706;color:#fff}.simple-btn.warning:hover{background-color:#b45309}.simple-btn.danger{background-color:#dc2626;color:#fff}.simple-btn.danger:hover{background-color:#b91c1c}.simple-btn.small{padding:.5rem 1rem;font-size:.75rem}.simple-btn:disabled{opacity:.5;cursor:not-allowed}.simple-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.simple-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite}.simple-table{background:var(--card-bg);border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.simple-table table{width:100%;border-collapse:collapse}.simple-table th,.simple-table td{padding:1rem;text-align:left;border-bottom:1px solid #f3f4f6}.simple-table th{background-color:#f9fafb;font-weight:600;color:#374151;font-size:.875rem}.simple-table tbody tr:hover{background-color:#f9fafb}.simple-table tbody tr:last-child td{border-bottom:none}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:#1f2937}.user-email{font-size:.875rem;color:#6b7280}.simple-actions{display:flex;gap:.5rem;flex-wrap:wrap}.simple-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.simple-badge.admin{background-color:#fee2e2;color:#991b1b}.simple-badge.user{background-color:#dbeafe;color:#1e40af}.simple-badge.active{background-color:#d1fae5;color:#065f46}.simple-badge.inactive{background-color:#f3f4f6;color:#6b7280}.simple-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.simple-modal-content{background:var(--card-bg);border-radius:8px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.simple-modal-content h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.simple-modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.simple-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;margin-bottom:1rem;transition:border-color .2s}.simple-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.simple-input-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.simple-card{background:var(--card-bg);border-radius:8px;padding:2rem;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.simple-card h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.simple-info{display:flex;flex-direction:column;gap:1.5rem}.simple-info-item{display:flex;flex-direction:column;gap:.5rem}.simple-info-item label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.simple-info-item span{font-size:1rem;color:#1f2937;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.simple-form{display:flex;flex-direction:column;gap:1.5rem}.simple-form-group{display:flex;flex-direction:column;gap:.5rem}.simple-form-group label{font-size:.875rem;font-weight:600;color:#374151}.simple-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #f3f4f6}@media (max-width: 768px){.simple-page{padding:1rem}.simple-header{flex-direction:column;gap:1rem;align-items:flex-start}.simple-actions,.simple-modal-actions{flex-direction:column}.simple-input-row{grid-template-columns:1fr}.simple-table{overflow-x:auto}.simple-table table{min-width:600px}}:root{--max-width-container: 25rem;--min-button-width: 7.5rem}.unauthorized-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary);padding:var(--spacing-8) var(--spacing-4)}.unauthorized-container{max-width:var(--max-width-container);width:100%;text-align:center}.unauthorized-icon{margin:0 auto var(--spacing-8);height:6rem;width:6rem;color:var(--danger-color)}.unauthorized-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-4)}.unauthorized-description{color:var(--text-secondary);margin-bottom:var(--spacing-8);line-height:1.6}.unauthorized-actions{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.unauthorized-actions .btn{min-width:var(--min-button-width);min-height:2.75rem}@media (min-width: 30rem){.unauthorized-actions{flex-direction:row}}@media (max-width: 29.99rem){.unauthorized-page{padding:var(--spacing-6) var(--spacing-3)}.unauthorized-actions{flex-direction:column;align-items:center}.unauthorized-actions .btn{width:100%;max-width:20rem}.unauthorized-title{font-size:var(--font-size-2xl)}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--card-bg: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e7eb;--accent-color: #000000;--hover-color: #f9fafb;--error-color: #ef4444;--success-color: #10b981;--warning-color: #f59e0b;--primary-color: #000000;--primary-hover: #1f2937;--primary-light: #f9fafb;--gradient-primary: linear-gradient(135deg, #000000 0%, #374151 100%);--gradient-secondary: linear-gradient(135deg, #f9fafb 0%, #ffffff 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--danger-color: #ef4444;--danger-bg: #fef2f2;--danger-border: #fecaca;--info-color: #3b82f6;--info-bg: #eff6ff;--info-border: #93c5fd;--success-bg: #f0fdf4;--success-border: #86efac;--warning-bg: #fffbeb;--warning-border: #fde68a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .2s ease;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--bg-primary: #0f1419;--bg-secondary: #1a1f29;--bg-tertiary: #252d3a;--card-bg: #1a1f29;--text-primary: #e4e6eb;--text-secondary: #a8b3cf;--text-muted: #6b7a99;--border-color: #2d3748;--accent-color: #00d4ff;--hover-color: #252d3a;--primary-color: #00d4ff;--primary-hover: #00b8e6;--primary-light: #1a2332;--error-color: #ff5c5c;--success-color: #00ff88;--warning-color: #ffb836;--gradient-primary: linear-gradient(135deg, #00d4ff 0%, #7c3aed 100%);--gradient-secondary: linear-gradient(135deg, #1a1f29 0%, #252d3a 100%);--gradient-success: linear-gradient(135deg, #00ff88 0%, #00cc6a 100%);--danger-color: #ff5c5c;--danger-bg: #2d1a1a;--danger-border: #4a2424;--info-color: #00d4ff;--info-bg: #1a2332;--info-border: #2d4050;--success-bg: #1a2d24;--success-border: #2d4a3a;--warning-bg: #2d2619;--warning-border: #4a3d24;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .5);--shadow-md: 0 4px 12px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .7);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .8)}body{margin:0;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}body,div,section,header,footer,nav,aside,article,main,button,input,select,textarea,a,p,h1,h2,h3,h4,h5,h6,.card,.profile-page,.profile-container,.info-item,.form-group{transition:background-color .3s ease,color .3s ease,border-color .3s ease}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--text-primary)}button{border-radius:12px;border:2px solid transparent;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;font-family:inherit;background:var(--gradient-primary);color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#fff3,#fff0);opacity:0;transition:opacity .3s ease}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:transparent}button:hover:before{opacity:1}button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}button:focus{outline:none;box-shadow:var(--shadow-md),0 0 0 3px #0003}button.secondary{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color);box-shadow:var(--shadow-sm)}button.secondary:hover{background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}button.danger{background:linear-gradient(135deg,#e53e3e,#c53030);border-color:transparent;color:#fff}button.danger:hover{background:linear-gradient(135deg,#c53030,#9c2626)}input,textarea{border-radius:12px;border:2px solid var(--border-color);padding:.875rem;font-size:.875rem;font-family:inherit;background-color:var(--card-bg);color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}input:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-md),0 0 0 3px #0000001a;transform:translateY(-1px)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.btn{border-radius:12px;border:2px solid transparent;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;background:var(--gradient-primary);color:#fff}.btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#fff3,#fff0);opacity:0;transition:opacity .3s ease}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:transparent}.btn:hover:before{opacity:1}.btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn:focus{outline:none;box-shadow:var(--shadow-md),0 0 0 3px #0003}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn:disabled:hover{transform:none;box-shadow:var(--shadow-sm)}.btn-primary{background:var(--gradient-primary);color:#fff;border-color:transparent}.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:2px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.btn-danger{background:linear-gradient(135deg,#e53e3e,#c53030);border-color:transparent;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c53030,#9c2626)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);border-color:transparent;color:#fff}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:transparent;color:#fff}.btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309)}.btn-full{width:100%}.profile-page{min-height:100vh;background:var(--bg-secondary);padding:2rem;width:100%}.profile-container{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:var(--text-secondary);font-size:.875rem}.loading-spinner{width:36px;height:36px;border:2px solid rgba(0,0,0,.1);border-radius:50%;border-top:2px solid var(--primary-color);animation:spin .8s linear infinite}.spinner{width:16px;height:16px;border:1.5px solid rgba(0,0,0,.1);border-radius:50%;border-top:1.5px solid currentColor;animation:spin .8s linear infinite;margin-right:.5rem}.profile-header-content{display:flex;align-items:center;justify-content:space-between;padding:2.5rem;position:relative}.profile-header-left{display:flex;align-items:center;gap:2rem}.profile-avatar{width:100px;height:100px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-md);flex-shrink:0}.profile-info{display:flex;flex-direction:column}.profile-name{font-size:1.75rem;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.02em}.profile-email{font-size:1rem;color:var(--text-secondary);margin:.375rem 0 1rem}.profile-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.role-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.role-badge.admin{background:var(--primary-color);color:#fff}.role-badge.user{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.member-since{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--text-secondary)}.profile-actions{display:flex;gap:1rem}.alert-container{margin-bottom:1rem}.alert{display:flex;align-items:center;padding:1.25rem;border-radius:var(--radius-sm);font-size:.9375rem;position:relative}.alert-icon{margin-right:.75rem;flex-shrink:0}.alert-content{flex:1;font-weight:500}.alert-success{background:var(--success-bg);color:var(--success-color);border-left:4px solid var(--success-color)}.alert-error{background:var(--danger-bg);color:var(--danger-color);border-left:4px solid var(--danger-color)}.alert-close{background:none;border:none;color:inherit;cursor:pointer;padding:.25rem;opacity:.7;transition:var(--transition);margin-left:.5rem;display:flex;align-items:center;justify-content:center}.alert-close:hover{opacity:1}.card{background:var(--card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border-color)}.card-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary)}.card-header h2{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.card-body{padding:2rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}.info-item{display:flex;flex-direction:column;gap:.625rem}.info-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:1.125rem;color:var(--text-primary);font-weight:500;display:flex;align-items:center;min-height:1.75rem}.role-tag{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500}.role-tag.admin{background:var(--primary-color);color:#fff}.role-tag.user{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-secondary)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}@media (max-width: 940px){.profile-page{padding:1.5rem}.profile-header-content{flex-direction:column;align-items:flex-start;padding:2rem;gap:1.5rem}.profile-header-left,.profile-actions{width:100%}.info-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 640px){.profile-page{padding:1rem}.profile-header-content{padding:1.5rem}.profile-header-left{flex-direction:column;align-items:center;text-align:center;gap:1.25rem}.profile-info{align-items:center}.profile-meta{justify-content:center}.profile-avatar{width:80px;height:80px}.card-header{padding:1.25rem;flex-direction:column;gap:1rem;align-items:flex-start}.card-body{padding:1.25rem}.form-actions{flex-direction:column;width:100%}.form-actions button{width:100%}}.language-selector,.theme-selector{position:relative;display:flex;align-items:center}.language-selector select,.theme-selector select{width:100%;padding:.875rem 3rem .875rem .875rem;border-radius:var(--radius-md);border:2px solid var(--border-color);background-color:var(--card-bg);color:var(--text-primary);font-size:.875rem;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none}.language-selector select:hover,.theme-selector select:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.language-selector select:focus,.theme-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-md),0 0 0 3px #00d4ff1a;transform:translateY(-1px)}.language-icon,.theme-icon{position:absolute;right:1rem;pointer-events:none;color:var(--text-secondary);transition:color .3s ease}.theme-selector select:hover~.theme-icon,.language-selector select:hover~.language-icon{color:var(--primary-color)}[data-theme=dark] .language-selector select,[data-theme=dark] .theme-selector select{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-color:var(--border-color)}[data-theme=dark] .language-selector select:focus,[data-theme=dark] .theme-selector select:focus{border-color:var(--primary-color);box-shadow:var(--shadow-lg),0 0 0 3px #00d4ff33}[data-theme=dark] .theme-icon,[data-theme=dark] .language-icon{color:var(--accent-color)}.change-password-container{max-width:600px;margin:0 auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.change-password-container h1{margin-bottom:1.5rem;color:#333;border-bottom:2px solid #f0f0f0;padding-bottom:.75rem}.loading{display:flex;justify-content:center;align-items:center;min-height:300px;font-size:1.2rem;color:#666}.error-message{color:#e74c3c;padding:1rem;border:1px solid #e74c3c;border-radius:4px;background-color:#e74c3c0d;margin-bottom:1.5rem}.success-message{color:#27ae60;padding:1rem;border:1px solid #27ae60;border-radius:4px;background-color:#27ae600d;margin-bottom:1.5rem}.change-password-form{margin-top:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.form-group input:disabled{background-color:#f9f9f9;cursor:not-allowed}.password-actions{display:flex;gap:1rem;margin-top:2rem}.btn-save,.btn-cancel{padding:.75rem 1.5rem;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s}.btn-save{background-color:#27ae60;color:#fff;flex:1}.btn-save:hover:not(:disabled){background-color:#219653}.btn-save:disabled{background-color:#95a5a6;cursor:not-allowed}.btn-cancel{background-color:#e74c3c;color:#fff;flex:1}.btn-cancel:hover:not(:disabled){background-color:#c0392b}.btn-cancel:disabled{background-color:#95a5a6;cursor:not-allowed}@media (max-width: 768px){.change-password-container{padding:1.5rem}.password-actions{flex-direction:column}.btn-save,.btn-cancel{width:100%}}.set-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-background-light),var(--color-background));padding:3rem 1rem}.set-password-container{max-width:28rem;width:100%;display:flex;flex-direction:column;gap:2rem}.set-password-header{text-align:center}.set-password-title{margin-top:1.5rem;font-size:1.875rem;font-weight:800;color:var(--color-text);margin-bottom:.5rem}.set-password-subtitle{margin-top:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.set-password-info{border-radius:.375rem;background-color:var(--color-warning-light);padding:1rem;margin-bottom:1rem}.set-password-info-text{font-size:.875rem;color:var(--color-warning);margin-bottom:1rem}.resend-button{width:100%;display:flex;justify-content:center;padding:.5rem 1rem;border:1px solid transparent;border-radius:.375rem;box-shadow:0 1px 2px #0000000d;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));cursor:pointer;transition:all .2s ease-in-out}.resend-button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),var(--color-secondary-dark));transform:translateY(-1px)}.resend-button:focus{outline:none;box-shadow:0 0 0 3px #3b82f666}.resend-button:disabled{opacity:.5;cursor:not-allowed}.set-password-form-container{background:var(--card-bg);border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--color-border);padding:2rem}.set-password-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text)}.set-password-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;display:block;width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:.375rem;color:var(--color-text);background:var(--card-bg);font-size:.875rem;line-height:1.25rem;transition:all .2s ease-in-out}.set-password-input::placeholder{color:var(--color-text-muted)}.set-password-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.set-password-submit{group-relative:relative;width:100%;display:flex;justify-content:center;padding:.75rem 1rem;border:1px solid transparent;border-radius:.375rem;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));cursor:pointer;transition:all .2s ease-in-out}.set-password-submit:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),var(--color-secondary-dark));transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.set-password-submit:focus{outline:none;box-shadow:0 0 0 3px #3b82f666}.set-password-submit:disabled{opacity:.5;cursor:not-allowed}.password-requirements{margin-top:.5rem}.password-requirements ul{list-style:none;padding:0;margin:0;font-size:.75rem;color:var(--color-text-secondary)}.password-requirements li{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.password-requirements li.valid{color:var(--color-success)}.password-requirements li.invalid{color:var(--color-error)}.btn-link{font-size:.875rem;color:var(--color-primary);text-decoration:none;transition:color .2s ease-in-out}.btn-link:hover{color:var(--color-primary-dark)}.text-center{text-align:center}@media (max-width: 640px){.set-password-page{padding:1rem .5rem}.set-password-form-container{padding:1.5rem}.set-password-title{font-size:1.5rem}}.reset-password-page{min-height:100vh;background-color:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:2rem .5rem}.reset-password-container{max-width:28rem;width:100%;margin:0 auto}.reset-password-header{text-align:center;margin-bottom:2rem}.reset-password-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;background:var(--gradient-primary);border-radius:.75rem;margin-bottom:1.5rem;box-shadow:var(--shadow-lg)}.reset-password-icon svg{width:2rem;height:2rem;color:#fff}.reset-password-title{font-size:1.875rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.reset-password-subtitle{color:var(--text-secondary);font-size:1rem}.reset-password-form-container{background:var(--card-bg);border-radius:1rem;box-shadow:var(--shadow-xl);border:1px solid var(--border-color);padding:2rem}.reset-password-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.reset-password-input{display:block;width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:.5rem;color:var(--color-text);background:var(--card-bg);font-size:1rem;transition:all .2s ease-in-out}.reset-password-input::placeholder{color:var(--color-text-muted)}.reset-password-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.reset-password-submit{width:100%;display:flex;justify-content:center;align-items:center;padding:.75rem 1rem;border:none;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;font-size:.875rem;font-weight:500;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));cursor:pointer;transition:all .2s ease-in-out}.reset-password-submit:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),var(--color-secondary-dark));transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.reset-password-submit:focus{outline:none;box-shadow:0 0 0 3px #3b82f666}.reset-password-submit:disabled{opacity:.5;cursor:not-allowed}.loading-spinner{width:1.25rem;height:1.25rem;margin-right:.75rem;margin-left:-.25rem;animation:spin 1s linear infinite}.loading-spinner circle{opacity:.25}.loading-spinner path{opacity:.75}.message{border-radius:.5rem;padding:.75rem;display:flex;align-items:center;margin-bottom:1rem}.message-icon{height:1.25rem;width:1.25rem;margin-right:.5rem;flex-shrink:0}.message-text{font-size:.875rem;font-weight:500;flex:1}.error-message{background-color:var(--color-error-light);border:1px solid var(--color-error-border);color:var(--color-error)}.success-message{background-color:var(--color-success-light);border:1px solid var(--color-success-border);color:var(--color-success)}@media (max-width: 640px){.reset-password-page{padding:1rem .5rem}.reset-password-form-container{padding:1.5rem}.reset-password-title{font-size:1.5rem}}.ai-estimation-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #dbeafe;border-radius:1.25rem;margin:0;box-shadow:0 .5rem 1.5rem #0f172a14;overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.ai-estimation-card:hover{transform:translateY(-2px);box-shadow:0 .75rem 2rem #0f172a1f}.ai-card-compact{display:flex;align-items:center;justify-content:space-between;padding:1.75rem 2rem;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid rgba(148,163,184,.2)}.ai-card-compact:hover{background:#3b82f60a}.compact-info{display:flex;align-items:center;gap:1.5rem}.ai-badge{display:flex;align-items:center;gap:.5rem;color:#1d4ed8;font-size:.95rem;font-weight:600}.ai-icon{color:inherit;width:18px;height:18px}.ai-price{color:#0f172a;font-size:1.25rem;font-weight:700}.expand-button{color:#1d4ed8;display:flex;align-items:center}.ai-card-expanded{border-top:1px solid rgba(148,163,184,.2);background:transparent;padding:1.75rem 2rem}.estimation-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;align-items:center;gap:10px;padding:8px 0}.detail-icon{color:#666;width:18px;height:18px;flex-shrink:0}.detail-label{color:#555;font-weight:500;min-width:120px}.detail-value{color:#333;font-weight:600;margin-left:auto}.estimation-breakdown{padding-top:1.25rem}.estimation-breakdown h4{margin:0 0 .75rem;color:#0f172a;font-size:1rem;font-weight:600}.task-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#3b82f60f;border-radius:.75rem;border:1px solid rgba(59,130,246,.1)}.task-desc{color:#0f172a;font-weight:500}.task-hours{color:#1e293b;font-size:.95rem;font-weight:500}@media (max-width: 768px){.ai-card-compact{padding:1.5rem}.compact-info{gap:1rem}.detail-row{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-value{margin-left:0}.ai-card-expanded{padding:1.5rem}.task-item{flex-direction:column;align-items:flex-start;gap:.25rem}}.todo-list-container{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a}.todo-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid #f3f4f6;padding-bottom:1rem}.todo-list-title{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.todo-count{font-size:.875rem;color:#6b7280;font-weight:500}.todo-add-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.todo-input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background:var(--card-bg);transition:border-color .2s ease}.todo-input:focus{outline:none;border-color:#374151;box-shadow:0 0 0 2px #3741511a}.todo-input:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.todo-add-btn{padding:.75rem;background:#374151;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:44px}.todo-add-btn:hover:not(:disabled){background:#1f2937}.todo-add-btn:disabled{background:#d1d5db;cursor:not-allowed}.todo-section{margin-bottom:1.5rem}.todo-section:last-child{margin-bottom:0}.todo-section-title{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.todo-list{display:flex;flex-direction:column;gap:.75rem}.todo-item{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:#f9fafb;border:1px solid #f3f4f6;border-radius:6px;transition:all .2s ease}.todo-item:hover{background:#f3f4f6;border-color:#e5e7eb}.todo-item.completed{background:#f0f9ff;border-color:#e0f2fe}.todo-toggle{padding:.25rem;background:none;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:24px;min-height:24px}.todo-toggle:hover{background:#f3f4f6;border-color:#9ca3af}.todo-toggle.completed{background:#374151;border-color:#374151;color:#fff}.todo-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.todo-text{font-size:.875rem;color:#1f2937;line-height:1.5}.todo-text.completed{text-decoration:line-through;color:#6b7280}.todo-metadata{font-size:.75rem;color:#9ca3af;line-height:1.25}.todo-actions{display:flex;gap:.5rem;align-items:center}.todo-edit-btn,.todo-delete-btn{padding:.375rem;background:none;border:none;border-radius:4px;cursor:pointer;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.todo-edit-btn:hover{background:#f3f4f6;color:#374151}.todo-delete-btn:hover{background:#fef2f2;color:#ef4444}.todo-edit-form{display:flex;align-items:center;gap:.75rem;flex:1}.todo-edit-input{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;background:var(--card-bg)}.todo-edit-input:focus{outline:none;border-color:#374151;box-shadow:0 0 0 2px #3741511a}.todo-edit-actions{display:flex;gap:.25rem}.todo-edit-save,.todo-edit-cancel{padding:.375rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.todo-edit-save{background:#374151;color:#fff}.todo-edit-save:hover{background:#1f2937}.todo-edit-cancel{background:#f3f4f6;color:#6b7280}.todo-edit-cancel:hover{background:#e5e7eb;color:#374151}.todo-empty-state{padding:2rem;text-align:center;background:#f9fafb;border:1px dashed #d1d5db;border-radius:6px}.todo-empty-text{margin:0;color:#6b7280;font-size:.875rem;font-style:italic}.todo-loading{padding:1rem;text-align:center;color:#6b7280;font-size:.875rem}@media (max-width: 640px){.todo-list-container{padding:1rem}.todo-list-header{flex-direction:column;align-items:flex-start;gap:.5rem}.todo-add-form{flex-direction:column}.todo-item{padding:.75rem}.todo-actions{flex-direction:column;gap:.25rem}}.task-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;align-items:flex-start;justify-content:center;padding:min(7vh,40px) 16px;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.task-modal-card{width:min(460px,100%);background:var(--card-bg);border-radius:14px;border:1px solid #e5e7eb;box-shadow:0 20px 60px #0000002e,0 2px 10px #00000014;overflow:hidden;animation:taskModalIn .18s ease-out}@keyframes taskModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.task-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem;border-bottom:1px solid #f1f5f9}.task-modal-header h3{margin:0;font-size:1.05rem;color:#0f172a}.task-modal-eyebrow{margin:0;font-size:.75rem;letter-spacing:.02em;text-transform:uppercase;color:#94a3b8}.task-modal-body{display:flex;flex-direction:column;gap:.75rem;padding:1.1rem}.task-modal-body label{font-size:.85rem;font-weight:600;color:#1f2937}.task-modal-body input{width:100%;border-radius:10px;border:1px solid #e5e7eb;padding:.65rem .75rem;font-size:.92rem;color:#0f172a;background:#f8fafc;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.task-modal-body input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea2e}.input-with-icon{position:relative;display:flex;align-items:center;gap:.5rem;border:1px solid #e5e7eb;border-radius:10px;padding:.55rem .75rem;background:#f8fafc}.input-with-icon input{border:none;background:transparent;padding:0;box-shadow:none}.input-with-icon svg{color:#94a3b8;flex-shrink:0}.project-suggestions{display:flex;flex-direction:column;gap:.35rem;padding-top:.25rem;max-height:180px;overflow-y:auto}.project-suggestion{display:flex;gap:.55rem;align-items:center;width:100%;border:1px solid #e2e8f0;border-radius:10px;padding:.65rem .75rem;background:var(--card-bg);cursor:pointer;transition:border-color .15s,background-color .15s,box-shadow .15s;text-align:left}.project-suggestion:hover{border-color:#667eea;background:#eef2ff;box-shadow:0 4px 12px #667eea26}.project-suggestion.active{border-color:#10b981;background:#ecfdf3;box-shadow:0 4px 12px #10b98124}.project-nr{font-weight:700;color:#0f172a}.project-meta .muted{color:#6b7280;font-size:.85rem}.selected-project{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:10px;background:#ecfdf3;border:1px solid #bbf7d0;color:#065f46;font-size:.9rem}.selected-project__icon{width:26px;height:26px;border-radius:50%;background:#d1fadf;display:grid;place-items:center;color:#047857}.selected-project__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-remove{border:none;background:transparent;color:#065f46;cursor:pointer;padding:.25rem;border-radius:50%}.chip-remove:hover{background:#065f461f}.task-modal-footer{padding:.9rem 1.1rem 1.1rem;display:flex;justify-content:flex-end;gap:.5rem}.ghost-btn,.primary-btn,.icon-btn{border:none;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.ghost-btn{background:var(--card-bg);color:#0f172a;border:1px solid #e5e7eb;padding:.6rem .95rem;border-radius:10px}.primary-btn{background:#667eea;color:#fff;padding:.6rem 1rem;border-radius:10px;box-shadow:0 10px 20px #667eea40}.icon-btn{width:34px;height:34px;border-radius:10px;background:#f8fafc;display:grid;place-items:center;color:#475569}.ghost-btn:hover,.primary-btn:hover,.icon-btn:hover{transform:translateY(-1px)}.primary-btn:hover{box-shadow:0 16px 30px #667eea47}.assignee-section{display:flex;flex-direction:column;gap:.5rem}.assignee-display{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:10px;background:#f8fafc;border:1px solid #e5e7eb}.assignee-avatar{position:relative;width:40px;height:40px;border-radius:50%;background:#667eea;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.assignee-initials{position:absolute;font-size:.75rem;font-weight:600;top:50%;left:50%;transform:translate(-50%,-50%)}.assignee-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.assignee-name{font-size:.92rem;font-weight:600;color:#0f172a}.assignee-note{font-size:.8rem;color:#6b7280;font-style:italic}.ghost-btn.small{padding:.4rem .7rem;font-size:.85rem}.user-picker{display:flex;flex-direction:column;gap:.4rem;padding:.5rem;border-radius:10px;background:#f8fafc;border:1px solid #e5e7eb;max-height:200px;overflow-y:auto}.user-picker-item{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:8px;background:var(--card-bg);border:1px solid #e5e7eb;cursor:pointer;transition:all .15s ease;text-align:left}.user-picker-item:hover{border-color:#667eea;background:#eef2ff;box-shadow:0 2px 8px #667eea26}.user-picker-item.active{border-color:#10b981;background:#ecfdf3;box-shadow:0 2px 8px #10b98124}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;flex-shrink:0}.user-name{font-size:.9rem;color:#0f172a;font-weight:500}.primary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.primary-btn:disabled:hover{transform:none;box-shadow:none}[data-theme=dark] .task-modal-overlay{background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}[data-theme=dark] .task-modal-card{background:var(--card-bg);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 60px #00d4ff4d,0 20px 60px #00000080}[data-theme=dark] .task-modal-header{border-bottom:1px solid rgba(0,212,255,.15);background:linear-gradient(135deg,#00d4ff0d,#7c3aed0d)}[data-theme=dark] .task-modal-header h3{color:var(--text-primary);text-shadow:0 0 15px rgba(0,212,255,.3)}[data-theme=dark] .task-modal-eyebrow{color:var(--text-muted)}[data-theme=dark] .task-modal-body label{color:var(--text-primary)}[data-theme=dark] .task-modal-body input{background:#0f141999;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .task-modal-body input:focus{border-color:var(--accent-color);background:#0f1419cc;box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .input-with-icon{background:#0f141999;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .input-with-icon:focus-within{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .input-with-icon svg{color:var(--text-muted)}[data-theme=dark] .project-suggestion{background:#00d4ff0d;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .project-suggestion:hover{border-color:var(--accent-color);background:#00d4ff1f;box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .project-suggestion.active{border-color:var(--success-color);background:#00ff881f;box-shadow:0 0 20px #00ff884d}[data-theme=dark] .project-nr{color:var(--accent-color)}[data-theme=dark] .project-meta .muted{color:var(--text-muted)}[data-theme=dark] .selected-project{background:#00ff8826;border:1px solid rgba(0,255,136,.3);color:var(--success-color)}[data-theme=dark] .selected-project__icon{background:#0f83;color:var(--success-color)}[data-theme=dark] .chip-remove{color:var(--success-color)}[data-theme=dark] .chip-remove:hover{background:#0f83}[data-theme=dark] .task-modal-footer{background:linear-gradient(135deg,#0f141980,#1a1f2980);border-top:1px solid rgba(0,212,255,.15)}[data-theme=dark] .ghost-btn{background:#00d4ff14;color:var(--text-primary);border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .ghost-btn:hover{background:#00d4ff26;box-shadow:0 0 15px #00d4ff4d}[data-theme=dark] .primary-btn{background:var(--gradient-primary);box-shadow:0 0 30px #00d4ff66}[data-theme=dark] .primary-btn:hover{box-shadow:0 0 40px #00d4ff99}[data-theme=dark] .icon-btn{background:#00d4ff14;color:var(--text-secondary)}[data-theme=dark] .icon-btn:hover{background:#00d4ff26;color:var(--accent-color)}[data-theme=dark] .assignee-display{background:#00d4ff0d;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .assignee-avatar{background:var(--gradient-primary);box-shadow:0 0 15px #00d4ff66}[data-theme=dark] .assignee-name{color:var(--text-primary)}[data-theme=dark] .assignee-note{color:var(--text-muted)}[data-theme=dark] .user-picker{background:#0f141999;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .user-picker-item{background:#00d4ff0d;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .user-picker-item:hover{border-color:var(--accent-color);background:#00d4ff1f;box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .user-picker-item.active{border-color:var(--success-color);background:#00ff881f;box-shadow:0 0 20px #00ff884d}[data-theme=dark] .user-avatar-small{background:var(--gradient-primary);box-shadow:0 0 10px #00d4ff66}.project-notes-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.project-notes-section h2{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#1a1a1a}.notes-loading,.notes-error{text-align:center;padding:1rem;color:#666;font-size:.9375rem}.notes-error{color:#d32f2f;background:#ffebee;border-radius:6px;margin-bottom:1rem}.note-input-container{display:flex;gap:.5rem;margin-bottom:1rem}.note-input{flex:1;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.note-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.note-input:disabled{background:#f5f5f5;cursor:not-allowed}.add-note-btn{padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s;flex-shrink:0}.add-note-btn:hover:not(:disabled){background:#5568d3;transform:scale(1.05)}.add-note-btn:active:not(:disabled){transform:scale(.98)}.add-note-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.notes-divider{height:1px;background:#e0e0e0;margin:1rem 0}.notes-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.notes-list::-webkit-scrollbar{width:8px}.notes-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.notes-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.notes-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.notes-empty{text-align:center;padding:2rem 1rem;color:#999;font-style:italic;font-size:.9375rem}.note-item{padding:1rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #667eea;transition:background .2s}.note-item:hover{background:#eef0f2}.note-content{color:#1a1a1a;font-size:.9375rem;line-height:1.5;margin-bottom:.5rem;word-wrap:break-word}.note-meta{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#666}[data-theme=dark] .project-notes-section{background:var(--card-bg);border:1px solid rgba(0,212,255,.15);box-shadow:0 0 30px #00d4ff1a,0 4px 15px #0000004d}[data-theme=dark] .project-notes-section h2{color:var(--text-primary);text-shadow:0 0 20px rgba(0,212,255,.3)}[data-theme=dark] .note-input{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .note-input:focus{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .add-note-btn{background:var(--gradient-primary);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .add-note-btn:hover:not(:disabled){box-shadow:0 0 30px #00d4ff80}[data-theme=dark] .notes-divider{background:#00d4ff26}[data-theme=dark] .note-item{background:#00d4ff0d;border-left-color:var(--accent-color)}[data-theme=dark] .note-item:hover{background:#00d4ff1a;box-shadow:0 0 15px #00d4ff1a}[data-theme=dark] .note-content{color:var(--text-primary)}[data-theme=dark] .note-meta{color:var(--text-secondary)}[data-theme=dark] .notes-empty{color:var(--text-muted)}[data-theme=dark] .notes-list::-webkit-scrollbar-track{background:#0f141980}[data-theme=dark] .notes-list::-webkit-scrollbar-thumb{background:#00d4ff4d;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .notes-list::-webkit-scrollbar-thumb:hover{background:#00d4ff80}@media (max-width: 768px){.project-notes-section{padding:1rem}.notes-list{max-height:300px}.note-input-container{flex-direction:column}.add-note-btn{width:100%;padding:.75rem 1rem}}.joint-timeline{height:100%;max-height:600px;overflow-y:auto}.joint-timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.joint-timeline-header h2{font-size:1.25rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.5rem}.joint-timeline-list{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto;padding-right:.5rem}.joint-timeline-loading,.joint-timeline-error,.joint-timeline-empty{padding:1.5rem;text-align:center;color:#64748b;border:1px dashed #cbd5e1;border-radius:8px}.joint-timeline-error{color:#dc2626;border-color:#fecaca;background-color:#fef2f2}.timeline-item{position:relative;padding:1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.timeline-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.timeline-dot{position:absolute;left:-8px;top:1.5rem;width:16px;height:16px;border-radius:50%;border:2px solid white}.task-dot{background:#22c55e}.slack-dot{background:#3b82f6}.audit-dot{background:#f59e0b}.timeline-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.timeline-item-title{font-weight:600;color:#0f172a;display:flex;align-items:center;gap:.5rem}.timeline-item-date{font-size:.8rem;color:#64748b;display:flex;align-items:center;gap:.25rem}.timeline-item-meta{display:flex;gap:1rem;font-size:.8rem;color:#64748b;margin-top:.75rem}.timeline-item-assignee{display:flex;align-items:center;gap:.25rem}.assignee-menneske{display:flex;align-items:center;gap:.25rem;color:#1e40af}.assignee-ai{display:flex;align-items:center;gap:.25rem;color:#7c3aed}.timeline-item-delete{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#fee2e2;color:#b91c1c;border:none;border-radius:50%;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.timeline-item-delete:hover{background:#dc2626;color:#fff}.slack-item{border-left:3px solid #3b82f6}.task-item{border-left:3px solid #22c55e}.audit-item{border-left:3px solid #f59e0b}.slack-message-icon{font-size:1rem;margin-right:.25rem}.slack-message-type-label{font-size:.9rem;font-weight:600;color:#3b82f6}.audit-message-type-label{font-size:.9rem;font-weight:600;color:#f59e0b}.audit-message-project{font-size:.8rem;color:#64748b;font-style:italic}.audit-message-content{margin:.75rem 0;font-size:.9rem;color:#374151;line-height:1.5}.slack-message-body{margin:.75rem 0;font-size:.9rem}.slack-message-original p,.slack-message-result p{margin:.5rem 0;line-height:1.5}.slack-message-original ul,.slack-message-result ul,.slack-message-original ol,.slack-message-result ol{margin:.5rem 0;padding-left:1.5rem}.slack-message-original code,.slack-message-result code{background-color:#f1f5f9;padding:.125rem .25rem;border-radius:3px;font-family:monospace;font-size:.875em}.slack-message-original pre,.slack-message-result pre{background-color:#1e293b;color:#f8fafc;padding:.75rem;border-radius:6px;overflow-x:auto;margin:.75rem 0}.slack-message-original pre code,.slack-message-result pre code{background-color:transparent;color:inherit;padding:0}.slack-message-original blockquote,.slack-message-result blockquote{border-left:3px solid #cbd5e1;padding-left:.75rem;margin:.75rem 0;color:#64748b}.slack-message-original a,.slack-message-result a{color:#2563eb;text-decoration:none}.slack-message-original a:hover,.slack-message-result a:hover{text-decoration:underline}.slack-message-result{background:#eff6ff;border-radius:6px;padding:.75rem;margin-top:.75rem}.slack-message-channel,.slack-message-user{display:flex;align-items:center;gap:.25rem}@media (max-width: 768px){.timeline-item-header{flex-direction:column;gap:.5rem}.timeline-item-date{margin-left:0}.timeline-item-meta{flex-direction:column;gap:.5rem}}.bids-section{width:100%;margin-bottom:1.5rem}.bids-list{display:flex;flex-direction:column;gap:.75rem}.bid-card{background-color:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;border-left:4px solid #ccc}.bid-card.status-draft{border-left-color:#6c757d}.bid-card.status-submitted{border-left-color:#007bff}.bid-card.status-accepted{border-left-color:#28a745}.bid-card.status-rejected{border-left-color:#dc3545}.bid-card.status-partial{border-left-color:#ffc107}.bid-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#f9f9f9}.bid-info{display:flex;flex-direction:column}.contractor-name{font-weight:700}.bid-amount{font-size:1.1rem;color:#333}.bid-status{display:flex;align-items:center;gap:.5rem}.status-label{font-size:.9rem;color:#666}.bid-actions{display:flex;gap:.5rem}.bid-details{padding:1rem;border-top:1px solid #eee}.bid-notes{margin-bottom:1rem}.bid-notes p{margin-top:.5rem;color:#666}.bid-tasks h4{margin-bottom:.75rem;font-size:1rem}.tasks-list{display:flex;flex-direction:column;gap:.75rem}.task-item{display:flex;justify-content:space-between;align-items:center;background-color:#f9f9f9;padding:.75rem;border-radius:4px}.task-info{flex:1}.task-description{font-weight:500;margin-bottom:.25rem}.task-details{font-size:.9rem;color:#666}.task-actions{display:flex;gap:.5rem}.task-status{font-size:.8rem;padding:.25rem .5rem;border-radius:4px;font-weight:500}.task-status.accepted{background-color:#28a7451a;color:#28a745}.task-status.rejected{background-color:#dc35451a;color:#dc3545}.bid-approval-actions{display:flex;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.no-bids{padding:2rem;text-align:center;color:#666;background-color:#f9f9f9;border-radius:8px}.text-muted{color:#888;font-size:.9rem;margin-top:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--card-bg);border-radius:8px;box-shadow:0 4px 12px #00000026;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #eee}.modal-body{padding:1rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}select.input{background-color:var(--card-bg)}.input-readonly{background-color:#f9f9f9;cursor:not-allowed}.tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.task-form{background-color:#f9f9f9;padding:.75rem;border-radius:4px;margin-bottom:.75rem}.task-form-row{display:flex;gap:.5rem;margin-bottom:.5rem}.task-form-row:last-child{margin-bottom:0}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem;border-top:1px solid #eee}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}.btn-sm{padding:.25rem .5rem;font-size:.875rem}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0069d9}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-outline{background-color:transparent;border:1px solid #ddd;color:#333}.btn-outline:hover{background-color:#f0f0f0}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#666}.error-message{padding:.75rem;margin-bottom:1rem;color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px}.bid-card{background-color:var(--card-bg);border-radius:8px;box-shadow:0 2px 4px #0000001a;border:1px solid #eee;margin-bottom:12px;overflow:visible;transition:all .2s ease}.bid-card:hover{box-shadow:0 4px 8px #00000026}.bid-card.full-bid{border-left:4px solid #28a745}.bid-header{padding:16px;display:grid;grid-template-columns:40px 1fr 1fr 1fr auto auto;align-items:center;gap:16px;cursor:pointer}.bid-number{display:flex;align-items:center;gap:6px;font-weight:700;color:#555}.bid-contractor{display:flex;align-items:center;gap:8px;font-weight:500}.bid-dates{display:flex;align-items:center;gap:8px;color:#666}.bid-price{display:flex;align-items:center;gap:8px;font-weight:600;color:#333}.bid-type{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase;display:flex;align-items:center;justify-content:center}.bid-type.full{background-color:#28a7451a;color:#28a745}.bid-type.partial{background-color:#dc35451a;color:#dc3545}.bid-actions{display:flex;gap:8px;align-items:center}.bid-tasks-breakdown{padding:16px;background-color:#f9f9f9;border-top:1px solid #eee;margin-top:0;overflow:visible;transition:all .2s ease}.bid-tasks-breakdown h4{margin-top:0;margin-bottom:12px;font-size:1rem;color:#444}.tasks-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.task-item{display:flex;justify-content:space-between;align-items:center;background-color:var(--card-bg);padding:10px 12px;border-radius:6px;border:1px solid #eee}.task-name{font-weight:500}.task-price{font-weight:600;color:#333}.tasks-total{margin-top:8px;padding:12px;border-top:1px dashed #ddd;text-align:right;font-size:1.1rem}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#444}.form-group select,.form-group input[type=text],.form-group input[type=number],.form-group input[type=date]{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:.95rem}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input{margin:0}.task-form{display:grid;grid-template-columns:1fr 120px auto;gap:8px;background-color:var(--card-bg);padding:12px;border-radius:6px;border:1px solid #eee;margin-bottom:8px}.modal-overlay{background-color:#0009}.modal-content{max-width:650px}.modal-header{padding:16px}.modal-body{padding:20px}.modal-footer{padding:16px;display:flex;justify-content:flex-end;gap:12px}.btn{padding:8px 16px;border-radius:6px;font-weight:500;transition:all .2s ease}.btn-sm{padding:4px 8px;font-size:.8rem}.bid-type.partial{background-color:#dc354526;color:#dc3545;font-weight:700;border:1px solid rgba(220,53,69,.3)}.bid-card.partial-bid{border-left:4px solid #dc3545}.bid-tasks-breakdown{padding:16px;background-color:#f9f9f9;border-top:1px solid #eee;animation:fadeIn .3s ease-in-out}.task-item{display:flex;justify-content:space-between;align-items:center;background-color:var(--card-bg);padding:10px 12px;border-radius:6px;border:1px solid #eee;margin-bottom:6px;transition:all .2s ease}.task-item:hover{transform:translateY(-2px);box-shadow:0 2px 5px #0000001a}.bids-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;min-height:0}.bids-header h3{margin:0;font-size:1.1rem;font-weight:500}.add-bid-button{margin-left:auto;padding:.3rem .7rem;font-size:.95rem;height:2rem;display:flex;align-items:center;gap:.3rem}@media (max-width: 768px){.bids-section{padding:.75rem}.bids-header{flex-direction:column;align-items:stretch;gap:1rem;padding:1rem 0}.add-bid-button{margin-left:0;width:100%;justify-content:center}.bid-card{margin-bottom:1rem}.bid-header{grid-template-columns:1fr;gap:.75rem;padding:1rem;text-align:left}.bid-number{justify-content:flex-start;font-size:.9rem}.bid-contractor{justify-content:flex-start;font-size:1rem;font-weight:600}.bid-dates{justify-content:flex-start;font-size:.9rem;color:#666}.bid-price{justify-content:flex-start;font-size:1.1rem;font-weight:600;color:#059669}.bid-type{align-self:flex-start;width:fit-content;font-size:.8rem;padding:4px 8px}.bid-actions{justify-content:flex-end;gap:.5rem;margin-top:.5rem}.bid-tasks-breakdown{padding:1rem}.task-form{grid-template-columns:1fr;gap:.75rem;padding:1rem}.task-form input{width:100%}.tasks-header{flex-direction:column;align-items:stretch;gap:.75rem}.modal-content{max-width:95vw;max-height:95vh;margin:1rem;overflow-y:auto}.modal-header,.modal-body,.modal-footer{padding:1rem}.form-row{flex-direction:column;gap:1rem}.form-group{margin-bottom:1rem}.form-group input,.form-group select{font-size:16px}}@media (max-width: 480px){.bids-section{padding:.5rem}.bid-header,.bid-tasks-breakdown{padding:.75rem}.task-form{padding:.75rem;gap:.5rem}.btn{font-size:.875rem;padding:.75rem 1rem}.btn-sm{font-size:.8rem;padding:.5rem .75rem}.modal-content{margin:.5rem}}.project-detail{max-width:none;width:100%;margin:0;padding:1.5rem 2rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.project-detail-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:2rem;padding:2rem 2.5rem;background:linear-gradient(135deg,#fff,#fafbfc);border-radius:1.25rem;box-shadow:0 .25rem 1rem #0000001a,0 .125rem .375rem #0000000d;border:.0625rem solid #e2e8f0;gap:1rem;position:relative;overflow:hidden}.project-detail-header .btn{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;font-size:.875rem;transition:all .2s ease;border:.0625rem solid transparent}.project-detail-header .btn-secondary{background:#f1f5f9;color:#475569;border-color:#e2e8f0}.project-detail-header .btn-secondary:hover{background:#e2e8f0;color:#334155}.project-detail-header .btn-primary{background:#0f172a;color:#fff}.project-detail-header .btn-primary:hover{background:#1e293b}.project-detail-header .btn-danger{background:#ef4444;color:#fff}.project-detail-header .btn-danger:hover{background:#dc2626}.header-quick-actions{flex-basis:100%;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.project-detail-content{display:flex;flex-direction:column;gap:2rem;width:100%;margin:0}.project-header-card{background:linear-gradient(135deg,#fff,#fafbfc);border-radius:1.25rem;padding:2.5rem;box-shadow:0 .25rem 1rem #0000001a,0 .125rem .375rem #0000000d;border:.0625rem solid #e2e8f0;width:100%;position:relative;overflow:hidden}.project-content-grid{display:grid;grid-template-columns:2fr 1fr;gap:3rem;align-items:start;width:100%}.project-main-content{display:flex;flex-direction:column;gap:1.5rem}.project-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:2rem}.email-section-bottom{grid-column:1 / -1;margin-top:2rem}.project-header-info{display:flex;align-items:center;justify-content:space-between;gap:2rem}.project-title-section h1{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;color:#0f172a;letter-spacing:-.025em;line-height:1.2}.project-meta{display:flex;align-items:center;gap:1rem;color:#64748b;font-size:.875rem;margin-bottom:1rem}.project-meta-item{display:flex;align-items:center;gap:.25rem}.project-header-info h1 input{font-size:2.5rem;font-weight:800;background:transparent;border:2px solid #e2e8f0;border-radius:8px;padding:.5rem;color:#0f172a;min-width:200px;transition:border-color .2s ease}.project-header-info h1 input:focus{outline:none;border-color:#0f172a}.project-email-section{border-radius:14px;padding:2rem;margin-top:1rem;margin-bottom:2rem;display:flex;flex-direction:column;align-items:flex-start}.placeholder-email{color:#64748b;font-size:1rem;font-style:italic;padding:1rem 0;width:100%;text-align:left}.status-badge{display:inline-flex;align-items:center;padding:.6rem 1.2rem;border-radius:20px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:2px solid;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.status-badge.draft{background-color:#6b7280;color:#fff;border-color:#4b5563}.status-badge.anbudsrunde{background-color:#f59e0b;color:#fff;border-color:#d97706}.status-badge.mottatt_bud{background-color:#e0f2fe;color:#0369a1;border-color:#0284c7}.status-badge.akseptert_oppdrag{background-color:#10b981;color:#fff;border-color:#059669}.status-badge.oppstartsjekkliste{background-color:#3b82f6;color:#fff;border-color:#2563eb}.status-badge.avsluttingsjekkliste{background-color:#6366f1;color:#fff;border-color:#4f46e5}.status-badge.ferdig_prosjekt{background-color:#22c55e;color:#fff;border-color:#16a34a}.status-badge.betalt{background-color:#15803d;color:#fff;border-color:#166534}.status-badge.sendt-inn-review{background-color:#fbbf24;color:#92400e;border-color:#f59e0b}.status-badge.tapt{background-color:#ef4444;color:#fff;border-color:#dc2626}.status-badge.kansellert{background-color:#991b1b;color:#fff;border-color:#7f1d1d}.info-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:2.5rem}.section{background:var(--card-bg);border-radius:16px;padding:2rem;box-shadow:0 2px 6px #0000000f;border:1px solid #e2e8f0;transition:all .2s ease}.section:hover{box-shadow:0 4px 6px #00000012;border-color:#cbd5e1}.section h2{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700;margin:0 0 1.5rem;color:#0f172a;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.section h2 svg{width:20px;height:20px;color:#64748b}.project-right-column{display:flex;flex-direction:column;gap:2.5rem;height:fit-content}.section{background:linear-gradient(135deg,#fff,#fafbfc);border:.0625rem solid #e2e8f0;border-radius:1.25rem;padding:2.5rem;box-shadow:0 .25rem 1rem #00000014,0 .125rem .375rem #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.section:hover{transform:translateY(-.125rem);box-shadow:0 .5rem 2rem #0000001f,0 .25rem .75rem #00000014}.section.full-width{grid-column:1 / -1}.section.task-section{height:fit-content;margin-bottom:2rem}.section.timeline-section{height:fit-content}.section h2{font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;color:var(--text-primary);display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.field-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.field{display:flex;flex-direction:column;gap:.25rem}.field label{font-weight:600;font-size:.8rem;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.125rem}.field span{font-size:.95rem;color:#0f172a;min-height:1.5rem;display:flex;align-items:center;padding:.375rem 0;font-weight:500}.field a{color:#0f172a;text-decoration:none;font-weight:600;transition:color .2s ease}.field a:hover{color:#475569;text-decoration:underline}.input,.select,.textarea{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;background:var(--card-bg);color:#0f172a;font-size:.95rem;font-weight:500;transition:all .2s ease;font-family:inherit}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:#0f172a;box-shadow:0 0 0 3px #0f172a1a}.textarea{resize:vertical;min-height:120px;line-height:1.5}.comment-display{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;min-height:120px;white-space:pre-wrap;color:#475569;line-height:1.6;font-size:.9rem}.field span.total-sum{font-size:1.75rem;font-weight:800;color:#0f172a;margin-top:1.25rem;background:linear-gradient(135deg,#0f172a,#1e293b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.items-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.items-list li{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.items-list li:hover{background:#f1f5f9;border-color:#cbd5e1}.items-list-empty{color:#64748b;font-style:italic;padding:1rem;text-align:center;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1}.items-form{display:flex;gap:.5rem;margin-top:1rem;align-items:flex-end}.items-form .input{flex:1}.items-form .btn{padding:.75rem 1rem;min-width:auto}.amount{font-weight:600}.amount.positive{color:#059669}.amount.negative{color:#dc2626}.error-message{background:#fef2f2;color:#991b1b;padding:1rem 1.25rem;border-radius:8px;border:1px solid #fecaca;margin-bottom:1rem;font-weight:500}.info-message{background:#eff6ff;color:#1e40af;padding:1rem 1.25rem;border-radius:8px;border:1px solid #bfdbfe;margin-bottom:1rem;font-weight:500}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;font-family:inherit}.btn svg{width:16px;height:16px}.btn-primary{background:#0f172a;color:#fff}.btn-primary:hover:not(:disabled){background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 8px #0f172a4d}.btn-secondary{background:var(--card-bg);color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 8px #ef44444d}.status-select{padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:2px solid #e2e8f0;background:var(--card-bg);color:#374151;cursor:pointer;transition:all .2s ease}.status-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.compact-field{display:flex;flex-direction:column;gap:.25rem}.compact-field-content{display:flex;flex-direction:column;gap:.125rem}.compact-field-content>div{display:flex;flex-direction:column;gap:.125rem}.compact-field-text{flex:1;min-width:0;word-break:break-word}.compact-ratings{display:flex;flex-direction:column;gap:.125rem;flex:1}.compact-rating{font-size:.875rem;color:var(--text-secondary)}.compact-btn{padding:.375rem .75rem;font-size:.75rem;white-space:nowrap}.compact-field-dotted-btn{background:none;border:none;color:var(--primary-color);font-size:.6875rem;padding:.125rem .25rem;margin-top:.25rem;cursor:pointer;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;transition:all .2s ease;display:inline-block}.compact-field-dotted-btn:hover{color:var(--primary-dark);text-decoration-style:solid;transform:scale(1.05)}.compact-field-dotted-btn:focus{outline:1px dotted var(--primary-color);outline-offset:2px}.status-description{font-size:.75rem;color:var(--text-secondary)}.section.bids-section{margin-top:1rem}.section.ai-estimation-section{margin-top:1rem;padding:0;background:transparent;border:none;box-shadow:none}.section.ai-estimation-section:hover{transform:none;box-shadow:none}.bids-content{display:flex;flex-direction:column;gap:1rem;min-height:615px;max-height:615px;overflow-y:auto;padding-right:.5rem}.bids-content::-webkit-scrollbar{width:6px}.bids-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:8px}.bids-content::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:8px}.financial-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem}.financial-left,.financial-right{display:flex;flex-direction:column;gap:1.5rem}.field-value{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.field-value>span{font-size:1.1rem;font-weight:600;color:#0f172a}.field-value .total-sum{font-size:1.4rem;font-weight:700;color:#059669}.mva-text{font-size:.875rem;color:#64748b;font-style:italic;padding-left:.5rem;border-left:3px solid #e2e8f0;margin-top:.25rem}.financial-grid .field{background:#f8fafc;padding:1.25rem;border-radius:12px;border:1px solid #e2e8f0;transition:all .2s ease}.financial-grid .field:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 8px #00000014}.financial-grid .field label{font-size:.875rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;display:block}@media (max-width: 768px){.financial-grid{grid-template-columns:1fr;gap:1rem}.financial-left,.financial-right{gap:1rem}.financial-grid .field{padding:1rem}.field-value .total-sum{font-size:1.2rem}.items-form{flex-direction:column;gap:.75rem;align-items:stretch}.items-form .btn{width:100%;justify-content:center}.items-list li{flex-direction:column;align-items:flex-start;gap:.75rem}.items-list li>div:last-child{align-self:flex-end}}@media (max-width: 480px){.financial-grid .field{padding:.75rem}.field-value>span{font-size:1rem}.field-value .total-sum{font-size:1.1rem}.mva-text{font-size:.8rem}}.total-sum{background:linear-gradient(135deg,#059669,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800;letter-spacing:-.02em}.financial-grid .field:has(.amount){background:linear-gradient(135deg,#fef3c7,#fef7cd);border-color:#f59e0b}.financial-grid .field:has(.amount.negative){background:linear-gradient(135deg,#fef2f2,#fef7f7);border-color:#f87171}.financial-grid .field:has(.amount.positive){background:linear-gradient(135deg,#f0fdf4,#f7fef7);border-color:#10b981}@media (max-width: 48rem){.project-detail{padding:.75rem}.project-detail-header{flex-direction:column;gap:1rem;align-items:stretch;padding:1.5rem;margin-bottom:1rem}.header-actions{justify-content:center}.project-header-info{flex-direction:column;align-items:flex-start;gap:1rem}.project-title-section h1{font-size:1.75rem}.project-header-info h1 input{font-size:1.75rem;min-width:9.375rem}.project-email-section{padding:1.5rem;margin-top:1rem;margin-bottom:1rem}.project-content-grid{grid-template-columns:1fr;gap:1rem}.project-sidebar{position:static;order:2}.project-main-content{order:1}.email-section-bottom{order:3;margin-top:.75rem;padding:1.5rem}.info-sections{grid-template-columns:1fr;gap:1rem}.section{padding:1rem;margin-bottom:.5rem}.section h2{font-size:1.125rem;margin-bottom:1rem}.field-group{grid-template-columns:1fr;gap:1rem}.items-form{flex-direction:column;gap:.75rem}.btn{justify-content:center;width:100%;padding:.75rem 1rem}.header-actions .btn{width:auto;flex:1}.review-ratings-summary{flex-direction:column;gap:.5rem}.no-review{flex-direction:column;align-items:flex-start;gap:.5rem}.cancellation-reason-display,.project-review-section{padding:.75rem}.project-main-content,.project-sidebar{gap:1rem}}@media (min-width: 48.0625rem) and (max-width: 64rem){.project-content-grid{grid-template-columns:1.5fr 1fr;gap:2rem}.project-sidebar{position:static}.section{padding:1.5rem}}@media (min-width: 80rem){.project-detail{padding:2rem 4rem}.project-content-grid{grid-template-columns:2.5fr 1fr;gap:4rem}.project-sidebar{position:sticky;top:2rem}}@media (max-width: 1600px){.project-detail-content{grid-template-columns:1.8fr 1fr;gap:2.5rem}}@media (max-width: 1400px){.project-detail-content{grid-template-columns:1.6fr 1fr;gap:2rem}.project-detail{padding:1.5rem}.info-sections{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}}@media (max-width: 1200px){.project-detail-content{grid-template-columns:1fr}.project-main-content{order:1}.project-right-column{order:2}}@media (max-width: 768px){.project-detail{padding:1rem}.project-detail-header{flex-direction:column;gap:1rem;align-items:stretch;padding:1.5rem}.header-actions{justify-content:center}.project-header-info{flex-direction:column;align-items:flex-start;gap:1rem}.project-title-section h1{font-size:2rem}.project-header-info h1 input{font-size:2rem;min-width:150px}.project-email-section{padding:1.5rem}.info-sections{grid-template-columns:1fr}.section{padding:1.25rem}.field-group{grid-template-columns:1fr}.items-form{flex-direction:column;gap:.75rem}.btn{justify-content:center;width:100%}.header-actions .btn{width:auto;flex:1}}@media (max-width: 768px){.customer-info-section .field{flex-direction:column;align-items:flex-start;gap:.5rem}.customer-info-section .field label{font-weight:600;margin-bottom:.25rem}.customer-info-section .field span,.customer-info-section .field input{width:100%;text-align:left}}@media (max-width: 768px){.contractor-section .field{flex-direction:column;align-items:flex-start;gap:.5rem}.contractor-section .field label{font-weight:600;margin-bottom:.25rem}.contractor-section .field span,.contractor-section .field input{width:100%;text-align:left}}@media (max-width: 768px){.bids-section{padding:1rem}.bids-content{min-height:auto;max-height:none;overflow-y:visible}.bid-header{grid-template-columns:1fr;gap:.75rem;padding:1rem}.bid-number,.bid-contractor,.bid-dates,.bid-price{justify-content:flex-start}.bid-type{align-self:flex-start;width:fit-content}.bid-actions{justify-content:flex-end;gap:.5rem}.bid-tasks-breakdown{padding:1rem}.task-form{grid-template-columns:1fr;gap:.75rem}.modal-content{max-width:95vw;margin:1rem}.form-row{flex-direction:column;gap:1rem}}@media (max-width: 768px){.financial-right .field{padding:1rem}.items-form{flex-direction:column;gap:.75rem}.items-form input{width:100%}.items-form .btn{width:100%;justify-content:center}.items-list .item{flex-direction:column;align-items:flex-start;gap:.5rem}.items-list .item .item-actions{align-self:flex-end}}@media (max-width: 768px){.project-timeline{padding:1.5rem 1rem}.timeline-track{overflow-x:auto;padding-bottom:1rem}.timeline-step{min-width:80px}.step-label{font-size:.75rem;line-height:1.2}}@media (max-width: 768px){.email-section-bottom,.email-section-bottom .section{padding:1rem}}@media (max-width: 480px){.project-detail{padding:.5rem}.section,.financial-left,.financial-right .field{padding:1rem}.bid-header,.bid-tasks-breakdown{padding:.75rem}.btn{padding:.75rem 1rem;font-size:.875rem}.btn-sm{padding:.5rem .75rem;font-size:.8rem}}.project-inclusion-section{margin-top:1rem;padding:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.project-inclusion-section h3{margin:0 0 1rem;color:#374151;font-size:1.125rem;font-weight:600}.inclusion-toggles{display:flex;flex-direction:column;gap:1rem}.toggle-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.toggle-item:last-child{border-bottom:none}.toggle-label{font-weight:500;color:#374151;font-size:.9rem}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--card-bg);transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background-color:#10b981}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 3px #10b9811a}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.saving-indicator{margin-top:.5rem;font-size:.875rem;color:#6b7280;font-style:italic;display:flex;align-items:center;gap:.5rem}.saving-indicator:before{content:"";width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #6b7280;border-radius:50%;animation:spin 1s linear infinite}.section.memory-points-section,.section.deviations-section{padding:2rem;background:linear-gradient(135deg,#fff,#fafbfc);border:.0625rem solid #e2e8f0;border-radius:1.25rem;box-shadow:0 .25rem 1rem #00000014,0 .125rem .375rem #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1)}.section.memory-points-section:hover,.section.deviations-section:hover{transform:translateY(-.125rem);box-shadow:0 .5rem 2rem #0000001f,0 .25rem .75rem #00000014}.section.memory-points-section h3,.section.deviations-section h3{font-size:1.125rem;font-weight:700;margin:0 0 1.5rem;color:#0f172a;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.section.memory-points-section>div,.section.deviations-section>div{background:transparent;border:none;box-shadow:none;padding:0;border-radius:0}.memory-item{border-left:3px solid #6b7280}.deviation-item{border-left:3px solid #374151}.memory-dot{background:#6b7280}.deviation-dot{background:#374151}.memory-point-description,.deviation-description{margin:.75rem 0;font-size:.9rem;color:#374151;line-height:1.5}.memory-point-status,.deviation-status{display:flex;align-items:center;gap:.25rem}.memory-point-system,.deviation-system{font-size:.8rem;color:#6b7280;display:flex;align-items:center;gap:.25rem}.memory-point-dates,.deviation-dates{font-size:.8rem;color:#6b7280;display:flex;flex-direction:column;gap:.25rem}.memory-item-modal,.deviation-item-modal{position:relative;padding:1.5rem;background:var(--card-bg);border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.memory-item-modal:hover,.deviation-item-modal:hover{background:var(--card-bg);border-color:#d1d5db;transform:none;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@media (max-width: 768px){.section.memory-points-section,.section.deviations-section{padding:1.25rem;border-radius:1rem}.section.memory-points-section h3,.section.deviations-section h3{font-size:1rem;margin-bottom:1rem}.memory-item-modal,.deviation-item-modal{padding:1rem;margin:.5rem}}@media (min-width: 769px) and (max-width: 1024px){.financial-grid{gap:1.5rem}.bid-header{grid-template-columns:30px 1fr 1fr 1fr auto auto;gap:1rem}.bids-content{max-height:500px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-title{display:flex;align-items:center;gap:.75rem}.modal-title h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:6px;transition:background-color .2s}.modal-close:hover{background-color:#f1f5f9}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e2e8f0;background-color:#f8fafc}.cancellation-modal{width:100%;max-width:500px}.cancellation-explanation{margin-bottom:1rem;color:var(--text-secondary);line-height:1.5}.cancellation-textarea{width:100%;min-height:100px;resize:vertical}.review-modal{width:100%;max-width:700px}.review-modal-body{max-height:70vh}.review-section{margin-bottom:2rem}.review-section:last-child{margin-bottom:0}.review-section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:.5rem;border-bottom:2px solid #e2e8f0}.review-ratings{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.5rem}.star-rating-container{display:flex;align-items:center;gap:1rem}.star-rating-label{flex:1;font-weight:500;color:var(--text-primary);min-width:200px}.star-rating{display:flex;gap:.25rem}.star{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s;color:#e2e8f0}.star:hover{transform:scale(1.1)}.star-filled{color:#fbbf24}.star-empty{color:#e2e8f0}.feedback-section{margin-top:1.5rem}.feedback-label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.feedback-textarea{width:100%;min-height:80px;resize:vertical}.transfer-modal{width:100%;max-width:500px}.transfer-project-info{background-color:#f8fafc;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.transfer-project-info p{margin:.5rem 0;color:var(--text-secondary)}.transfer-project-info p:first-child{margin-top:0}.transfer-project-info p:last-child{margin-bottom:0}.transfer-form{margin-bottom:1rem}.transfer-form label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.transfer-form select{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem}.transfer-error{color:#dc2626;background-color:#fef2f2;padding:.75rem 1rem;border-radius:6px;margin-top:1rem;font-size:.875rem}.transfer-success{text-align:center;padding:2rem}.transfer-success .success-icon{width:60px;height:60px;background-color:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}.transfer-success p{margin:.5rem 0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.transfer-success .success-subtitle{font-weight:400;font-size:.875rem;color:var(--text-secondary)}@media (max-width: 768px){.modal-content{margin:1rem;max-width:calc(100vw - 2rem)}.modal-header,.modal-body,.modal-footer{padding:1rem}.review-modal-body{max-height:60vh}.star-rating-container{flex-direction:column;align-items:flex-start;gap:.5rem}.star-rating-label{min-width:auto}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}[data-theme=dark] .modal-overlay{background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}[data-theme=dark] .modal-content{background:var(--card-bg);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 60px #00d4ff4d,0 20px 40px #00000080;animation:modalGlow 3s ease-in-out infinite}@keyframes modalGlow{0%,to{box-shadow:0 0 60px #00d4ff4d,0 20px 40px #00000080}50%{box-shadow:0 0 80px #00d4ff66,0 20px 40px #00000080}}[data-theme=dark] .modal-header{border-bottom:1px solid rgba(0,212,255,.15);background:linear-gradient(135deg,#00d4ff0d,#7c3aed0d)}[data-theme=dark] .modal-title h2{color:var(--text-primary);text-shadow:0 0 20px rgba(0,212,255,.3)}[data-theme=dark] .modal-close{color:var(--text-secondary)}[data-theme=dark] .modal-close:hover{background-color:#00d4ff1a;color:var(--accent-color);box-shadow:0 0 15px #00d4ff4d}[data-theme=dark] .modal-footer{border-top:1px solid rgba(0,212,255,.15);background:linear-gradient(135deg,#0f141980,#1a1f2980)}[data-theme=dark] .cancellation-explanation{color:var(--text-secondary)}[data-theme=dark] .review-section-title{color:var(--text-primary);border-bottom:2px solid rgba(0,212,255,.3);text-shadow:0 0 15px rgba(0,212,255,.2)}[data-theme=dark] .star-rating-label,[data-theme=dark] .feedback-label{color:var(--text-primary)}[data-theme=dark] .star-empty{color:#fff3}[data-theme=dark] .star-filled{color:#fbbf24;filter:drop-shadow(0 0 8px rgba(251,191,36,.6))}[data-theme=dark] .transfer-project-info{background:#00d4ff14;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .transfer-project-info p{color:var(--text-secondary)}[data-theme=dark] .transfer-form label{color:var(--text-primary)}[data-theme=dark] .transfer-form select{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .transfer-form select:focus{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .transfer-error{background-color:#ff5c5c26;color:#ff8a8a;border:1px solid rgba(255,92,92,.3)}[data-theme=dark] .transfer-success .success-icon{background:var(--gradient-primary);box-shadow:0 0 30px #00d4ff80}[data-theme=dark] .transfer-success p{color:var(--text-primary)}[data-theme=dark] .transfer-success .success-subtitle{color:var(--text-secondary)}.project-timeline{padding:2.5rem;background:linear-gradient(135deg,#fff,#fafbfc);border-radius:1.25rem;box-shadow:0 .25rem 1rem #00000014,0 .125rem .375rem #0000000a;border:.0625rem solid #e2e8f0;margin-bottom:2rem;position:relative;overflow:hidden}.timeline-track{display:flex;align-items:center;position:relative;padding:1rem 0;overflow-x:auto;gap:1.5rem;justify-content:space-between}.timeline-step{display:flex;flex-direction:column;align-items:center;position:relative;flex:0 0 auto;min-width:8rem;padding:0 .5rem}.step-marker{width:1.25rem;height:1.25rem;border-radius:50%;background-color:#e2e8f0;z-index:2;border:.125rem solid #e2e8f0}.step-label{margin-top:.75rem;font-size:.8rem;font-weight:600;text-align:center;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2;padding:0 .25rem}.step-connector{position:absolute;height:.125rem;background-color:#e2e8f0;top:.625rem;width:calc(100% + 1.5rem);left:50%;z-index:1}.timeline-step.complete .step-marker{background-color:#22c55e;border-color:#22c55e}.timeline-step.complete .step-connector{background-color:#22c55e}.timeline-step.complete .step-label{color:#16a34a}.timeline-step.current .step-marker{background-color:var(--card-bg);border-color:#3b82f6;border-width:.1875rem}.timeline-step.current .step-label{color:#2563eb;font-weight:700}.step-connector.next{background-image:repeating-linear-gradient(to right,#3b82f6 0,#3b82f6 .5rem,transparent .5rem,transparent 1rem);background-size:1rem .125rem;background-repeat:repeat-x;background-color:transparent!important;animation:dash-move 2s linear infinite}.timeline-step.next .step-marker{background-color:var(--card-bg);border:.1875rem dashed #3b82f6;box-shadow:0 0 0 .125rem #3b82f61a;animation:pulse-next 2s infinite}@keyframes pulse-next{0%,to{box-shadow:0 0 0 .125rem #3b82f61a}50%{box-shadow:0 0 0 .25rem #3b82f633}}@keyframes dash-move{0%{background-position:0 0}to{background-position:1rem 0}}.timeline-step.next .step-label{color:#3b82f6;font-weight:600}.timeline-step.failed .step-marker{background-color:#ef4444;border-color:#ef4444}.timeline-step.failed .step-connector{background-color:#ef4444}.timeline-step.failed .step-label{color:#b91c1c}.timeline-failure-status{display:flex;justify-content:center;margin-top:1rem}.failure-badge{display:inline-block;padding:.5rem 1rem;background-color:#fecaca;color:#b91c1c;font-weight:600;border-radius:62.4375rem;text-transform:uppercase;font-size:.8rem;letter-spacing:.05em}@media (max-width: 48rem){.project-timeline{padding:1rem}.timeline-track{padding-bottom:2rem;gap:1rem}.timeline-step{min-width:6rem;padding:0 .25rem}.step-label{font-size:.75rem;white-space:normal;word-break:break-word}}.email-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;margin-bottom:20px;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.email-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background-color:#fff}.email-header h2{margin:0;display:flex;align-items:center;gap:8px;font-weight:600;color:#2c3e50;font-size:1.3rem}.email-controls{display:flex;gap:10px}.btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;outline:none}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#f1f3f5;color:#495057}.btn-secondary:hover{background-color:#e9ecef}.btn:disabled{opacity:.6;cursor:not-allowed}.email-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin-bottom:16px}.email-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px 20px;color:#6c757d;text-align:center}.email-empty svg{color:#adb5bd;margin-bottom:16px}.email-empty h3{margin-top:0;margin-bottom:8px;font-weight:600;color:#495057}.email-empty p{margin-top:0;max-width:400px}.email-error{display:flex;align-items:center;gap:10px;background-color:#fff3f3;color:#e74c3c;padding:12px 16px;border-radius:6px;margin:16px 20px;position:relative}.error-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;color:#e74c3c;cursor:pointer;padding:0;line-height:1}.email-tabs{display:flex;background-color:#fff;border-bottom:1px solid #e9ecef;padding:0 20px}.tab{display:flex;align-items:center;gap:8px;padding:12px 16px;background:none;border:none;border-bottom:2px solid transparent;color:#6c757d;font-weight:500;cursor:pointer;transition:all .2s ease}.tab:hover{color:#495057}.tab.active{color:#3498db;border-bottom-color:#3498db}.email-content{padding:20px}.conversation-card{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden;margin-bottom:16px;transition:box-shadow .2s ease}.conversation-card:hover{box-shadow:0 4px 12px #0000000d}.conversation-header{display:flex;justify-content:space-between;align-items:center;padding:16px;cursor:pointer;background-color:#fff;transition:background-color .2s ease}.conversation-header:hover{background-color:#f8f9fa}.conversation-info{flex:1}.conversation-subject{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:8px;color:#2c3e50}.conversation-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:.85rem;color:#6c757d}.participants,.message-count,.last-message{display:flex;align-items:center;gap:4px}.conversation-toggle{color:#6c757d}.conversation-content{padding:0 16px 16px}.conversation-messages{border-radius:6px;overflow:hidden}.conversation-message{padding:16px;border-radius:6px;margin-bottom:12px;background-color:#fff;box-shadow:0 1px 3px #0000000d;position:relative}.conversation-message.from-company{background-color:#fff;border-left:4px solid #3498db}.conversation-message.from-customer{background-color:#fff;border-left:4px solid #e67e22}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.message-from{display:flex;align-items:center;gap:6px;font-weight:500}.sender-name{color:#495057;font-weight:600}.company-badge{background-color:#3498db;color:#fff;font-size:.75rem;padding:3px 8px;border-radius:12px;font-weight:500;margin-left:4px}.customer-badge{background-color:#e67e22;color:#fff;font-size:.75rem;padding:3px 8px;border-radius:12px;font-weight:500;margin-left:4px}.message-date{color:#6c757d;font-size:.8rem}.message-content{color:#212529;line-height:1.6;max-height:none;overflow:visible;white-space:pre-wrap;word-break:break-word}.message-separator{height:1px;background-color:#e9ecef;margin:16px 0}.system-email{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;overflow:hidden;margin-bottom:16px;transition:box-shadow .2s ease;box-shadow:0 1px 3px #0000000d}.system-email:hover{box-shadow:0 4px 12px #0000000d}.system-email-header{padding:16px;cursor:pointer;position:relative;transition:background-color .2s ease}.system-email-header:hover{background-color:#f8f9fa}.email-toggle{position:absolute;top:16px;right:16px;color:#6c757d}.email-content-expanded{padding:0 16px 16px;border-top:1px solid #e9ecef}.email-header-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-right:24px}.email-subject{display:flex;align-items:center;gap:8px;font-weight:600;color:#2c3e50}.email-date{display:flex;align-items:center;gap:4px;color:#6c757d;font-size:.85rem}.email-recipients{color:#6c757d;font-size:.85rem;margin-bottom:12px;display:flex;flex-direction:column;gap:6px}.email-from{display:flex;align-items:center;gap:6px}.email-to{display:flex;align-items:center;gap:6px;margin-left:20px}.email-snippet{color:#212529;line-height:1.6;padding:8px 0;white-space:pre-wrap;word-break:break-word;max-height:none;overflow:visible}.email-search{padding:16px 20px;background-color:#fff}.search-input-container{position:relative;display:flex;align-items:center;background-color:#fff;border:1px solid #e9ecef;border-radius:8px;padding:12px 16px;gap:12px;transition:border-color .2s ease,box-shadow .2s ease}.search-input-container:focus-within{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.search-input-container svg{color:#6c757d;flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-size:14px;color:#495057;background:transparent}.search-input::placeholder{color:#6c757d}.search-clear{background:none;border:none;color:#6c757d;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0}.search-clear:hover{color:#495057;background-color:#f8f9fa}.search-results-info{margin-top:12px;font-size:13px;color:#6c757d;display:flex;align-items:center;gap:6px}.search-results-info:before{content:"🔍";font-size:12px}.search-highlight{background-color:#fff3cd;color:#856404;padding:2px 4px;border-radius:3px;font-weight:500}@media (max-width: 768px){.email-header{flex-direction:column;align-items:flex-start;gap:12px}.conversation-meta{flex-direction:column;gap:8px}.message-header{flex-direction:column;align-items:flex-start;gap:6px}.email-header-info{flex-direction:column;align-items:flex-start;gap:8px}}.handover-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#6b7280;color:#f8fafc;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.handover-button:hover{background:#4b5563}.handover-button:disabled{background:#9ca3af;cursor:not-allowed}.handover-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.handover-modal{background:var(--card-bg);border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a;max-width:500px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.handover-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.handover-modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.close-button{background:none;border:none;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:background-color .2s}.close-button:hover{background:#f3f4f6}.handover-modal-body{padding:1.5rem;overflow-y:auto}.handover-description{margin:0 0 1.5rem;color:#6b7280;font-size:.875rem;line-height:1.5}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem}.form-group select{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;color:#111827;background:var(--card-bg);cursor:pointer}.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group select:disabled{background:#f3f4f6;cursor:not-allowed}.handover-modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e5e7eb}.cancel-button,.submit-button{padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.cancel-button{background:var(--card-bg);color:#374151;border:1px solid #d1d5db}.cancel-button:hover:not(:disabled){background:#f9fafb}.submit-button{background:#3b82f6;color:#fff}.submit-button:hover:not(:disabled){background:#2563eb}.cancel-button:disabled,.submit-button:disabled{opacity:.5;cursor:not-allowed}.autocomplete-container{position:relative;width:100%}.autocomplete-label{display:block;margin-bottom:6px;font-weight:500;color:#495057;font-size:14px}.autocomplete-label .required{color:#dc3545;margin-left:2px}.autocomplete-input-wrapper{position:relative}.autocomplete-input{width:100%;padding:12px 16px;border:2px solid #e9ecef;border-radius:6px;font-size:16px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box;background-color:var(--card-bg)}.autocomplete-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--card-bg);border:1px solid #e9ecef;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;overflow-y:auto;margin-top:2px}.autocomplete-loading{padding:16px;text-align:center;color:#6c757d;font-style:italic}.autocomplete-option{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f8f9fa;transition:background-color .2s ease}.autocomplete-option:hover{background-color:#f8f9fa}.autocomplete-option:last-child{border-bottom:none}.option-main{display:flex;align-items:center;gap:8px;margin-bottom:4px}.option-name{font-weight:500;color:#2c3e50}.option-details{display:flex;gap:16px;margin-left:24px;font-size:13px;color:#6c757d}.option-phone,.option-email{flex:1}.autocomplete-no-results{padding:16px;text-align:center;color:#6c757d;font-style:italic}.autocomplete-divider{height:1px;background-color:#e9ecef;margin:8px 0}.autocomplete-create-new{padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:8px;color:#007bff;font-weight:500;background-color:#f8f9ff;transition:background-color .2s ease;border-top:1px solid #e9ecef}.autocomplete-create-new:hover{background-color:#e3f2fd}.autocomplete-create-new svg{color:#007bff}@media (max-width: 768px){.autocomplete-input{font-size:16px;padding:12px 14px}.autocomplete-dropdown{max-height:250px}.option-details{flex-direction:column;gap:4px;margin-left:24px}.autocomplete-option{padding:14px 16px}}:root{--max-width-page: 87.5rem;--max-width-search: 37.5rem;--border-width-thick: .125rem;--border-width-thin: .0625rem;--min-select-width: 9.375rem;--margin-left-sidebar: 15.625rem}.project-manager{max-width:var(--max-width-page);margin:0 auto;padding:1.5rem 2rem;min-height:100vh;background-color:var(--bg-primary)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-8);padding-bottom:var(--spacing-6);border-bottom:var(--border-width-thick) solid var(--border-color)}.header button{display:flex;align-items:center;gap:var(--spacing-2);font-weight:600;min-height:2.75rem}.search-container{margin-bottom:var(--spacing-8)}.modern-filter-container{background:var(--bg-secondary);border-radius:8px;border:1px solid #e1e5e9;padding:1rem;margin-bottom:1.5rem}.filters-section{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}@media (min-width: 768px){.filters-section{flex-wrap:nowrap}}.filters-group{display:flex;align-items:center;gap:1rem;margin-left:auto}.modern-search-input{min-width:300px;padding:.625rem .875rem;border:1px solid #d1d9e0;border-radius:6px;font-size:.9rem;transition:all .2s ease;background-color:var(--card-bg);color:#2c3e50}.modern-search-input:focus{outline:none;border-color:#74a9d8;box-shadow:0 0 0 2px #74a9d826}.modern-search-input::placeholder{color:#8b9dc3}.filter-category{display:flex;flex-direction:column;gap:.375rem}.filter-label{font-size:.75rem;font-weight:600;color:#6b7280;margin:0;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.filter-dropdown{position:relative;min-width:180px}.project-manager .filter-dropdown .dropdown-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;border:1px solid #d1d9e0!important;border-radius:6px;background:#f8f9fa!important;background-color:#f8f9fa!important;background-image:none!important;color:#374151!important;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:38px;box-shadow:0 1px 2px #00000005!important}.project-manager .filter-dropdown .dropdown-button:before{display:none!important}.project-manager .filter-dropdown .dropdown-button:hover{border-color:#b8c5d1;background:#e9ecef!important;background-color:#e9ecef!important;background-image:none!important}.project-manager .filter-dropdown .dropdown-button:hover:before{display:none!important}.project-manager .filter-dropdown .dropdown-button:focus{outline:none;border-color:#74a9d8;box-shadow:0 0 0 2px #74a9d826}.project-manager .filter-dropdown .dropdown-button.open{border-color:#74a9d8;box-shadow:0 0 0 2px #74a9d826}.dropdown-chevron{width:14px;height:14px;color:#8b9dc3;transition:transform .2s ease;flex-shrink:0}.dropdown-chevron.open{transform:rotate(180deg);color:#74a9d8}.project-manager .filter-dropdown .dropdown-content{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:#fff!important;border:1px solid #e1e5e9;border-radius:6px;box-shadow:0 4px 12px #00000014;z-index:50;max-height:280px;overflow-y:auto}.dropdown-option{display:flex;align-items:center;gap:.625rem;padding:.5rem .875rem;color:#2c3e50;font-size:.85rem;cursor:pointer;transition:background-color .15s ease;border-bottom:1px solid #f1f3f4}.dropdown-option:last-child{border-bottom:none}.dropdown-option:hover{background-color:var(--bg-secondary)}.dropdown-option.selected{background-color:#f0f7ff;color:#2563eb}.dropdown-option.selected:hover{background-color:#e8f2ff}.dropdown-checkbox{width:14px;height:14px;border:1px solid #d1d9e0;border-radius:2px;background:var(--card-bg);position:relative;flex-shrink:0;transition:all .15s ease}.dropdown-checkbox.checked{background-color:#2563eb;border-color:#2563eb}.dropdown-checkbox.checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;font-weight:700}.project-manager .filter-dropdown .dropdown-placeholder{color:#6b7280!important;font-weight:400}.dropdown-selected-count{background-color:#dbeafe;color:#1d4ed8;padding:.125rem .375rem;border-radius:8px;font-size:.7rem;font-weight:600;margin-left:.375rem}.filter-actions{display:flex;align-items:center}.clear-filters-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background-color:#f1f3f4;color:#64748b;border:1px solid #e1e5e9;border-radius:6px;font-size:.8rem;font-weight:400;cursor:pointer;transition:all .2s ease;white-space:nowrap}.clear-filters-btn:hover{background-color:#e8eaed;border-color:#d1d9e0;color:#475569}@media (max-width: 768px){.modern-filter-container{padding:.75rem;margin-bottom:1.25rem}.filters-section{flex-direction:column;align-items:stretch;gap:.75rem}.modern-search-input{min-width:auto;width:100%;order:1}.filters-group{margin-left:0;flex-direction:column;gap:.75rem;order:2}.filter-dropdown{min-width:auto;width:100%}.filter-actions{justify-content:center;order:3}.filter-label{font-size:.75rem}}@media (min-width: 769px){.filters-group{flex-direction:row;align-items:flex-end}}@media (max-width: 480px){.dropdown-content{max-height:200px}.dropdown-option{padding:.5rem;font-size:.8rem}}.search-filter-container{display:flex;align-items:center;gap:var(--spacing-8);margin-bottom:var(--spacing-8);padding:var(--spacing-4);background:var(--card-bg);border-radius:.75rem;border:var(--border-width-thin) solid var(--border-color);box-shadow:var(--shadow-sm)}.search-section{flex:1;max-width:var(--max-width-search)}.filter-section{display:flex;align-items:center;gap:var(--spacing-3);flex-shrink:0;transform:translateY(-.0625rem);margin-bottom:var(--spacing-2)}.filter-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);white-space:nowrap}.status-select{padding:var(--spacing-3) var(--spacing-4);border:var(--border-width-thin) solid var(--border-color);border-radius:.5rem;font-size:var(--font-size-sm);background:var(--card-bg);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:var(--min-select-width);min-height:2.75rem}.status-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 .125rem #0000001a}.search-input{width:100%;padding:var(--spacing-3) var(--spacing-4);border:var(--border-width-thick) solid var(--border-color);border-radius:.5rem;font-size:var(--font-size-base);background:var(--card-bg);color:var(--text-primary);transition:all .3s ease;min-height:2.75rem}.filter-controls{background:var(--card-bg);padding:2rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin-bottom:2rem}.filter-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:500;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.error-message{background-color:var(--error-color);color:#fff;padding:1rem;border-radius:6px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--text-primary);border-radius:50%;animation:spin 1s linear infinite}.table-container{background-color:var(--card-bg);border-radius:12px;overflow:hidden;border:2px solid var(--border-color);box-shadow:0 4px 6px #0000000d}.projects-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.projects-table th,.projects-table td{padding:1.25rem;text-align:left;border-bottom:1px solid var(--border-color)}.projects-table th{background:var(--bg-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);border-bottom:2px solid var(--border-color)}.projects-table tbody tr{transition:background .2s ease;cursor:pointer}.projects-table tbody tr:hover{background:var(--bg-tertiary)}.clickable-row:hover{background:var(--bg-tertiary)!important}.clickable-row:active{background:var(--border-color);transition:background .1s ease}.editing-row{background-color:var(--bg-tertiary)!important}.editing-row input{width:100%;min-width:120px;margin:0}.hidden{display:none}.project-number{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:600;font-size:.875rem;background-color:var(--card-bg);color:var(--primary-color);padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border-color)}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background-color:var(--card-bg)}.status-badge.anbudsrunde{background-color:#fef3c7;color:#92400e}.status-badge.mottatt_bud{background-color:#e0f2fe;color:#0369a1}.status-badge.sendt_inn_review{background-color:#fef3c7;color:#92400e}.status-badge.akseptert_oppdrag{background-color:#d1fae5;color:#065f46}.status-badge.oppstartsjekkliste{background-color:#dbeafe;color:#1e40af}.status-badge.avsluttingsjekkliste{background-color:#e0e7ff;color:#3730a3}.status-badge.ferdig_prosjekt{background-color:#dcfce7;color:#166534}.status-badge.betalt{background-color:#f0fdf4;color:#14532d}.status-badge.kansellert{background-color:#fecaca;color:#991b1b}.status-badge.sendt-inn-review{background-color:#fef3c7;color:#92400e}.status-badge.akseptert-oppdrag{background-color:#d1fae5;color:#065f46}.status-badge.ferdig-prosjekt{background-color:#dcfce7;color:#166534}.btn-view:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.btn-delete{color:var(--error-color);border-color:var(--error-color)}.btn-delete:hover{background-color:var(--error-color);color:#fff;border-color:var(--error-color)}.create-form{background-color:var(--card-bg);border-radius:12px;padding:2.5rem;border:2px solid var(--border-color);box-shadow:0 4px 6px #0000000d}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.form-group{display:flex;flex-direction:column;gap:.75rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.875rem;letter-spacing:.025em}.input{padding:.875rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s ease;background-color:var(--bg-primary);box-shadow:0 1px 3px #0000000d}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;padding:1.5rem;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.pagination-info{font-size:.875rem;color:var(--text-secondary);font-weight:500}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-pages{display:flex;align-items:center;gap:.25rem;margin:0 .5rem}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 .5rem;border:1px solid #d1d5db;background:var(--card-bg);color:#374151;font-size:.875rem;font-weight:500;border-radius:4px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.pagination-btn:hover:not(:disabled){border-color:#9ca3af;background:#f9fafb}.pagination-btn:active:not(:disabled){background:#f3f4f6;transform:translateY(.5px)}.pagination-btn.active{border-color:#000;background:#000;color:#fff}.pagination-btn:disabled{border-color:#e5e7eb;background:#f9fafb;color:#9ca3af;cursor:not-allowed}@media (max-width: 48rem){.project-manager{padding:var(--spacing-4)}.header{flex-direction:column;gap:var(--spacing-4);align-items:stretch}.header h1{text-align:center;font-size:var(--font-size-3xl)}.search-filter-container{flex-direction:column;gap:var(--spacing-4)}.filter-section{margin-left:0;margin-bottom:0;justify-content:center}.table-container{overflow-x:auto}.projects-table{min-width:37.5rem}.projects-table th,.projects-table td{padding:var(--spacing-3) var(--spacing-2);font-size:var(--font-size-sm)}.actions{flex-direction:column;gap:var(--spacing-1)}.pagination-container{padding:var(--spacing-4)}.pagination-controls{gap:.125rem}.pagination-pages{margin:0 var(--spacing-1);gap:.125rem}.pagination-btn{min-width:1.75rem;height:1.75rem;font-size:.8125rem}}@media (max-width: 30rem){.project-manager{padding:var(--spacing-2)}.header h1{font-size:var(--font-size-2xl)}.projects-table th,.projects-table td{padding:var(--spacing-2) var(--spacing-1);font-size:var(--font-size-xs)}.search-filter-container{padding:var(--spacing-3)}.status-select{min-width:7rem;font-size:var(--font-size-xs)}}@media (min-width: 80rem){.project-manager{padding:var(--spacing-3xl)}.header h1{font-size:var(--font-size-5xl)}}.tasks-page{padding:2rem;background:var(--bg-primary);min-height:100vh}.tasks-header{margin-bottom:2rem}.tasks-header h1{font-size:2.25rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.search-container{margin-bottom:1.5rem}.search-input{width:100%;max-width:600px;padding:1rem 1.25rem;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;background:#fff;color:var(--text-primary);transition:all .3s ease;box-shadow:var(--shadow-sm)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-md),0 0 0 3px #0000001a;transform:translateY(-1px)}.filter-controls{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem;background:#fff;padding:2rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.filter-group{display:flex;flex-direction:column;gap:1rem}.filter-group h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.filter-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.filter-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:500;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.filter-btn:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.tasks-table-container{border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background:#fff;box-shadow:var(--shadow-md)}.tasks-table{width:100%;border-collapse:collapse;table-layout:fixed}.tasks-table th,.tasks-table td{padding:1.25rem 1.5rem;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:top}.tasks-table th:nth-child(1),.tasks-table td:nth-child(1){width:30%}.tasks-table th:nth-child(2),.tasks-table td:nth-child(2){width:25%}.tasks-table th:nth-child(3),.tasks-table td:nth-child(3){width:15%}.tasks-table th:nth-child(4),.tasks-table td:nth-child(4){width:15%}.tasks-table th:nth-child(5),.tasks-table td:nth-child(5){width:15%}.tasks-table th{background:var(--bg-secondary);font-weight:600;font-size:.875rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color)}.tasks-table tbody tr{transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative}.tasks-table tbody tr:hover{background:var(--bg-tertiary)}.clickable-row{position:relative}.clickable-row:hover{background:var(--bg-tertiary)!important;transform:none;box-shadow:none}.clickable-row:active{background:var(--border-color);transform:none;transition:background .1s ease}.active-task-row{background:var(--bg-tertiary)}.project-info{display:flex;flex-direction:column;gap:.25rem}.project-number{font-weight:700;color:var(--primary-color);font-size:.9rem}.project-name{font-size:.875rem;color:var(--text-secondary);font-weight:500}.assignee{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:50px;font-size:.875rem;font-weight:600;box-shadow:var(--shadow-sm);border:2px solid transparent;transition:all .3s ease}.assignee.menneske{background:linear-gradient(135deg,#f7fafc,#edf2f7);color:var(--text-primary);border-color:var(--border-color)}.assignee.ai{background:linear-gradient(135deg,#ebf4ff,#dbeafe);color:var(--info-color);border-color:#3182ce33}.status-label{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:50px;font-size:.875rem;font-weight:600;box-shadow:var(--shadow-sm);border:2px solid transparent;position:relative;overflow:hidden}.status-label:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;opacity:.1;border-radius:inherit}.status-label.completed{background:linear-gradient(135deg,var(--success-bg) 0%,#f0fff4 100%);color:var(--success-color);border-color:#38a16933}.status-label.completed:before{background:var(--success-color)}.status-label.overdue{background:linear-gradient(135deg,var(--danger-bg) 0%,#fed7d7 100%);color:var(--danger-color);border-color:#e53e3e33;animation:pulse-danger 2s infinite}.status-label.overdue:before{background:var(--danger-color)}@keyframes pulse-danger{0%,to{box-shadow:var(--shadow-sm),0 0 #e53e3e66}50%{box-shadow:var(--shadow-sm),0 0 0 8px #e53e3e00}}.status-label.today{background:linear-gradient(135deg,var(--warning-bg) 0%,#fffbeb 100%);color:var(--warning-color);border-color:#ed893633}.status-label.today:before{background:var(--warning-color)}.status-label.planned{background:linear-gradient(135deg,var(--info-bg) 0%,#ebf8ff 100%);color:var(--info-color);border-color:#3182ce33}.status-label.planned:before{background:var(--info-color)}.no-tasks{padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-radius:20px;border:2px dashed var(--border-color);position:relative;overflow:hidden}.no-tasks:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}.no-tasks p{color:var(--text-secondary);font-size:1.125rem;font-weight:500}@media (max-width: 1024px){.filter-controls{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 768px){.tasks-page{padding:1rem}.filter-controls{padding:1.5rem;gap:1rem}.tasks-table-container{overflow-x:auto}.tasks-table{min-width:600px;font-size:.875rem;table-layout:auto}.tasks-table th,.tasks-table td{padding:1rem .75rem}.tasks-table th:nth-child(1),.tasks-table td:nth-child(1),.tasks-table th:nth-child(2),.tasks-table td:nth-child(2),.tasks-table th:nth-child(3),.tasks-table td:nth-child(3),.tasks-table th:nth-child(4),.tasks-table td:nth-child(4),.tasks-table th:nth-child(5),.tasks-table td:nth-child(5){width:auto}.filter-buttons{gap:.5rem}.filter-btn{padding:.625rem 1rem;font-size:.8rem}.tasks-header h1{font-size:1.875rem}}.contractor-card.clickable{cursor:pointer;transition:all .2s ease;min-height:200px;max-height:250px}.contractor-card.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:var(--primary-color)}.contractor-info{overflow:hidden}.contractor-services{margin-bottom:.75rem}.contractor-services strong{display:none}.contractor-contact .contact-item{font-size:.85rem;margin-bottom:.25rem}.load-analytics-section{display:flex;justify-content:flex-end;margin:1rem 0}.load-analytics-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.load-analytics-btn.inline{padding:.5rem 1rem;font-size:.85rem;margin-left:1rem}.load-analytics-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.load-analytics-btn:disabled{opacity:.6;cursor:not-allowed}.load-analytics-btn .spinner{animation:spin 1s linear infinite}.chart-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin:2rem 0;box-shadow:0 1px 3px #0000001a}.chart-container{background:#fff;border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;margin:2rem 0;box-shadow:var(--shadow-sm)}.chart-container>div{min-height:400px!important;height:400px!important}.bidding-round-chart,.recharts-wrapper,.recharts-responsive-container{min-height:400px!important;height:400px!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:95vw;max-width:1400px;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 20px 60px #0000004d}.modal-header h3{margin:0;color:var(--text-primary)}.modal-close-btn{background:none;border:none;padding:.5rem;cursor:pointer;border-radius:6px;transition:background .2s ease}.modal-close-btn:hover{background:var(--bg-secondary)}.contractor-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:1.5rem;width:100%;overflow:hidden}@media (max-width: 1200px){.contractor-detail-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.contractor-detail-grid{grid-template-columns:1fr}}.detail-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem;word-wrap:break-word;overflow:hidden}.detail-item strong{color:var(--text-secondary);font-size:.9rem;min-width:120px;flex-shrink:0}.detail-item span,.detail-item p{word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;color:#fff}.contact-history{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.modal-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.modal-action-btn.primary{background:var(--primary-color);color:#fff}.modal-action-btn.secondary{background:var(--bg-secondary);color:var(--text-primary)}.modal-action-btn.danger{background:#ef4444;color:#fff}.modal-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.contact-note-section{margin-top:1rem}.contact-note-section textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;resize:vertical;min-height:80px;font-family:inherit}.contractor-stats-section{margin:.5rem 0 1rem}.database-info{text-align:right;margin:0}.info-text{font-size:.75rem;color:#9ca3af;background:transparent;padding:.25rem 0;border:none;display:inline-block;font-weight:400}.stats-info-bar{display:flex;justify-content:flex-end;align-items:center}.stats-cards-compact{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.stat-card-compact{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;text-align:center;min-width:120px;box-shadow:0 1px 3px #0000001a}.stat-card-compact .stat-content .stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.stat-card-compact .stat-content .stat-label{display:block;font-size:.875rem;color:#6b7280}.stats-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a}.card-header{padding:1.5rem 1.5rem 1rem}.card-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0}.card-subtitle{font-size:.875rem;color:#6b7280;margin:.25rem 0 0}.chart-content{height:400px;position:relative}.chart-content>div,.chart-container>div{height:100%!important;min-height:100%!important}.recharts-responsive-container{height:100%!important;min-height:100%!important}.modal-action-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.modal-action-btn.primary:hover:not(:disabled){background:#2563eb!important;color:#fff!important}.modal-action-btn.secondary:hover:not(:disabled){background:#f3f4f6!important;color:var(--text-primary)!important}.modal-action-btn.danger:hover:not(:disabled){background:#dc2626!important;color:#fff!important}.modern-bidding-chart{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;margin-bottom:2rem}.live-data-section{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-title{font-size:1rem;font-weight:600;color:#111827;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.live-indicator{font-size:.75rem;color:#22c55e;font-weight:600;background:#22c55e1a;padding:.25rem .5rem;border-radius:4px;border:1px solid rgba(34,197,94,.2)}.live-metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width: 768px){.live-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.live-metrics-grid{grid-template-columns:1fr}}.live-metric{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem;background:#fff;border-radius:6px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.live-metric-value{font-size:1.5rem;font-weight:600;color:#111827;line-height:1;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.live-metric-label{font-size:.75rem;color:#6b7280;margin-top:.5rem;font-weight:400}.historical-data-section{padding:1.5rem;background:#fff}.period-label{font-size:.75rem;color:#6b7280;background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;border:1px solid #e5e7eb}.trend-summary{margin-bottom:1rem;display:flex;justify-content:center}.trend-metric{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem 1rem;background:#f9fafb;border-radius:6px;border:1px solid #e2e8f0}.trend-indicator{font-size:1rem;font-weight:500;margin-bottom:.25rem;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.trend-indicator.positive{color:#059669}.trend-indicator.negative{color:#dc2626}.trend-label{font-size:.75rem;color:#9ca3af;font-weight:400}.chart-visualization{height:300px;background:#fff}.insight-value{font-size:1.125rem;font-weight:600;color:#111827;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.modern-chart-loading{height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#6b7280;background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:2rem}.loading-animation{width:24px;height:24px;border:2px solid #f3f4f6;border-top:2px solid #6b7280;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:.75rem}.notepad-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.notepad-textarea{width:100%;border:none;padding:1rem;font-family:Menlo,Monaco,Courier New,monospace;font-size:.875rem;line-height:1.6;resize:vertical;background:#fafbfc;color:#1e293b;outline:none}.notepad-textarea:focus{background:#fff;box-shadow:inset 0 0 0 1px #3b82f6}.notepad-textarea::placeholder{color:#94a3b8;font-style:italic}.notepad-actions{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8fafc;border-top:1px solid #e2e8f0}.save-notes-btn{font-size:.875rem;padding:.5rem 1rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:all .2s}.save-notes-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.save-notes-btn:disabled{opacity:.6;cursor:not-allowed}.action-buttons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:1rem}.action-buttons-grid .btn{width:100%;justify-content:center;align-items:center}.load-analytics-btn:hover:not(:disabled){background:#2563eb!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}[data-theme=dark] .tasks-page{background:var(--bg-primary)}[data-theme=dark] .tasks-header h1{color:var(--text-primary);text-shadow:0 0 30px rgba(0,212,255,.4)}[data-theme=dark] .search-input{background:#0f1419cc;border:2px solid rgba(0,212,255,.2);color:var(--text-primary);box-shadow:0 0 20px #00d4ff1a}[data-theme=dark] .search-input:focus{border-color:var(--accent-color);box-shadow:0 0 30px #00d4ff4d}[data-theme=dark] .search-input::placeholder{color:var(--text-muted)}[data-theme=dark] .filter-group label{color:var(--text-primary)}[data-theme=dark] .filter-group select{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .filter-group select:focus{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] .tasks-sections{background:transparent}[data-theme=dark] .task-section{background:var(--card-bg);border:1px solid rgba(0,212,255,.15);box-shadow:0 0 30px #00d4ff1a,0 4px 15px #0000004d}[data-theme=dark] .section-header{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);border-bottom:2px solid rgba(0,212,255,.2)}[data-theme=dark] .section-header h2{color:var(--text-primary)}[data-theme=dark] .section-count{background:var(--gradient-primary);color:#fff;box-shadow:0 0 15px #00d4ff80}[data-theme=dark] .task-card{background:#00d4ff0d;border:1px solid rgba(0,212,255,.15);box-shadow:0 2px 10px #0003}[data-theme=dark] .task-card:hover{background:#00d4ff14;border-color:#00d4ff4d;box-shadow:0 0 25px #00d4ff40,0 4px 15px #0000004d}[data-theme=dark] .task-content h3{color:var(--text-primary)}[data-theme=dark] .task-meta{color:var(--text-muted)}[data-theme=dark] .task-status{background:var(--gradient-primary);box-shadow:0 0 10px #00d4ff66}[data-theme=dark] .task-status.completed{background:#0f83;color:var(--success-color);border:1px solid rgba(0,255,136,.3)}[data-theme=dark] .task-status.pending{background:#ffb83633;color:var(--warning-color);border:1px solid rgba(255,184,54,.3)}[data-theme=dark] .task-actions button{background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .task-actions button:hover{background:#00d4ff33;box-shadow:0 0 20px #00d4ff4d;color:var(--accent-color)}[data-theme=dark] .load-analytics-btn{background:var(--gradient-primary)!important;color:#fff!important;box-shadow:0 0 30px #00d4ff66}[data-theme=dark] .load-analytics-btn:hover:not(:disabled){background:var(--gradient-primary)!important;box-shadow:0 0 40px #00d4ff99!important}[data-theme=dark] .empty-section{color:var(--text-muted)}[data-theme=dark] .task-list-item{background:#00d4ff0d;border:1px solid rgba(0,212,255,.1)}[data-theme=dark] .task-list-item:hover{background:#00d4ff1a;border-color:#00d4ff33;box-shadow:0 0 20px #00d4ff33}:root{--max-width-page: 87.5rem;--max-width-search: 37.5rem;--border-width-thick: .125rem;--border-width-thin: .0625rem}.customers-page{max-width:var(--max-width-page);margin:0 auto;padding:var(--spacing-2xl);min-height:100vh;background-color:var(--bg-primary)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:var(--border-width-thick) solid var(--border-color)}.header h1{font-size:var(--font-size-4xl);font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.025em}.header button{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;min-height:2.75rem}.search-container{margin-bottom:var(--spacing-2xl)}.search-input-wrapper{position:relative;max-width:var(--max-width-search)}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg) var(--spacing-md) var(--spacing-3xl);border:var(--border-width-thick) solid var(--border-color);border-radius:.75rem;font-size:var(--font-size-base);background:var(--card-bg);color:var(--text-primary);transition:all .3s ease;box-shadow:var(--shadow-sm);min-height:2.75rem}.error-message{background-color:var(--error-color);color:#fff;padding:var(--spacing-md);border-radius:.375rem;margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:center}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-md)}.table-container{background-color:var(--card-bg);border-radius:.75rem;overflow:hidden;border:var(--border-width-thick) solid var(--border-color);box-shadow:0 .25rem .375rem #0000000d}.customers-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-md);border:var(--border-width-thin) solid var(--border-color)}.customers-table th,.customers-table td{padding:var(--spacing-md);text-align:left;border-bottom:var(--border-width-thin) solid var(--border-color)}.customers-table th{background:var(--bg-secondary);font-weight:600;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);border-bottom:var(--border-width-thick) solid var(--border-color)}.customers-table tbody tr{transition:background .2s ease}.customers-table tbody tr:hover{background:var(--bg-tertiary)}.customer-name{font-weight:600;color:var(--text-primary)}.contact-info{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-secondary)}.actions{display:flex;gap:var(--spacing-xs)}.empty-state{padding:var(--spacing-3xl);text-align:center;color:var(--text-secondary)}.empty-state p{font-size:var(--font-size-lg)}@media (max-width: 768px){.customers-page{padding:1rem}.header{flex-direction:column;gap:1rem}}@media (max-width: 48rem){.customers-page{padding:var(--spacing-md)}.header{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.header h1{text-align:center;font-size:var(--font-size-3xl)}.search-input-wrapper{max-width:100%}.table-container{overflow-x:auto}.customers-table{min-width:37.5rem}.customers-table th,.customers-table td{padding:var(--spacing-sm) var(--spacing-xs)}.actions{flex-direction:column;gap:var(--spacing-xs)}.modal{width:95%}}@media (max-width: 30rem){.customers-page{padding:var(--spacing-xs)}.header h1{font-size:var(--font-size-2xl)}.customers-table th,.customers-table td{padding:var(--spacing-xs) var(--spacing-xs);font-size:var(--font-size-sm)}.contact-info{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}@media (min-width: 80rem){.customers-page{padding:var(--spacing-3xl)}.header h1{font-size:var(--font-size-5xl)}}.contractors-page{max-width:87.5rem;margin:0 auto;padding:2rem;min-height:100vh;background-color:var(--bg-primary)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:.125rem solid var(--border-color)}.header h1{font-size:2.5rem;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.025em}.header button{display:flex;align-items:center;gap:.5rem;font-weight:600}.search-container{margin-bottom:2rem}.search-input-wrapper{position:relative;max-width:37.5rem}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:1rem 1.25rem 1rem 3rem;border:.125rem solid var(--border-color);border-radius:.75rem;font-size:1rem;background:var(--card-bg);color:var(--text-primary);transition:all .3s ease;box-shadow:var(--shadow-sm)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:var(--shadow-md),0 0 0 .1875rem #0000001a;transform:translateY(-.0625rem)}.search-input::placeholder{color:var(--text-muted)}.error-message{background-color:var(--error-color);color:#fff;padding:1rem;border-radius:.375rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.table-container{background-color:var(--card-bg);border-radius:.75rem;overflow:hidden;border:.125rem solid var(--border-color);box-shadow:0 .25rem .375rem #0000000d}.contractors-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-md);border:.0625rem solid var(--border-color)}.contractors-table th,.contractors-table td{padding:1.25rem;text-align:left;border-bottom:.0625rem solid var(--border-color)}.contractors-table th{background:var(--bg-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);border-bottom:.125rem solid var(--border-color)}.contractors-table tbody tr{transition:background .2s ease}.contractors-table tbody tr:hover{background:var(--bg-tertiary)}.contractor-name{font-weight:600;color:var(--text-primary)}.contact-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.contact-info svg{color:var(--text-muted)}.empty-state{padding:3rem;text-align:center;color:var(--text-secondary)}.empty-state p{font-size:1.125rem}.modal{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-lg);max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.modal-content{padding:1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color)}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary)}.input{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s ease;background-color:var(--bg-primary)}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0000001a}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary)}.btn-success{background:var(--success-color, #10b981);color:#fff}.btn-success:hover{background:var(--success-hover, #059669)}.btn-danger{background:var(--error-color);color:#fff}.btn-danger:hover{background:var(--error-hover, #dc2626)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem}.btn-ghost:hover{background:var(--bg-tertiary)}.btn-sm{padding:.5rem .75rem;font-size:.75rem}.contractors-table .status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.contractors-table .status-badge.status-frozen{background-color:#fecaca;color:#dc2626;border:1px solid #fecaca}.contractors-table .status-badge.status-active{background-color:#d1fae5;color:#059669;border:1px solid #a7f3d0}.contractors-table .checkbox-wrapper{display:flex;align-items:center;gap:.5rem}.contractors-table .checkbox{width:1rem;height:1rem;accent-color:var(--primary-color)}.contractors-table .checkbox-wrapper label{margin:0;font-size:.875rem;cursor:pointer;font-weight:400}@media (max-width: 768px){.contractors-page{padding:1rem}.header{flex-direction:column;gap:1rem;align-items:stretch}.header h1{text-align:center}.table-container{overflow-x:auto}.contractors-table{min-width:600px}.contractors-table th,.contractors-table td{padding:.75rem .5rem}.actions{flex-direction:column;gap:.25rem}.modal{width:95%}}@media (max-width: 480px){.contractors-page{padding:.5rem}.contractors-table th,.contractors-table td{padding:.5rem .25rem;font-size:.875rem}}.profit-margin-section{background:var(--card-bg);border:1px solid #e5e5e5;border-radius:.5rem;padding:1.5rem;margin-bottom:2rem}.profit-margin-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.profit-margin-section .section-header h3{display:flex;align-items:center;gap:.5rem;color:#000;font-size:1.25rem;font-weight:600;margin:0}.profit-margin-section .section-header .icon{width:1.25rem;height:1.25rem;color:#3b82f6}.profit-margin-section .section-actions{display:flex;gap:.5rem}.profit-margin-section .section-actions button{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.profit-margin-section .edit-btn{background:#3b82f6;color:#fff}.profit-margin-section .edit-btn:hover{background:#2563eb}.profit-margin-section .save-btn{background:#10b981;color:#fff}.profit-margin-section .save-btn:hover:not(:disabled){background:#059669}.profit-margin-section .save-btn:disabled{opacity:.6;cursor:not-allowed}.profit-margin-section .cancel-btn{background:#6b7280;color:#fff}.profit-margin-section .cancel-btn:hover{background:#4b5563}.profit-margin-section .history-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.profit-margin-section .history-btn:hover{background:#e5e7eb}.profit-margin-section .error-message{display:flex;align-items:center;gap:.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;padding:.75rem;margin-bottom:1rem;color:#b91c1c;font-size:.875rem}.profit-margin-section .error-message .icon{width:1rem;height:1rem;flex-shrink:0}.profit-margin-section .loading{text-align:center;padding:2rem;color:#6b7280}.profit-margin-section .margin-content{display:flex;flex-direction:column;gap:1.5rem}.profit-margin-section .current-margin-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1.5rem}.profit-margin-section .margin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.profit-margin-section .margin-info{display:flex;align-items:center;gap:.75rem}.profit-margin-section .margin-label{font-size:1rem;font-weight:600;color:#1f2937}.profit-margin-section .default-badge{background:#fbbf24;color:#92400e;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.profit-margin-section .margin-meta{display:flex;align-items:center;gap:.375rem;color:#6b7280;font-size:.875rem}.profit-margin-section .margin-meta .icon{width:.875rem;height:.875rem}.profit-margin-section .margin-display{text-align:center}.profit-margin-section .margin-value{font-size:3rem;font-weight:700;color:#3b82f6;margin-bottom:.5rem}.profit-margin-section .margin-description{color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.profit-margin-section .margin-message{color:#059669;font-size:.875rem;font-style:italic}.profit-margin-section .margin-form{display:flex;flex-direction:column;gap:1.5rem}.profit-margin-section .form-group{display:flex;flex-direction:column;gap:.5rem}.profit-margin-section .form-group label{font-weight:600;color:#374151;font-size:.875rem}.profit-margin-section .range-hint{color:#6b7280;font-weight:400;font-size:.75rem}.profit-margin-section .percentage-input{display:flex;align-items:center;background:var(--card-bg);border:1px solid #d1d5db;border-radius:.375rem;overflow:hidden;max-width:200px}.profit-margin-section .margin-input{flex:1;padding:.75rem;border:none;outline:none;font-size:1rem;background:transparent}.profit-margin-section .percentage-symbol{padding:.75rem;background:#f3f4f6;color:#374151;font-weight:600;border-left:1px solid #d1d5db}.profit-margin-section .date-input{padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;background:var(--card-bg);max-width:200px}.profit-margin-section .date-input:focus,.profit-margin-section .margin-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.profit-margin-section .form-note{display:flex;align-items:flex-start;gap:.5rem;background:#fffbeb;border:1px solid #fde68a;border-radius:.375rem;padding:.75rem;color:#92400e;font-size:.875rem}.profit-margin-section .form-note .icon{width:1rem;height:1rem;flex-shrink:0;margin-top:.125rem}.profit-margin-section .margin-history{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem}.profit-margin-section .margin-history h4{margin:0 0 1rem;color:#374151;font-size:1.125rem;font-weight:600}.profit-margin-section .history-list{display:flex;flex-direction:column;gap:.75rem}.profit-margin-section .history-item{display:flex;justify-content:space-between;align-items:center;background:var(--card-bg);border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem;transition:all .15s ease}.profit-margin-section .history-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.profit-margin-section .history-item.inactive{opacity:.6;background:#f9fafb}.profit-margin-section .history-info{display:flex;flex-direction:column;gap:.25rem}.profit-margin-section .history-percentage{font-size:1.25rem;font-weight:600;color:#3b82f6}.profit-margin-section .history-date{display:flex;align-items:center;gap:.375rem;color:#6b7280;font-size:.875rem}.profit-margin-section .history-date .icon{width:.875rem;height:.875rem}.profit-margin-section .history-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.profit-margin-section .history-created{color:#9ca3af;font-size:.75rem}.profit-margin-section .inactive-badge{background:#f3f4f6;color:#6b7280;padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}@media (max-width: 768px){.profit-margin-section .section-header{flex-direction:column;align-items:flex-start;gap:1rem}.profit-margin-section .margin-header{flex-direction:column;align-items:flex-start}.profit-margin-section .history-item{flex-direction:column;align-items:flex-start;gap:.75rem}.profit-margin-section .history-meta{align-items:flex-start}.profit-margin-section .percentage-input,.profit-margin-section .date-input{max-width:100%}}.ringeliste-config-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;margin-bottom:2rem}.ringeliste-config-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.ringeliste-config-section .section-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.ringeliste-config-section .section-header .icon{color:var(--primary-color)}.ringeliste-config-section .section-actions{display:flex;gap:.75rem;align-items:center}.ringeliste-config-section .edit-btn,.ringeliste-config-section .save-btn,.ringeliste-config-section .cancel-btn,.ringeliste-config-section .preview-btn,.ringeliste-config-section .reset-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.ringeliste-config-section .edit-btn{background:var(--primary-color);color:#fff}.ringeliste-config-section .edit-btn:hover{background:var(--primary-hover)}.ringeliste-config-section .save-btn{background:var(--success-color);color:#fff}.ringeliste-config-section .save-btn:hover{background:var(--success-hover)}.ringeliste-config-section .save-btn:disabled{background:var(--border-color);cursor:not-allowed}.ringeliste-config-section .cancel-btn{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.ringeliste-config-section .cancel-btn:hover{background:var(--bg-tertiary)}.ringeliste-config-section .preview-btn{background:var(--info-color);color:#fff}.ringeliste-config-section .preview-btn:hover{background:var(--info-hover)}.ringeliste-config-section .preview-btn:disabled{background:var(--border-color);cursor:not-allowed}.ringeliste-config-section .reset-btn{background:var(--warning-color);color:#fff}.ringeliste-config-section .reset-btn:hover{background:var(--warning-hover)}.ringeliste-config-section .config-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.ringeliste-config-section .config-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}.ringeliste-config-section .config-group{background:var(--bg-secondary);border-radius:.5rem;padding:1.25rem}.ringeliste-config-section .config-group-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.ringeliste-config-section .time-range-inputs{display:flex;align-items:center;gap:1rem}.ringeliste-config-section .input-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.ringeliste-config-section .input-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.ringeliste-config-section .time-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s ease}.ringeliste-config-section .time-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.ringeliste-config-section .time-value{padding:.75rem;background:var(--bg-tertiary);border-radius:.5rem;font-size:.875rem;color:var(--text-primary);text-align:center;font-weight:500}.ringeliste-config-section .time-separator{font-size:1.25rem;font-weight:700;color:var(--text-secondary);align-self:end;padding-bottom:.75rem}.ringeliste-config-section .edit-actions{display:flex;justify-content:center;margin-bottom:1.5rem}.ringeliste-config-section .preview-section{background:var(--bg-secondary);border-radius:.5rem;padding:1.25rem;margin-top:1.5rem}.ringeliste-config-section .preview-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.ringeliste-config-section .preview-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.ringeliste-config-section .preview-stat{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-primary);border-radius:.5rem;border:1px solid var(--border-color)}.ringeliste-config-section .preview-stat.total{border-color:var(--primary-color);background:#3b82f60d}.ringeliste-config-section .preview-stat .stat-label{font-size:.875rem;color:var(--text-secondary)}.ringeliste-config-section .preview-stat .stat-value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.ringeliste-config-section .preview-stat.total .stat-value{color:var(--primary-color)}.ringeliste-config-section .config-info{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.ringeliste-config-section .config-meta{margin:0;font-size:.875rem;color:var(--text-secondary);text-align:center}.ringeliste-config-section .error-message{background:var(--error-bg);color:var(--error-text);padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}@media (max-width: 768px){.ringeliste-config-section .config-grid{grid-template-columns:1fr;gap:1rem}.ringeliste-config-section .section-header{flex-direction:column;gap:1rem;align-items:stretch}.ringeliste-config-section .section-actions{justify-content:center}.ringeliste-config-section .time-range-inputs{flex-direction:column;gap:.75rem}.ringeliste-config-section .time-separator{align-self:center;padding:0;transform:rotate(90deg)}.ringeliste-config-section .preview-stats{grid-template-columns:1fr}}.working-list-config-section{background:var(--card-bg);border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:2rem;overflow:hidden}.working-list-config-section .section-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;color:#fff;margin:0}.working-list-config-section .section-header h3{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.25rem;font-weight:600}.working-list-config-section .section-header .icon{width:20px;height:20px}.working-list-config-section .section-actions{display:flex;gap:.75rem}.working-list-config-section .section-actions button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;color:#fff}.working-list-config-section .edit-btn{background:#000;color:#fff;border:1px solid rgba(255,255,255,.2)}.working-list-config-section .edit-btn:hover{background:#1f2937;border-color:#ffffff4d}.working-list-config-section .preview-btn{background:#3b82f6cc;border:1px solid rgba(59,130,246,.9)}.working-list-config-section .preview-btn:hover:not(:disabled){background:#3b82f6}.working-list-config-section .save-btn{background:#22c55ecc;border:1px solid rgba(34,197,94,.9)}.working-list-config-section .save-btn:hover:not(:disabled){background:#22c55e}.working-list-config-section .cancel-btn{background:#ef4444cc;border:1px solid rgba(239,68,68,.9)}.working-list-config-section .cancel-btn:hover{background:#ef4444}.working-list-config-section .reset-btn{background:#9ca3afcc;border:1px solid rgba(156,163,175,.9);color:#fff}.working-list-config-section .reset-btn:hover{background:#9ca3af}.working-list-config-section .section-actions button:disabled{opacity:.6;cursor:not-allowed}.working-list-config-section .section-actions .icon{width:16px;height:16px}.working-list-config-section .config-content{padding:2rem}.working-list-config-section .config-description{color:#6b7280;font-size:.95rem;margin-bottom:2rem;line-height:1.6}.working-list-config-section .config-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}@media (max-width: 768px){.working-list-config-section .config-grid{grid-template-columns:1fr;gap:1.5rem}}.working-list-config-section .config-group{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem}.working-list-config-section .config-group-title{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.working-list-config-section .time-range-inputs{display:flex;align-items:center;gap:1rem}.working-list-config-section .input-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.working-list-config-section .input-group label{color:#4b5563;font-size:.875rem;font-weight:500}.working-list-config-section .time-input{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;transition:border-color .2s ease}.working-list-config-section .time-input:focus{outline:none;border-color:#9ca3af;box-shadow:0 0 0 3px #9ca3af1a}.working-list-config-section .time-value{padding:.75rem;background:var(--card-bg);border:1px solid #e5e7eb;border-radius:6px;color:#374151;font-weight:500}.working-list-config-section .time-separator{color:#6b7280;font-weight:600;margin-top:1.5rem}.working-list-config-section .edit-actions{display:flex;justify-content:flex-start;margin-bottom:2rem}.working-list-config-section .preview-section{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.working-list-config-section .preview-title{color:#0c4a6e;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.working-list-config-section .preview-stats{display:flex;gap:2rem;flex-wrap:wrap}.working-list-config-section .preview-stat{display:flex;flex-direction:column;gap:.25rem}.working-list-config-section .preview-stat.total{font-weight:600;color:#0c4a6e}.working-list-config-section .stat-label{color:#374151;font-size:.875rem}.working-list-config-section .stat-value{color:#1f2937;font-size:1.5rem;font-weight:700}.working-list-config-section .config-info{padding-top:1.5rem;border-top:1px solid #e5e7eb}.working-list-config-section .config-meta{color:#6b7280;font-size:.875rem;margin:0}.working-list-config-section .error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem 1.5rem;margin:0 2rem 1rem;border-radius:6px;font-size:.9rem}.responsibility-section{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000f}.responsibility-section .group-header{margin-bottom:1rem}.responsibility-section .create-rule-form{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;flex-wrap:wrap}.responsibility-section .create-rule-form button{background:#5568d3;color:#fff;border:none;border-radius:6px;padding:.75rem 1.25rem;cursor:pointer;transition:background .2s ease}.responsibility-section .create-rule-form button:hover{background:#4554ad}.responsibility-section .input-with-icon{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:6px;background:var(--card-bg);flex:1;min-width:260px}.responsibility-section .input-with-icon input,.responsibility-section .input-with-icon select{border:none;outline:none;flex:1;background:transparent;font-size:.9375rem}.responsibility-section .rules-table-container{overflow-x:auto}.responsibility-section .admin-loading{padding:1rem;color:#666}.responsibility-section .rules-table{width:100%;border-collapse:collapse}.responsibility-section .rules-table thead{background:#f8f9fa}.responsibility-section .rules-table th{padding:.75rem;text-align:left;font-weight:600;font-size:.875rem;color:#666;border-bottom:2px solid #e0e0e0}.responsibility-section .rules-table td{padding:.75rem;font-size:.9375rem;color:#1a1a1a;border-bottom:1px solid #f0f0f0}.responsibility-section .customer-type{font-weight:600;color:#5568d3}.responsibility-section .date-cell{color:#666;font-size:.875rem}.responsibility-section .delete-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.responsibility-section .delete-btn:hover{background:#c82333}.responsibility-section .no-rules{text-align:center;padding:1rem;color:#777}.responsibility-section .error-message{background:#fdecec;color:#b42318;border:1px solid #f6c9c6;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.team-visibility-section{padding:20px}.team-visibility-loading,.team-visibility-error{padding:20px;text-align:center;color:#666}.team-visibility-error{color:#e74c3c}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.user-visibility-card{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--card-bg);border:1px solid #e0e0e0;border-radius:8px;transition:box-shadow .2s}.user-visibility-card:hover{box-shadow:0 2px 8px #0000001a}.user-info{display:flex;align-items:center;gap:12px;flex:1}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.user-info h4{margin:0 0 4px;font-size:16px;color:#333}.user-email{margin:0 0 4px;font-size:13px;color:#666}.user-role{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.user-role.role-admin{background:#e3f2fd;color:#1976d2}.user-role.role-user{background:#f3e5f5;color:#7b1fa2}.visibility-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.visibility-toggle input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:44px;height:24px;background:#ccc;border-radius:24px;transition:background .3s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:var(--card-bg);border-radius:50%;transition:transform .3s}.visibility-toggle input[type=checkbox]:checked+.toggle-slider{background:#4caf50}.visibility-toggle input[type=checkbox]:checked+.toggle-slider:before{transform:translate(20px)}.toggle-label{font-size:13px;font-weight:500;color:#666;min-width:60px}.register-page{padding:2rem;max-width:1400px;margin:0 auto;background:var(--card-bg);min-height:100vh}.register-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem;border-bottom:1px solid #e5e5e5;padding-bottom:1rem}.register-header h1{color:#000;font-size:2.5rem;font-weight:700;margin:0}.week-selector{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.year-week-inputs{display:flex;gap:1rem}.year-week-inputs label{display:flex;flex-direction:column;gap:.25rem;font-weight:600;color:#333}.year-week-inputs select{padding:.5rem;border:1px solid #cccccc;border-radius:.375rem;background:var(--card-bg);color:#333;min-width:120px}.week-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f3f4f6;border-radius:.375rem;color:#374151;font-weight:500}.loading{display:flex;justify-content:center;align-items:center;padding:2rem;color:#666;font-size:1.125rem}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.error{padding:1rem;background:#f5f5f5;border:1px solid #cccccc;border-radius:.375rem;color:#333;margin-bottom:1rem;text-align:center}.register-content{display:flex;flex-direction:column;gap:2rem}.register-section{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid #e5e5e5}.section-header h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.section-header h3{color:#000;font-size:1.25rem;font-weight:600;margin:0;display:flex;align-items:center;gap:.5rem}.section-actions{display:flex;gap:.5rem}.edit-button,.save-button,.cancel-button,.edit-btn,.save-btn,.cancel-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid #cccccc;font-size:.875rem}.edit-button{background:#000;color:#fff;border-color:#000}.edit-button:hover{background:#333}.save-button{background:#666;color:#fff;margin-right:.5rem;border-color:#666}.save-button:hover{background:#333}.save-button:disabled{background:#ccc;cursor:not-allowed}.cancel-button{background:#999;color:#fff;border-color:#999}.cancel-button:hover{background:#666}.icon{width:1rem;height:1rem}.edit-actions{display:flex}.input-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#333}.input-group input{padding:.75rem;border:1px solid #cccccc;border-radius:.375rem;font-size:1rem;background:var(--card-bg);color:#000}.input-group input:focus{outline:none;border-color:#666;box-shadow:0 0 0 2px #6666661a}.input-group .value{padding:.75rem;background:#f5f5f5;border:1px solid #e5e5e5;border-radius:.375rem;color:#333;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.metric-card{background:var(--card-bg);border:1px solid #e5e5e5;border-radius:.5rem;padding:1.5rem}.metric-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.metric-header h3{color:#000;font-size:1.125rem;font-weight:600;margin:0}.metric-value{font-size:2rem;font-weight:700;color:#000;margin-bottom:.5rem}.metric-subtitle{color:#666;font-size:.875rem}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f5f5f5;border:1px solid #e5e5e5;border-radius:.375rem}.breakdown-label{font-weight:500;color:#333}.breakdown-value{font-weight:700;color:#000;background:#666;color:#fff;padding:.25rem .5rem;border-radius:.25rem;min-width:2rem;text-align:center}.financial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.financial-item{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#666,#333);border-radius:.75rem;color:#fff}.financial-label{font-size:.875rem;font-weight:500;opacity:.9;margin-bottom:.5rem}.financial-value{font-size:1.5rem;font-weight:700}.yearly-goals-section{background:var(--card-bg);border:1px solid #e5e5e5;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.goals-content{margin-top:1.5rem}.goals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem}.goal-card{background:linear-gradient(135deg,#f8f8f8,#e5e5e5);border:1px solid #cccccc;border-radius:.75rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.goal-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.goal-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.goal-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#666,#333);border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem}.goal-icon.brutto{background:linear-gradient(135deg,#666,#333)}.goal-icon.dekningsbidrag{background:linear-gradient(135deg,#999,#666)}.goal-body h3{color:#000;font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.goal-body p{color:#666;font-size:.875rem;margin:0}.goal-value{font-size:2rem;font-weight:700;color:#000;margin:1rem 0;padding:.75rem;background:#f5f5f5;border:1px solid #e5e5e5;border-radius:.5rem;text-align:center}.goal-input{width:100%;font-size:1.5rem;font-weight:600;padding:.75rem;border:2px solid #cccccc;border-radius:.5rem;text-align:center;background:var(--card-bg);color:#000;margin:1rem 0}.goal-input:focus{outline:none;border-color:#666;box-shadow:0 0 0 2px #6666661a}.goal-input::placeholder{color:#999;font-weight:400}.goals-edit-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e5e5}.goals-edit-actions .save-button{background:linear-gradient(135deg,#666,#333);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.goals-edit-actions .save-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6666664d}.goals-edit-actions .save-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.goals-edit-actions .cancel-button{background:#999;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.goals-edit-actions .cancel-button:hover{background:#666;transform:translateY(-1px)}.goals-empty-state{text-align:center;padding:2rem;color:#666}.goals-empty-state p{margin-bottom:1rem;font-size:1.125rem}.set-goals-button{background:linear-gradient(135deg,#666,#333);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.set-goals-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6666664d}.register-group{display:flex;flex-direction:column;gap:1rem}.group-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.group-header h2{margin:0;font-size:1.5rem;color:#111827}.group-description{margin:.25rem 0 0;color:#6b7280;font-size:.95rem}.muted{color:#6b7280;font-size:.9rem}.sidebar-visibility-card{border:1px solid #e5e7eb;border-radius:.75rem;padding:1.25rem;background:#fff;box-shadow:0 1px 3px #00000014}.visibility-table{display:flex;flex-direction:column;gap:.5rem}.visibility-header,.visibility-row{display:grid;grid-template-columns:1.2fr repeat(2,.4fr);gap:.5rem;align-items:center}.visibility-header{font-weight:600;color:#374151;padding:.5rem;border-bottom:1px solid #e5e7eb}.visibility-row{padding:.75rem .5rem;border-bottom:1px dashed #e5e7eb}.visibility-col{display:flex;flex-direction:column;gap:.25rem}.visibility-col.role{flex-direction:row;align-items:center;gap:.35rem;font-weight:600;color:#111827}.visibility-col.heading{font-size:.95rem}.item-title{font-weight:600;color:#111827}.item-description{color:#6b7280;font-size:.9rem}.visibility-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border-radius:.5rem;border:1px solid #d1d5db;background:#f9fafb;cursor:pointer;width:fit-content;transition:all .2s ease}.visibility-toggle.on{background:#ecfdf3;border-color:#bbf7d0;color:#166534}.visibility-toggle.off{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.reset-button{border:1px solid #d1d5db;background:#f9fafb;color:#111827;padding:.5rem .9rem;border-radius:.5rem;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;transition:all .2s ease}.reset-button:hover{background:#f3f4f6}.notification-card{border:1px solid #e5e7eb;border-radius:.75rem;padding:1.25rem;background:#fff;box-shadow:0 1px 3px #00000014}.notification-table{display:flex;flex-direction:column;gap:.5rem}.notification-header,.notification-row{display:grid;grid-template-columns:1.2fr .4fr .3fr .3fr .3fr;gap:.5rem;align-items:center}.notification-header{font-weight:600;color:#374151;padding:.5rem;border-bottom:1px solid #e5e7eb}.notification-row{padding:.75rem .5rem;border-bottom:1px dashed #e5e7eb}.notification-col{display:flex;flex-direction:column;gap:.25rem}.notification-col.channel{flex-direction:row;align-items:center;gap:.35rem}.threshold-input{width:100%;padding:.4rem .5rem;border:1px solid #d1d5db;border-radius:.4rem}.checkbox-toggle{display:inline-flex;align-items:center;gap:.35rem;font-weight:500}.checkbox-toggle input{width:1rem;height:1rem}.footnote{margin-top:.75rem}@media (max-width: 768px){.goals-grid{grid-template-columns:1fr}.goal-value,.goal-input{font-size:1.5rem}.goals-edit-actions{flex-direction:column}.goals-edit-actions .save-button,.goals-edit-actions .cancel-button{width:100%}}.info-tooltip-container{position:relative;display:inline-flex;align-items:center;margin-left:.375rem}.info-tooltip-trigger{background:none;border:none;padding:0;cursor:help;display:inline-flex;align-items:center;justify-content:center;color:#6b7280;transition:color .2s ease;outline:none}.info-tooltip-trigger:hover{color:#3b82f6}.info-tooltip-trigger:focus{outline:2px solid #3b82f6;outline-offset:2px;border-radius:4px}.info-tooltip-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--card-bg);border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;box-shadow:0 10px 25px #00000026;z-index:1000;min-width:250px;max-width:350px;animation:tooltipFadeIn .2s ease;pointer-events:none}.info-tooltip-popup:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#fff}.info-tooltip-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:#e5e7eb;margin-top:1px;z-index:-1}.info-tooltip-title{font-weight:600;font-size:.875rem;color:#1f2937;margin-bottom:.375rem}.info-tooltip-content{font-size:.8125rem;color:#4b5563;line-height:1.5}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.info-tooltip-popup{min-width:200px;max-width:280px;font-size:.75rem}.info-tooltip-title{font-size:.8125rem}}.reviews-performance-card{background:var(--card-bg);border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.header-left{display:flex;align-items:center;gap:1rem}.card-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0}.review-count{font-size:.875rem;color:#6b7280;background:#f3f4f6;padding:.25rem .75rem;border-radius:9999px}.header-right{display:flex;align-items:center}.overall-summary{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#f9fafb;border-radius:8px}.summary-item{display:flex;align-items:center;gap:.5rem}.summary-label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.summary-score{display:flex;align-items:center;gap:.25rem;font-size:1rem;font-weight:600;color:#111827}.summary-divider{width:1px;height:24px;background:#d1d5db}.card-body{padding:1.5rem}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.metrics-section{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin:0;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.metrics-list{display:flex;flex-direction:column;gap:.75rem}.metric-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f9fafb;border-radius:8px;transition:background-color .2s ease}.metric-row:hover{background:#f3f4f6}.metric-row:first-child{background:linear-gradient(135deg,#fef3c7,#fde68a);font-weight:600}.metric-row:first-child:hover{background:linear-gradient(135deg,#fde68a,#fcd34d)}.metric-label{font-size:.875rem;color:#374151;font-weight:500}.metric-row:first-child .metric-label{color:#92400e;font-weight:600}.metric-value{display:flex;align-items:center;gap:.75rem}.star-rating{display:flex;align-items:center;gap:2px}.half-star-container{position:relative;display:inline-flex;width:16px;height:16px}.metric-score{font-size:.875rem;font-weight:600;min-width:70px;text-align:right}.score-excellent{color:#059669}.score-good{color:#3b82f6}.score-average{color:#f59e0b}.score-poor{color:#ef4444}.metric-trend{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:4px}.trend-up{color:#059669;background:#d1fae5}.trend-down{color:#dc2626;background:#fee2e2}.card-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.view-charts-button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem;background:var(--card-bg);border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;justify-content:center}.view-charts-button:hover{background:#f3f4f6;border-color:#9ca3af}.view-charts-button:active{background:#e5e7eb}@media (max-width: 1024px){.metrics-grid{grid-template-columns:1fr;gap:1.5rem}.card-header{flex-direction:column;align-items:flex-start;gap:1rem}.overall-summary{width:100%;justify-content:space-around}}@media (max-width: 640px){.card-header,.card-body{padding:1rem}.card-title{font-size:1.125rem}.metric-row{flex-direction:column;align-items:flex-start;gap:.5rem}.metric-value{width:100%;justify-content:space-between}.overall-summary{flex-direction:column;gap:.5rem;padding:.75rem}.summary-divider{width:100%;height:1px}.summary-item{width:100%;justify-content:space-between}}.stats-page{padding:1rem 1rem 3rem;margin:0 auto;max-width:100vw;overflow-x:hidden;box-sizing:border-box;width:100%;background:var(--bg-primary);min-height:100vh;overflow-y:auto}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.stats-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.stats-controls{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.period-selector{display:flex;gap:.25rem;background-color:var(--bg-tertiary);padding:.25rem;border-radius:.5rem}.breakdown-value.modern{font-size:.9rem;font-weight:600;color:var(--text-primary);background:transparent}.period-selector button{padding:.25rem .5rem;border:none;background:none;border-radius:.375rem;cursor:pointer;font-weight:500;font-size:.75rem;transition:all .2s;color:var(--text-secondary);min-height:2.25rem}.period-selector button.active{background-color:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.period-value-selector{display:flex;align-items:center;gap:.375rem}.period-value-selector select,.period-value-selector input{padding:.25rem .375rem;border:.0625rem solid var(--border-color);border-radius:.375rem;background-color:var(--bg-primary);min-width:3.75rem;font-size:.8rem;color:var(--text-primary);min-height:2.25rem}.custom-date-selector{display:flex;align-items:center;gap:.75rem}.custom-date-selector label{display:flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:500;color:var(--text-primary)}.custom-date-selector input[type=date]{padding:.25rem .375rem;border:.0625rem solid var(--border-color);border-radius:.375rem;background-color:var(--bg-primary);min-width:8rem;font-size:.8rem;color:var(--text-primary);min-height:2.25rem}.action-buttons{display:flex;gap:.375rem}.action-button{display:flex;align-items:center;gap:.25rem;padding:.375rem .5rem;border:none;border-radius:.375rem;background-color:var(--bg-secondary);cursor:pointer;font-size:.75rem;transition:background-color .2s;color:var(--text-primary);min-height:2.25rem}.action-button.primary{background-color:var(--primary-color);color:#fff}.action-button:hover{background-color:var(--bg-tertiary)}.action-button.primary:hover{background-color:var(--primary-hover, #333)}.stats-content{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;margin-top:1rem;max-width:100%}.section-container.modern{background:var(--bg-primary);border-radius:.375rem;padding:.5rem;box-shadow:var(--shadow-sm);border:.0625rem solid var(--border-color);margin-bottom:.625rem;max-width:100%;overflow-x:hidden;width:100%}.section-header.modern{margin-bottom:.5rem;text-align:left}.section-title.modern{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem;letter-spacing:-.02em}.section-description.modern{font-size:.7rem;color:var(--text-secondary);margin:0;line-height:1.3}.metrics-grid.modern.primary{display:grid;grid-template-columns:repeat(auto-fit,minmax(11.25rem,1fr));gap:.625rem;margin-bottom:0}.metrics-grid.modern.secondary{display:grid;grid-template-columns:repeat(auto-fit,minmax(9.375rem,1fr));gap:.5rem;margin-bottom:0}.metric-card.modern.primary{background:var(--bg-secondary);border-radius:.375rem;padding:.625rem;display:flex;align-items:center;gap:.625rem;border:.0625rem solid var(--border-color);min-height:3.75rem;transition:all .2s ease;position:relative}.metric-card.modern.primary:hover{transform:translateY(-.0625rem);box-shadow:var(--shadow-md);border-color:var(--border-color);background:var(--bg-primary)}.metric-card.modern.primary:before{content:"";position:absolute;top:0;left:0;right:0;height:.125rem;background:linear-gradient(90deg,#1a1a1a,#4a4a4a);border-radius:.375rem .375rem 0 0}.metric-card.modern.secondary{background:#f8f8f8;border-radius:.375rem;padding:.5rem;display:flex;align-items:center;gap:.5rem;border:.0625rem solid #e8e8e8;min-height:3.125rem;transition:all .2s ease}.metric-card.modern.secondary:hover{background:var(--card-bg);box-shadow:0 .125rem .5rem #0000000f;border-color:#d0d0d0}.metric-icon.primary{width:2rem;height:2rem;border-radius:.375rem;display:flex;align-items:center;justify-content:center;background:#1a1a1a;color:#fff;flex-shrink:0;box-shadow:0 .125rem .25rem #1a1a1a26}.metric-icon.secondary{width:1.75rem;height:1.75rem;border-radius:.3125rem;display:flex;align-items:center;justify-content:center;background:#333;color:#fff;flex-shrink:0}.metric-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.metric-label.primary{font-size:.7rem;color:#555;font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:.25rem}.metric-label.secondary{font-size:.75rem;color:#666;font-weight:600;margin:0;display:flex;align-items:center;gap:.25rem}.metric-value.primary{font-size:1.4rem;font-weight:800;color:#1a1a1a;margin:2px 0;line-height:1;letter-spacing:-.02em}.metric-value.secondary{font-size:1.1rem;font-weight:700;color:#1a1a1a;margin:2px 0;line-height:1}.metric-context{font-size:.7rem;color:#888;margin:0;font-weight:500}.customer-grid.modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:6px}.customer-card.modern{background:#f5f5f5;border-radius:4px;padding:6px;text-align:center;border:1px solid #e5e5e5;transition:all .2s ease}.customer-card.modern:hover{background:var(--card-bg);border-color:#d0d0d0;box-shadow:0 1px 3px #0000000f}.customer-label{font-size:.65rem;color:#666;margin-bottom:3px;font-weight:500;line-height:1.2}.customer-value{font-size:.9rem;font-weight:700;color:#1a1a1a}.stats-header.modern{margin-bottom:20px;align-items:flex-start;padding:16px 0;border-bottom:1px solid #f0f0f0}.stats-title.modern{font-size:1.8rem;font-weight:800;color:#1a1a1a;letter-spacing:-.02em}.stats-controls.modern{gap:12px;align-items:center}.stats-content.modern{display:flex;flex-direction:column;gap:16px}.stats-graphs-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.bidding-chart-wrapper.enhanced{display:flex;flex-direction:column;flex:1}.chart-visualization-dynamic{height:300px}.stats-card{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000000f;padding:10px;border:1px solid #f0f0f0;display:flex;flex-direction:column;transition:all .2s ease;overflow:visible}.stats-card:hover{box-shadow:0 2px 8px #00000014;border-color:#e0e0e0}.card-header{margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #f5f5f5}.card-title{font-size:.9rem;font-weight:600;color:#1a1a1a;margin:0 0 2px}.card-subtitle{font-size:.7rem;color:#666;margin:0;line-height:1.2}.card-content{flex:1;display:flex;flex-direction:column}.stats-page .chart-container{width:100%;height:800px;min-height:800px;max-height:800px;margin-top:8px;overflow:visible}.contractor-analysis-page .chart-container{height:400px!important;min-height:400px!important;max-height:400px!important;overflow:hidden!important}.analytics-row{max-height:none}.stats-bidding-chart-responsive{min-height:400px!important;height:400px!important;max-height:400px!important;overflow:hidden!important}.stats-chart-responsive{width:100%;height:auto;min-height:350px}.stats-loading-responsive{min-height:200px!important;height:200px!important;max-height:200px!important;overflow:hidden!important}.stats-card{max-height:700px;overflow:hidden}.stats-card .card-content{overflow:visible}@media (max-width: 1200px){.metrics-grid.modern.primary{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.metrics-grid.modern.secondary{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.stats-graphs-grid{grid-template-columns:1fr;gap:14px}}@media (max-width: 768px){.stats-page,.section-container.modern{padding:8px}.metrics-grid.modern.primary{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:4px}.metrics-grid.modern.secondary{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:4px}.customer-grid.modern{grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:4px}.metric-value.primary{font-size:1.1rem}.metric-value.secondary{font-size:.95rem}.stats-title.modern{font-size:1.4rem}.metric-card.modern.primary{padding:6px;min-height:45px}.metric-card.modern.secondary{padding:5px;min-height:40px}.chart-container{height:200px!important;min-height:150px!important;max-height:200px!important}.stats-controls{flex-wrap:wrap;gap:6px}.customer-label{font-size:.6rem}.customer-value{font-size:.8rem}}@media (max-width: 600px){.metrics-grid.modern.primary,.metrics-grid.modern.secondary{grid-template-columns:1fr 1fr;gap:6px}.stats-header{flex-direction:column;align-items:flex-start;gap:12px}.stats-controls{width:100%;justify-content:flex-start}}@media (max-width: 480px){.metrics-grid.modern.primary,.metrics-grid.modern.secondary{grid-template-columns:1fr}.metric-card.modern.primary,.metric-card.modern.secondary{min-height:40px;padding:6px}.metric-value.primary{font-size:1.1rem}.metric-value.secondary{font-size:.95rem}}.pdf-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.pdf-preview-content{background-color:var(--card-bg);border-radius:8px;padding:20px;max-width:90%;max-height:90%;overflow:auto;position:relative}.pdf-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.pdf-preview-title{font-size:20px;font-weight:600;margin:0}.pdf-preview-close{background:none;border:none;font-size:24px;cursor:pointer;color:#555}.pdf-preview-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.pdf-preview-iframe{width:100%;height:70vh;border:1px solid #eee}.loading-indicator.modern{display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-text{text-align:center;max-width:500px}.loading-text h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#333}.loading-text p{margin:0;font-size:14px;color:#666;line-height:1.4}.loading-spinner{color:#fbfbfb}.error-message.modern{background:#fef2f2;color:#dc2626;padding:12px;border-radius:6px;border:1px solid #fecaca;margin-bottom:16px;font-weight:500;font-size:.9rem}.metric-value{font-size:24px;font-weight:600;margin:0;color:#1a1a1a}.metric-label{font-size:12px;color:#777;margin-top:4px}.metric-change{margin-top:6px;font-size:12px;display:flex;align-items:center;gap:3px}.metric-change.positive{color:#4caf50}.metric-change.negative{color:#f44336}.error-message{background-color:var(--error-bg, #fff5f5);color:var(--error-color);padding:.75rem;border-radius:.375rem;border:1px solid var(--error-border, #fed7d7);margin-bottom:1rem}.loading-indicator{display:flex;justify-content:center;align-items:center;color:var(--text-secondary)}@media (max-width: 768px){.stats-page{padding:.5rem}.stats-header{flex-direction:column;align-items:flex-start;gap:.75rem}.stats-controls{width:100%;justify-content:flex-start}.period-selector{width:100%;justify-content:space-around}.stats-content{gap:.75rem}.metrics-grid.modern.primary{grid-template-columns:1fr;gap:.5rem}.metrics-grid.modern.secondary{grid-template-columns:1fr;gap:.375rem}.section-container.modern{padding:.375rem;margin-bottom:.5rem}.metric-card.modern.primary{min-height:3rem;padding:.5rem;gap:.5rem}}@media (min-width: 769px) and (max-width: 1024px){.stats-page{padding:1rem}.metrics-grid.modern.primary{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr))}.metrics-grid.modern.secondary{grid-template-columns:repeat(auto-fit,minmax(8rem,1fr))}}@media (min-width: 1200px){.stats-page{padding:1.5rem;max-width:1400px;margin:0 auto}.stats-content{gap:1.5rem}}.stats-page .stats-page-chart{height:auto!important;max-height:500px!important;overflow-y:auto!important;overflow-x:hidden!important}.stats-page .stats-page-chart .chart-container{height:400px!important;max-height:400px!important;overflow:hidden!important}.stats-page .stats-page-chart canvas{max-width:100%!important;height:100%!important;max-height:100%!important}.stats-page .chart-container{width:100%;height:350px!important;min-height:350px!important;max-height:350px!important;overflow:visible!important}.stats-page .bidding-chart-wrapper.enhanced{width:100%;height:auto!important;min-height:80vh!important;max-height:none!important;overflow:visible!important}.stats-page .modern-bidding-chart{width:100%;height:auto!important;min-height:650px!important;display:flex;flex-direction:column}.stats-page .historical-data-section{height:auto!important;min-height:450px!important;margin-top:20px}.stats-page .chart-visualization-dynamic{width:100%;height:auto!important;min-height:400px!important}.stats-page .chart-content-wrapper{position:relative;width:100%;height:auto!important;min-height:350px!important}.stats-page canvas{width:100%!important;height:100%!important}.stats-page .live-data-section{flex-shrink:0;margin-bottom:1rem}.stats-page .historical-data-section{flex:1;display:flex;flex-direction:column}.stats-page .bidding-chart-container{min-height:auto!important;height:auto!important;max-height:none!important;overflow:visible!important}.stats-page .bidding-chart-container .bidding-chart-wrapper{min-height:80vh!important;height:auto!important;max-height:none!important;overflow:visible!important}.analytics-dashboard-page{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color)}.header-title{display:flex;align-items:center;gap:var(--spacing-md)}.header-title h1{margin:0;font-size:2rem;font-weight:700;color:var(--text-primary)}.date-filter-section{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.filter-row{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.preset-buttons{display:flex;gap:var(--spacing-xs)}.preset-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.preset-btn:hover{border-color:var(--primary-color);background:var(--bg-primary)}.preset-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.custom-date-range{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.custom-date-range svg{color:var(--text-secondary)}.date-input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--radius-xs);background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.date-input:focus{outline:none;border-color:var(--primary-color)}.date-separator{color:var(--text-secondary);font-size:.875rem}.apply-filter-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s ease;margin-left:auto}.apply-filter-btn:hover:not(:disabled){background:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.apply-filter-btn:disabled{opacity:.6;cursor:not-allowed}.active-filter-display{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary)}.active-filter-display strong{color:var(--text-primary)}.analytics-empty{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.header-controls{display:flex;gap:var(--spacing-md);align-items:center}.period-selector{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.period-selector:hover{border-color:var(--primary-color)}.period-selector:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0000001a}.refresh-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.refresh-button:hover:not(:disabled){background:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.kpi-section{margin-bottom:var(--spacing-2xl)}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.kpi-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;gap:var(--spacing-md);transition:all .2s ease}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-card-wide{grid-column:span 2}.kpi-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.kpi-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.kpi-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.kpi-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.kpi-subtitle{font-size:.75rem;color:var(--text-secondary)}.funnel-section{margin-bottom:var(--spacing-2xl)}.funnel-chart{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg)}.funnel-step{margin-bottom:var(--spacing-lg)}.funnel-step:last-child{margin-bottom:0}.funnel-step-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.funnel-step-name{font-weight:600;color:var(--text-primary);text-transform:capitalize}.funnel-step-stats{display:flex;gap:var(--spacing-md);font-size:.875rem;color:var(--text-secondary)}.stat-item{display:flex;align-items:center;gap:.25rem}.funnel-bar-container{background:var(--bg-secondary);border-radius:var(--radius-sm);height:32px;position:relative;overflow:hidden}.funnel-bar{height:100%;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:flex-end;padding-right:var(--spacing-sm);transition:width .5s ease}.funnel-percentage{color:#fff;font-weight:600;font-size:.875rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.funnel-dropoff{display:flex;align-items:center;gap:var(--spacing-sm);margin:var(--spacing-md) 0;padding:var(--spacing-sm) var(--spacing-md);background:#ff00000d;border-left:3px solid currentColor;border-radius:var(--radius-sm);font-size:.875rem}.dropoff-arrow{font-size:1.5rem;font-weight:700;line-height:1}.dropoff-text{display:flex;flex-direction:column;gap:.25rem}.dropoff-text strong{font-weight:700}.dropoff-count{font-size:.75rem;opacity:.8}.variants-section{margin-bottom:var(--spacing-2xl)}.variants-table-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.variants-table{width:100%;border-collapse:collapse}.variants-table thead{background:var(--bg-secondary)}.variants-table th{padding:var(--spacing-md);text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.variants-table tbody tr.variant-row{border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s ease}.variants-table tbody tr.variant-row:hover{background:var(--bg-secondary)}.variants-table tbody tr.variant-row.expanded{background:var(--bg-secondary);border-bottom:none}.variants-table td{padding:var(--spacing-md);font-size:.875rem;color:var(--text-primary)}.expand-cell{width:30px;text-align:center;color:var(--text-secondary)}.variant-id{font-family:monospace;font-size:.75rem;color:var(--text-secondary)}.thumbs-up{color:var(--success-color);font-weight:600}.thumbs-down{color:var(--error-color);font-weight:600}.rating-score{font-weight:700;font-size:1rem}.variant-details-row{border-bottom:1px solid var(--border-color)}.variant-details{padding:var(--spacing-lg);background:var(--bg-primary)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.detail-item label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:.875rem;color:var(--text-primary)}.score-bar-container{background:var(--bg-secondary);height:8px;border-radius:4px;overflow:hidden;margin-bottom:.25rem}.score-bar{height:100%;border-radius:4px;transition:width .3s ease}.analytics-loading,.analytics-error,.analytics-unauthorized{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.analytics-error h2,.analytics-unauthorized h1{color:var(--text-primary);margin-bottom:var(--spacing-sm)}.analytics-error p,.analytics-unauthorized p{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.retry-button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:var(--text-primary);transform:translateY(-1px)}.empty-state{background:var(--bg-primary);border:1px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-2xl);text-align:center;color:var(--text-secondary)}[data-theme=dark] .kpi-card,[data-theme=dark] .funnel-chart,[data-theme=dark] .variants-table-container{background:var(--bg-secondary);border-color:#2a2a2a}[data-theme=dark] .variants-table thead,[data-theme=dark] .variants-table tbody tr.variant-row:hover,[data-theme=dark] .variants-table tbody tr.variant-row.expanded,[data-theme=dark] .funnel-bar-container,[data-theme=dark] .score-bar-container{background:var(--bg-primary)}.action-analytics-section,.bid-analytics-section{margin-bottom:var(--spacing-2xl)}.kpi-grid-2col{grid-template-columns:repeat(2,1fr)}.kpi-grid-3col{grid-template-columns:repeat(3,1fr)}.subsection-title{font-size:1.125rem;font-weight:600;margin:var(--spacing-lg) 0 var(--spacing-md) 0;color:var(--text-primary)}.popular-actions,.top-performers{margin-top:var(--spacing-lg)}.action-badges,.performer-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.action-badge,.performer-badge{background:var(--bg-secondary);border:1px solid var(--border-color);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--text-primary);transition:all .2s ease}.action-badge:hover,.performer-badge:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.action-table-container,.contractor-table-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;margin-top:var(--spacing-lg)}.action-table,.contractor-table{width:100%;border-collapse:collapse}.action-table thead,.contractor-table thead{background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.action-table th,.contractor-table th{padding:var(--spacing-md);text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.action-table td,.contractor-table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-color);color:var(--text-primary)}.action-table tbody tr,.contractor-table tbody tr{transition:background .2s ease}.action-table tbody tr:hover,.contractor-table tbody tr:hover{background:var(--bg-secondary)}.action-table tbody tr:last-child td,.contractor-table tbody tr:last-child td{border-bottom:none}.action-name,.contractor-name{font-weight:600;text-transform:capitalize}.action-clicks{color:var(--primary-color);font-weight:600}.bookings-count{color:var(--success-color);font-weight:600}.action-steps{display:flex;flex-wrap:wrap;gap:.25rem}.step-badge{background:var(--bg-secondary);padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary);text-transform:capitalize;white-space:nowrap}.conversion-badge{font-weight:700;padding:.25rem .5rem;border-radius:var(--radius-sm);background:#0000000d}.position-badge{background:var(--info-color);color:#fff;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600}.price-text{font-weight:600;color:var(--text-primary)}@media (max-width: 768px){.analytics-dashboard-page{padding:var(--spacing-md)}.analytics-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.header-controls{width:100%;flex-direction:column}.period-selector,.refresh-button{width:100%}.kpi-grid,.kpi-grid-2col,.kpi-grid-3col{grid-template-columns:1fr}.kpi-card-wide{grid-column:span 1}.variants-table-container,.action-table-container,.contractor-table-container{overflow-x:auto}.variants-table,.action-table,.contractor-table{min-width:800px}.detail-grid{grid-template-columns:1fr}.action-badges,.performer-badges{flex-direction:column}.action-badge,.performer-badge{width:100%;text-align:center}}.contractor-analysis-page{padding:1rem;color:var(--text-primary);max-width:100vw;overflow-x:hidden;box-sizing:border-box;width:100%;background:var(--bg-primary);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.page-title{margin:0;font-size:1.75rem;font-weight:600;color:var(--text-primary)}.page-controls{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.period-select,.period-value-select,.year-input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background:var(--card-bg);font-size:.875rem;color:var(--text-primary)}.period-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;margin-bottom:1.5rem;font-weight:500;color:var(--text-secondary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;text-align:center}.loading-container .spin{animation:spin 1s linear infinite;color:var(--primary-color);margin-bottom:1rem}.animate-spin{animation:spin 1s linear infinite}.analysis-section{margin-bottom:2rem}.analysis-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.fylke-cards-container{margin-bottom:2rem}.fylke-cards-wrapper{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px}.clickable-fylke-card{position:relative;cursor:pointer;transition:all .2s ease;border-radius:4px;overflow:hidden}.clickable-fylke-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.clickable-fylke-card:hover .generate-button-overlay{opacity:1}.generate-button-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:.5rem .25rem;opacity:0;transition:opacity .2s ease}.btn-generate-small{background:var(--primary-color);color:#fff;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;display:flex;align-items:center;gap:.25rem;cursor:pointer;width:100%;justify-content:center}.contractor-chart-container{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a;overflow:visible;width:100%!important;height:auto!important;min-height:auto!important;max-height:none!important}.contractor-analysis-page .chart-container{width:100%!important;height:auto!important;min-height:400px!important;max-height:none!important;margin-top:8px}.contractor-analysis-page .chart-wrapper{width:100%!important;height:auto!important;min-height:350px!important;max-height:none!important}.contractor-analysis-page .chart-wrapper.large{min-height:450px!important}.contractor-analysis-page .chart-wrapper.extra-large{min-height:600px!important}.contractor-analysis-page .chart-container{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a;overflow:visible;width:100%!important;height:auto!important;min-height:400px!important;max-height:none!important}.chart-title{font-size:1.125rem;font-weight:600;margin:0 0 .5rem;color:#1f2937;display:flex;align-items:center;gap:8px}.live-badge{display:inline-flex;align-items:center;background-color:#22c55e;color:#fff;font-size:.75rem;font-weight:500;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.chart-description{font-size:.875rem;color:#6b7280;margin:0 0 1.5rem;line-height:1.5}.chart-wrapper{position:relative;min-height:400px;height:auto;width:100%}.chart-wrapper.large{min-height:500px}.chart-wrapper.extra-large{min-height:650px}.bidding-chart-container{min-height:auto!important;height:auto!important;max-height:none!important}.bidding-chart-container .chart-wrapper{min-height:auto}.bidding-chart-wrapper{width:100%;min-height:65vh}.bidding-chart-wrapper.enhanced{min-height:75vh}.modern-bidding-chart{width:100%;margin:0;min-height:350px;display:flex;flex-direction:column;height:100%}.contractor-analysis-page .modern-bidding-chart .chart-visualization-dynamic{min-height:300px!important;height:auto!important;width:100%!important;margin-top:.5rem}.contractor-analysis-page .modern-bidding-chart .chart-visualization{height:450px!important;min-height:450px!important;width:100%!important;margin-top:1rem}.contractor-analysis-page canvas{max-width:100%!important;height:auto!important;min-height:auto!important}.live-data-section,.historical-data-section{margin-bottom:.5rem;width:100%}.live-data-section:last-child,.historical-data-section:last-child{margin-bottom:0}.live-analytics-section .historical-data-section{margin-bottom:0;flex:1;display:flex;flex-direction:column}.live-analytics-section .chart-visualization-dynamic{flex:1}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;border-bottom:1px solid #e5e7eb;padding-bottom:.375rem}.section-header.compact{margin-bottom:.125rem;padding-bottom:.125rem}.live-analytics-section .section-header.compact{margin-bottom:0;padding-bottom:0;border-bottom:none}.section-title{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.live-indicator{color:#22c55e;font-size:.875rem;font-weight:600}.period-label{color:#6b7280;font-size:.875rem}.live-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:.75rem}.live-metric{text-align:center;padding:.75rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.live-metric-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.live-metric-label{display:block;font-size:.75rem;color:#6b7280;text-transform:uppercase;font-weight:500;letter-spacing:.05em}.trend-summary{margin-bottom:1rem}.trend-metric{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f3f4f6;border-radius:6px}.trend-indicator{font-size:1rem;font-weight:600}.trend-indicator.positive{color:#22c55e}.trend-indicator.negative{color:#ef4444}.trend-label{font-size:.875rem;color:#6b7280}.chart-visualization{position:relative;height:400px;width:100%;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;align-items:center;justify-content:center}.chart-visualization-dynamic{position:relative;width:100%;min-height:300px;height:auto;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column}.chart-content-wrapper{flex:1;width:100%;padding:.25rem .25rem .1rem;min-height:0;display:flex;flex-direction:column;position:relative!important}.chart-content-wrapper>div{flex:1;width:100%;height:auto;min-height:0}.trend-overlay{position:absolute!important;top:.75rem!important;right:.75rem!important;left:auto!important;z-index:20!important;pointer-events:none}.trend-metric-overlay{display:flex!important;flex-direction:column!important;align-items:flex-end!important;gap:.125rem;padding:.375rem .5rem;background:#fffffffa;border:1px solid #d1d5db;border-radius:6px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 2px 8px #00000026;max-width:90px;min-width:70px;float:right!important}.trend-label-small{font-size:.625rem;color:#6b7280;font-weight:500;line-height:1.1;text-align:right;white-space:nowrap}.chart-content-wrapper canvas{width:100%!important;height:auto!important;max-height:none!important;min-height:auto!important}.live-analytics-section .bidding-chart-container canvas{width:100%!important;height:auto!important;max-height:280px!important;min-height:200px!important}.live-analytics-section .bidding-chart-container.compact canvas{max-height:280px!important;min-height:200px!important}.chart-no-data-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6b7280;font-size:.875rem;gap:1rem;text-align:center;padding:2rem}.no-data-title{font-size:1.25rem;font-weight:600;color:#374151}.no-data-description{max-width:300px;line-height:1.5}.no-data-debug{font-size:.75rem;color:#9ca3af;white-space:pre-wrap;background:#f3f4f6;padding:.5rem;border-radius:4px;border:1px solid #e5e7eb;font-family:monospace}@media (min-width: 768px){.chart-visualization-dynamic{min-height:120px}}@media (min-width: 1024px){.chart-visualization-dynamic{min-height:120px}}@media (min-width: 1440px){.chart-visualization-dynamic{min-height:120px}}.chart-card{width:100%;background:var(--card-bg);border-radius:8px;padding:1rem;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;min-height:400px}@media (max-width: 768px){.live-metrics-grid{grid-template-columns:repeat(2,1fr)}.chart-visualization{height:250px}}@media (max-width: 480px){.live-metrics-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.chart-visualization{height:200px}}.revenue-analysis-container{height:auto!important;max-height:none!important}.revenue-analysis-container .chart-wrapper{min-height:500px}.revenue-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}.revenue-chart-item{height:320px;min-height:320px;position:relative}.revenue-chart-item.enhanced-chart{height:400px;min-height:400px;padding:1rem;background:#fafafa;border:1px solid #f0f0f0;border-radius:8px;box-shadow:0 2px 4px #0000000d}@media (max-width: 768px){.revenue-charts-grid{grid-template-columns:1fr;gap:1.5rem}.revenue-chart-item{height:280px;min-height:280px}.revenue-chart-item.enhanced-chart{height:350px;min-height:350px;padding:.75rem}}@media (max-width: 480px){.revenue-chart-item{height:250px;min-height:250px}.revenue-chart-item.enhanced-chart{height:320px;min-height:320px;padding:.5rem}}.chart-loading-state,.chart-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:2rem;text-align:center;gap:1rem}.chart-loading-state p,.chart-loading-container p{color:#6b7280;margin:0}.loading-animation{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.advanced-analytics-section{margin-top:2rem}.live-analytics-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.section-divider-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin-bottom:2rem;text-align:center;display:flex;align-items:center;gap:1rem}.section-divider-title:before,.section-divider-title:after{content:"";flex:1;height:1px;background:linear-gradient(to right,transparent,#22c55e,transparent)}.advanced-analytics-section .contractor-chart-container,.advanced-analytics-section .chart-container{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;height:auto!important;min-height:auto!important;max-height:none!important;overflow:visible!important}.live-analytics-section .contractor-chart-container.bidding-chart-container{padding:.75rem;margin-bottom:1rem;min-height:auto!important}.live-analytics-section .contractor-chart-container.bidding-chart-container.compact{padding:.5rem;margin-bottom:.5rem;min-height:auto!important}.live-analytics-section .contractor-chart-container.compact .chart-title{font-size:.9rem;margin-bottom:.25rem}.live-analytics-section .contractor-chart-container.compact .chart-description{font-size:.8rem;margin-bottom:.5rem}.chart-header-with-filter{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.chart-title-section{flex:1}.bidding-county-filter{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;min-width:140px}.filter-label{font-size:.75rem;color:#6b7280;font-weight:500;margin-bottom:.125rem}.county-filter-select{padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:4px;background:var(--card-bg);font-size:.8rem;color:#374151;cursor:pointer;transition:border-color .2s ease;min-width:120px}.county-filter-select:hover{border-color:#9ca3af}.county-filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}@media (max-width: 768px){.chart-header-with-filter{flex-direction:column;align-items:stretch;gap:.5rem}.bidding-county-filter{flex-direction:row;align-items:center;justify-content:space-between}.filter-label{margin-bottom:0}}.bidding-chart-wrapper.updating{position:relative}.chart-updating-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffb3;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:8px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.updating-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.chart-container{padding:1rem;margin-bottom:1.5rem}.chart-wrapper{min-height:300px}.chart-wrapper.large{min-height:400px}.chart-wrapper.extra-large{min-height:550px}.revenue-analysis-container .chart-wrapper{min-height:450px}.bidding-chart-wrapper.enhanced{min-height:550px}}@media (max-width: 480px){.chart-wrapper{min-height:250px}.chart-wrapper.large{min-height:350px}.chart-wrapper.extra-large{min-height:500px}.revenue-analysis-container .chart-wrapper{min-height:400px}.bidding-chart-wrapper.enhanced{min-height:500px}}.contractor-stats-section{margin-bottom:2rem}.contractor-stats-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:box-shadow .2s ease}.stat-card:hover{box-shadow:0 2px 8px #0000000d}.stat-icon{color:var(--primary-color);min-width:24px}.stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.generated-contractors-section,.all-contractors-section{margin-bottom:2rem}.generated-contractors-section h2,.all-contractors-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.contractor-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem}.filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.filter-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.filter-group select,.filter-group input{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background:var(--card-bg);font-size:.875rem;color:var(--text-primary)}.search-group{flex:1;min-width:200px}.search-input-wrapper{position:relative}.search-input-wrapper svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.search-input-wrapper input{padding-left:2.25rem;width:100%}.contractors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.contractor-card{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;transition:all .2s ease}.contractor-card:hover{box-shadow:0 4px 12px #0000001a;border-color:var(--primary-color)}.contractor-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.contractor-title{flex:1}.contractor-title h4{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.contractor-status{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.05em}.contractor-rating{font-size:.875rem;color:var(--text-secondary);margin-left:1rem}.contractor-info>div{margin-bottom:.75rem}.contractor-location{font-size:.875rem;color:var(--text-secondary)}.contractor-services{font-size:.875rem}.contractor-services strong{color:var(--text-primary);margin-bottom:.5rem;display:block}.services-tags{display:flex;flex-wrap:wrap;gap:.25rem}.service-tag{background:#f3f4f6;color:var(--text-secondary);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem}.service-tag.more{background:var(--primary-color);color:#fff}.contractor-description{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.contractor-contact{display:flex;flex-direction:column;gap:.5rem}.contact-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.contact-item svg{color:var(--primary-color);min-width:16px}.contact-item a{color:var(--primary-color);text-decoration:none}.contact-item a:hover{text-decoration:underline}.contractor-note{background:#f0f9ff;border:1px solid #e0f2fe;border-radius:.375rem;padding:.75rem;display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem}.contractor-note svg{color:#0369a1;min-width:16px;margin-top:.125rem}.contractor-note small{color:var(--text-secondary);margin-left:.5rem}.contractor-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.contact-note-form{margin-bottom:1rem}.contact-note-form textarea{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;font-family:inherit;resize:vertical}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.action-buttons button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.375rem;border:none;font-size:.875rem;cursor:pointer;transition:all .2s ease}.btn-contact{background:#22c55e;color:#fff}.btn-contact:hover{background:#16a34a}.btn-remove-temp{background:#f59e0b;color:#fff}.btn-remove-temp:hover{background:#d97706}.btn-remove-perm{background:#ef4444;color:#fff}.btn-remove-perm:hover{background:#dc2626}.action-buttons button:disabled{opacity:.6;cursor:not-allowed}.no-contractors{text-align:center;padding:3rem;color:var(--text-secondary)}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem;text-align:center;color:#b91c1c;margin:1rem 0}.load-more-container{display:flex;justify-content:center;padding:2rem;margin-top:1rem}.btn-load-more{background:var(--primary-color);color:#fff;border:none;border-radius:.5rem;padding:.75rem 2rem;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-load-more:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn-load-more:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg);border-radius:.5rem;width:90vw;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;color:var(--text-primary)}.form-group small{display:block;margin-top:.25rem;color:var(--text-secondary);font-size:.75rem}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem}.btn-secondary,.btn-primary{padding:.5rem 1rem;border-radius:.375rem;border:none;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.btn-secondary{background:#f3f4f6;color:var(--text-secondary);border:1px solid #d1d5db}.btn-secondary:hover{background:#e5e7eb}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.contractor-analysis-page{padding:.5rem}.page-header{flex-direction:column;align-items:stretch}.page-controls{justify-content:center}.contractors-grid{grid-template-columns:1fr}.contractor-filters{flex-direction:column}.filter-group{min-width:auto}.stats-cards{grid-template-columns:1fr}.fylke-cards-wrapper{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}.schedule-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:var(--spacing-lg)}.schedule-list-loading,.schedule-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;color:var(--text-secondary)}.schedule-list-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}.empty-icon{color:var(--text-secondary);opacity:.5;margin-bottom:var(--spacing-md)}.schedule-list-empty h3{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.schedule-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:all .2s ease}.schedule-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.schedule-card.paused{opacity:.7;border-color:var(--warning-color)}.schedule-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.schedule-status{display:flex;align-items:center;gap:var(--spacing-sm)}.status-badge{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-active{background:var(--success-color);color:#fff}.status-paused{background:var(--warning-color);color:#fff}.status-disabled{background:var(--error-color);color:#fff}.schedule-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary)}.schedule-actions{display:flex;gap:var(--spacing-xs)}.action-btn{background:var(--bg-primary);border:1px solid var(--border-color);padding:.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.action-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn-danger:hover:not(:disabled){background:var(--error-color);border-color:var(--error-color)}.schedule-card-body{padding:var(--spacing-md)}.schedule-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.schedule-info-item{display:flex;align-items:flex-start;gap:var(--spacing-xs)}.info-icon{color:var(--primary-color);flex-shrink:0;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.schedule-subject,.schedule-message{margin-top:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.875rem}.schedule-message p{margin:.5rem 0 0;color:var(--text-secondary)}.schedule-recipients{margin-top:var(--spacing-md)}.schedule-recipients strong{font-size:.875rem;color:var(--text-primary)}.recipients-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.recipient-badge{background:var(--bg-secondary);border:1px solid var(--border-color);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;color:var(--text-primary)}@media (max-width: 768px){.schedule-list{grid-template-columns:1fr}.schedule-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.schedule-actions{width:100%;justify-content:flex-end}.schedule-info-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-primary);border-radius:var(--radius-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.modal-close{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color .2s ease}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--text-primary);font-size:.875rem}.form-group label .required{color:var(--error-color);margin-left:.25rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0000001a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--error-color)}.form-hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--text-secondary)}.error-message{display:block;margin-top:.25rem;font-size:.75rem;color:var(--error-color)}.email-input-group{display:flex;gap:var(--spacing-sm)}.email-input-group input{flex:1}.btn-add-email{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;transition:background .2s ease}.btn-add-email:hover{background:var(--text-primary)}.email-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:var(--spacing-sm)}.email-tag{background:var(--bg-secondary);border:1px solid var(--border-color);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.email-tag-remove{background:none;border:none;cursor:pointer;padding:0;font-size:1.25rem;line-height:1;color:var(--text-secondary);transition:color .2s ease}.email-tag-remove:hover{color:var(--error-color)}.form-group-checkbox label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.form-group-checkbox input[type=checkbox]{width:auto;cursor:pointer}.btn-primary,.btn-secondary,.btn-danger{padding:.625rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;font-size:.875rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 4px #10b9814d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 8px #10b98166}.btn-primary:disabled{opacity:.6;cursor:not-allowed;background:#9ca3af;box-shadow:none}.btn-secondary{background:#fff;color:#374151;border:1px solid #D1D5DB}.btn-secondary:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 4px #ef44444d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 8px #ef444466}.modal-large{max-width:700px}.modal-header-icon{color:var(--primary-color);margin-right:.5rem}.modal-header h2{display:flex;align-items:center}.modal-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-section:last-of-type{border-bottom:none}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.section-title svg{color:var(--primary-color)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.btn-with-icon{display:inline-flex;align-items:center;gap:.5rem}.btn-with-icon .spinner{animation:spin 1s linear infinite}@media (max-width: 768px){.modal-content{max-width:100%;max-height:100vh;border-radius:0}.modal-large{max-width:100%}.modal-overlay{padding:0}.email-input-group{flex-direction:column}.btn-add-email{width:100%}.form-row{grid-template-columns:1fr}}.history-table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.history-table{width:100%;border-collapse:collapse;font-size:.875rem}.history-table thead{background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.history-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px;white-space:nowrap}.history-table tbody tr{transition:background .15s ease;border-bottom:1px solid var(--border-color)}.history-table tbody tr:hover{background:var(--bg-secondary)}.history-table tbody tr:last-child{border-bottom:none}.history-table td{padding:.875rem 1rem;color:var(--text-primary)}.date-cell{white-space:nowrap;font-weight:500}.customer-type-cell strong{color:var(--text-primary);font-size:.875rem}.date-range-cell{color:var(--text-secondary);font-size:.8125rem}.recipients-cell{max-width:250px}.recipients-preview{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center}.recipient-tag-small{background:var(--bg-secondary);border:1px solid var(--border-color);padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;color:var(--text-primary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipient-more{font-size:.6875rem;color:var(--text-secondary);font-weight:500}.status-cell{display:flex;align-items:center;gap:.5rem}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-sent{background:#dcfce7;color:#166534}.status-pending{background:#fef9c3;color:#854d0e}.status-failed{background:#fee2e2;color:#991b1b}.error-tooltip{position:relative;display:inline-flex;align-items:center;cursor:help;color:#991b1b}.error-tooltip:hover .tooltip-text{visibility:visible;opacity:1}.tooltip-text{visibility:hidden;opacity:0;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;white-space:nowrap;max-width:300px;white-space:normal;z-index:100;transition:all .2s ease;margin-bottom:.5rem}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1f2937}.actions-cell{white-space:nowrap}.action-buttons{display:flex;gap:.5rem;align-items:center}.action-btn-small{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#6b7280;color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn-small:hover{transform:translateY(-1px)}.action-btn-small:disabled{opacity:.5;cursor:not-allowed}.action-btn-preview{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d}.action-btn-preview:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666}.action-btn-download{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d}.action-btn-download:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166}.history-table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.history-table-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.history-table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary)}.history-table-empty .empty-icon{color:var(--text-secondary);opacity:.5;margin-bottom:1rem}.history-table-empty h3{margin:0 0 .5rem;color:var(--text-primary);font-weight:600}.history-table-empty p{margin:0;font-size:.875rem}.history-pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.pagination-info{font-size:.875rem;color:var(--text-secondary)}.pagination-controls{display:flex;gap:.5rem}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;color:var(--text-primary)}.pagination-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 768px){.history-table{font-size:.8125rem}.history-table th,.history-table td{padding:.625rem .5rem}.recipients-cell{max-width:120px}.history-pagination{flex-direction:column;gap:.75rem}}.history-filters{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0000000a}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.filters-title{display:flex;align-items:center;gap:.625rem;font-weight:600;color:var(--text-primary);font-size:1rem}.filters-title svg{color:#3b82f6}.clear-filters-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#fff;border:1px solid #E5E7EB;border-radius:8px;color:#6b7280;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-filters-btn:hover{background:#ef4444;color:#fff;border-color:#ef4444;box-shadow:0 2px 4px #ef44444d}.filters-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:end}.filter-group label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.filter-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid #E2E8F0;border-radius:8px;background:#fff;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select:hover:not(:focus){border-color:#cbd5e1}.filter-results{display:flex;align-items:center;justify-content:flex-end;padding-bottom:.375rem}.results-count{font-size:.875rem;color:#64748b;font-weight:500;background:#fff;padding:.5rem 1rem;border-radius:8px;border:1px solid #E2E8F0}@media (max-width: 1024px){.filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.history-filters{padding:1rem}.filters-grid{grid-template-columns:1fr}.filter-results{justify-content:flex-start;padding-top:.75rem;border-top:1px solid var(--border-color)}}.partner-control-page{padding:2rem;max-width:1400px;margin:0 auto;background-color:#fafafa;min-height:100vh}.page-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#2d3748;padding:2.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 4px #0000000d;border:1px solid #e2e8f0}.page-header h1{margin:0;font-size:2rem;font-weight:700;display:flex;align-items:center;gap:.75rem;color:#2d3748}.page-header p{margin:.5rem 0 0;color:#718096;font-size:1rem}.modern-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e2e8f0;padding-bottom:0}.modern-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#718096;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;margin-bottom:-2px}.modern-tab:hover{color:#2d3748;background:#f7fafc}.modern-tab.active{color:#2d3748;border-bottom-color:#48bb78;background:var(--card-bg)}.modern-tab span{font-size:.95rem}.tab-content{animation:fadeIn .3s ease}.info-box{background:linear-gradient(135deg,#f0fdf4,#dcfce7);padding:1.5rem 2rem;border-radius:12px;border:1px solid #86efac;margin-bottom:1.5rem}.info-box h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#166534}.info-box ul{margin:0 0 1rem;padding-left:1.5rem;color:#15803d}.info-box li{margin-bottom:.5rem;line-height:1.6}.info-note{margin:1rem 0 0;padding:.75rem 1rem;background:var(--card-bg);border-radius:8px;color:#166534;font-size:.875rem;border:1px solid #bbf7d0}.content-card{background:var(--card-bg);padding:2rem;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1.5rem;border:1px solid #e2e8f0}.card-description{margin:0 0 1.5rem;color:#718096;font-size:.9375rem;line-height:1.6}.content-card h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#2d3748;display:flex;align-items:center;gap:.5rem}.content-card h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:#2d3748}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header h2{margin:0}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:500;color:#4a5568;font-size:.875rem;display:flex;align-items:center;gap:.375rem}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-top:.5rem}.modern-checkbox{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.875rem}.modern-checkbox:hover{background:#edf2f7;border-color:#cbd5e0}.modern-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.modern-checkbox span{color:#2d3748;font-weight:500}.modern-input,.modern-select{width:100%;padding:.75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#2d3748;background:var(--card-bg);transition:all .2s ease}.modern-input:focus,.modern-select:focus{outline:none;border-color:#48bb78;box-shadow:0 0 0 3px #48bb781a}.modern-input::placeholder{color:#a0aec0}textarea.modern-input{resize:vertical;min-height:80px;font-family:inherit}.modern-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.modern-btn:disabled{opacity:.5;cursor:not-allowed}.modern-btn.primary{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;box-shadow:0 2px 4px #48bb7833}.modern-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#38a169,#2f855a);box-shadow:0 4px 8px #48bb784d;transform:translateY(-1px)}.modern-btn.secondary{background:#edf2f7;color:#2d3748;border:1px solid #e2e8f0}.modern-btn.secondary:hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e0}.modern-btn.small{padding:.5rem 1rem;font-size:.8125rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);padding:1.5rem;border-radius:10px;border:1px solid #e2e8f0;transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.metric-label{font-size:.875rem;color:#718096;font-weight:500;margin-bottom:.5rem}.metric-value{font-size:2rem;font-weight:700;color:#2d3748}.metric-value.success{color:#38a169}.data-table{overflow-x:auto;margin-top:1.5rem}.data-table table{width:100%;border-collapse:collapse}.data-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.data-table th{padding:.875rem 1rem;text-align:left;font-weight:600;color:#4a5568;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.data-table td{padding:.875rem 1rem;border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:.875rem}.data-table tbody tr{transition:background .15s ease}.data-table tbody tr:hover{background:#f7fafc}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--card-bg, #fff);border:1px solid #e2e8f0;border-radius:10px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-icon{width:48px;height:48px;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:#2d3748;line-height:1.2}.stat-label{font-size:.8125rem;color:#718096;font-weight:500}.header-actions{display:flex;gap:.75rem}.error-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fed7d7;border:1px solid #fc8181;border-radius:10px;color:#742a2a;margin-bottom:1.5rem;font-size:.875rem}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;border-top:1px solid #e2e8f0;margin-top:1rem}.pagination-info{font-size:.875rem;color:#718096}.schedule-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1.5rem;transition:all .2s ease}.schedule-card:hover{border-color:#cbd5e0;box-shadow:0 2px 8px #00000014}.schedule-card.paused{opacity:.7;background:#fff}.schedule-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.schedule-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#2d3748}.schedule-frequency{display:flex;align-items:center;gap:.375rem;margin:.25rem 0 0;font-size:.875rem;color:#718096}.schedule-status{display:flex;gap:.5rem}.schedule-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.detail-row{font-size:.875rem;color:#4a5568}.detail-row strong{color:#2d3748;font-weight:600}.schedule-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}.action-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .75rem;background:var(--card-bg);border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#f7fafc;border-color:#cbd5e0;color:#2d3748}.action-btn.danger{color:#e53e3e}.action-btn.danger:hover{background:#fff5f5;border-color:#feb2b2}.badge{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge.success{background:#c6f6d5;color:#22543d}.badge.warning{background:#feebc8;color:#7c2d12}.badge.error{background:#fed7d7;color:#742a2a}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#718096}.loading-state svg,.empty-state svg{color:#cbd5e0;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#2d3748}.empty-state p{margin:0 0 1.5rem;color:#718096;max-width:400px}.alert{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;border-left:4px solid;font-size:.875rem}.alert.error{background:#fed7d7;border-color:#e53e3e;color:#742a2a}.alert.success{background:#c6f6d5;border-color:#38a169;color:#22543d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:var(--card-bg);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#2d3748;display:flex;align-items:center;gap:.5rem}.close-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:#f7fafc;border-radius:6px;color:#718096;cursor:pointer;transition:all .2s ease}.close-btn:hover{background:#edf2f7;color:#2d3748}.modal-body{padding:2rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem 2rem;border-top:1px solid #e2e8f0;background:#f7fafc}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#4a5568;font-size:.875rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.email-input-group{display:flex;gap:.5rem;margin-bottom:.5rem}.email-input-group .modern-input{flex:1}.remove-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;border:1px solid #e2e8f0;background:var(--card-bg);border-radius:6px;color:#e53e3e;cursor:pointer;transition:all .2s ease;flex-shrink:0}.remove-btn:hover{background:#fff5f5;border-color:#feb2b2}.history-filters{display:flex;gap:.75rem}.history-filters select{min-width:150px}@media (max-width: 768px){.partner-control-page{padding:1rem}.page-header{padding:1.5rem}.page-header h1{font-size:1.5rem}.modern-tabs{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.modern-tabs::-webkit-scrollbar{display:none}.modern-tab{padding:.75rem 1rem;white-space:nowrap}.content-card{padding:1.5rem}.filters-grid,.checkbox-grid,.metrics-grid{grid-template-columns:1fr}.card-header{flex-direction:column;align-items:flex-start;gap:1rem}.form-row{grid-template-columns:1fr}.data-table{font-size:.8125rem}.data-table th,.data-table td{padding:.625rem .5rem}.modal-content{max-width:100%;margin:1rem}.modal-body{padding:1.5rem}}@media (max-width: 480px){.page-header h1{font-size:1.25rem}.content-card h2{font-size:1.125rem}.modern-btn{width:100%;justify-content:center}.schedule-header{flex-direction:column;gap:.75rem}.schedule-actions{flex-wrap:wrap}.action-btn{flex:1;min-width:80px}}.dashboard-header{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e2e8f0;border-radius:1.25rem;padding:2rem 2.5rem;margin-bottom:2rem;box-shadow:0 4px 16px #00000014,0 2px 6px #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1)}.dashboard-header:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000001f,0 4px 12px #00000014}.dashboard-header-content{display:flex;justify-content:space-between;align-items:center;gap:2rem}.dashboard-header-left{flex:1}.dashboard-title{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;color:#0f172a;letter-spacing:-.025em;line-height:1.2}.dashboard-subtitle{font-size:1.125rem;color:#64748b;margin:0;font-weight:400;line-height:1.5}.dashboard-header-right{display:flex;align-items:center;gap:1.5rem}.dashboard-datetime{text-align:right;padding:1.25rem 1.75rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:1rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.dashboard-time{font-size:1.75rem;font-weight:700;color:#0f172a;margin-bottom:.25rem;font-family:Inter,monospace;letter-spacing:-.025em}.dashboard-date{font-size:.875rem;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.dashboard-search-container{position:relative;margin-bottom:2rem}.dashboard-search{display:flex;align-items:center;background-color:var(--card-bg);border-radius:1rem;box-shadow:0 .25rem .75rem #0000000f;padding:0 1.25rem;border:.0625rem solid #f0f0f0;transition:all .2s ease}.dashboard-search:focus-within{border-color:#1a1a1a;box-shadow:0 .25rem 1.25rem #0000001a}.dashboard-search input{flex:1;padding:1rem .75rem;border:none;outline:none;font-size:1rem;background:transparent}.dashboard-search svg{color:#888}.search-btn{background-color:#1a1a1a;color:#fff;border:none;border-radius:.625rem;padding:.625rem 1.25rem;margin-left:.75rem;cursor:pointer;font-weight:500;transition:background-color .2s;font-size:.875rem}.search-btn:hover{background-color:#333}.search-btn:disabled{background-color:#666;cursor:not-allowed}.search-btn-content{display:flex;align-items:center;gap:.5rem}.button-spinner{width:.875rem;height:.875rem;border:.125rem solid rgba(255,255,255,.3);border-top:.125rem solid white;border-radius:50%;animation:button-spinner-rotate 1s linear infinite}@keyframes button-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-clear-btn{background:none;border:none;color:#888;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:.25rem;transition:all .2s ease}.search-clear-btn:hover{color:#1a1a1a;background:#f0f0f0}.search-loading-indicator{display:flex;align-items:center;justify-content:center;padding:.5rem;margin-left:.5rem}.search-loading-indicator .button-spinner{width:1rem;height:1rem;border:.125rem solid rgba(26,26,26,.3);border-top:.125rem solid #1a1a1a}.search-results{position:absolute;top:100%;left:0;right:0;background-color:var(--card-bg);border-radius:1rem;box-shadow:0 .5rem 1.5625rem #00000026;margin-top:.5rem;z-index:10;max-height:21.875rem;overflow-y:auto;border:.0625rem solid #f0f0f0}.search-results-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;background-color:#f8f9fa;border-bottom:.0625rem solid #e9ecef;font-size:.9rem}.search-results-count{color:#666;font-weight:500}.search-email-loading{display:flex;align-items:center;gap:.5rem;color:#007bff;font-size:.85rem}.inline-spinner{width:.75rem;height:.75rem;border:.125rem solid #e0e0e0;border-top:.125rem solid #007bff;border-radius:50%;animation:inline-spinner-rotate 1s linear infinite}@keyframes inline-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-result-item{display:flex;align-items:center;padding:1rem 1.25rem;gap:1rem;text-decoration:none;color:#333;border-bottom:1px solid #f8f8f8;transition:all .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:#fafafa;transform:translate(4px)}.search-result-content{flex:1}.search-result-title{font-weight:600;color:#1a1a1a;margin-bottom:4px}.search-result-subtitle{font-size:.9rem;color:#666}.search-result-phone{margin-top:6px;display:flex;flex-wrap:wrap;gap:12px}.phone-number{font-size:.85rem;color:#007bff;background-color:#f8f9ff;padding:2px 8px;border-radius:12px;border:1px solid #e1e8ff;font-weight:500}.search-result-empty{padding:20px;text-align:center;color:#888;font-style:italic}.search-result-title{font-weight:500;margin-bottom:2px}.search-result-subtitle{font-size:14px;color:#666}.search-result-empty{padding:16px;text-align:center;color:#666}.search-result-snippet{font-size:.8rem;color:#888;margin-top:4px;line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-loading-indicator{padding:16px 20px;border-bottom:1px solid #f8f8f8;background-color:#fafafa}.search-loading-content{display:flex;align-items:center;gap:12px;color:#666;font-size:.9rem}.search-loading-spinner{width:16px;height:16px;border:2px solid #e0e0e0;border-top:2px solid #1a1a1a;border-radius:50%;animation:search-spinner-rotate 1s linear infinite}@keyframes search-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-bottom:32px;width:100%}.stat-card{background-color:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;display:flex;align-items:center;gap:18px;min-height:120px;border:1px solid #e0e0e0;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;color:#fff}.stat-icon.new-contracts{background-color:#2196f3}.stat-icon.avg-time{background-color:#ff9800}.stat-icon.completion-time{background-color:#9c27b0}.stat-icon.ongoing{background-color:#4caf50}.stat-icon.tasks{background-color:#f44336}.stat-content{flex:1}.stat-value{font-size:24px;font-weight:600;line-height:1.2}.stat-label{font-size:14px;color:#666;margin-top:4px}.stat-tooltip{font-size:10px;color:#888;font-style:italic;margin-top:2px}.small-text{font-size:.8em;color:#777}.dashboard-page{padding:1.5rem 2rem;max-width:none;width:100%;color:#333;background:#fff;min-height:100vh}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(18rem,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card-new{background:var(--card-bg);border-radius:1rem;padding:1.75rem;box-shadow:0 .125rem .5rem #0000000f;border:.125rem solid #f0f0f0;display:flex;align-items:center;gap:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer;transform:translateY(0)}.stat-card-new:hover{transform:translateY(-.25rem);box-shadow:0 .5rem 1.5rem #0000001f;border-color:#e0e0e0}.stat-card-new.clickable{cursor:pointer}.stat-card-new.active{border-color:#1a1a1a;background:linear-gradient(135deg,#fff,#f8f9fa);box-shadow:0 .5rem 2rem #1a1a1a26;transform:translateY(-.25rem) scale(1.02)}.stat-card-new.active:before{background:linear-gradient(90deg,#1a1a1a,#333,#1a1a1a);height:.25rem}.stat-card-new:before{content:"";position:absolute;top:0;left:0;right:0;height:.25rem;background:linear-gradient(90deg,#1a1a1a,#333);transition:all .3s ease}.stat-card-icon{width:3.75rem;height:3.75rem;background:#1a1a1a;border-radius:.875rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;flex-shrink:0;transition:all .3s ease}.stat-card-new.active .stat-card-icon{background:linear-gradient(135deg,#1a1a1a,#333);box-shadow:0 .25rem .75rem #1a1a1a4d}.stat-card-icon.ai-task{background:#444}.stat-card-content{flex:1}.stat-number{font-size:2.2rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem;line-height:1;transition:all .3s ease}.stat-card-new.active .stat-number{color:#000;text-shadow:0 1px 2px rgba(0,0,0,.1)}.stat-label{font-size:.95rem;color:#666;margin:0;font-weight:500;transition:all .3s ease}.stat-card-new.active .stat-label{color:#333;font-weight:600}.main-content-section{min-height:25rem;transition:all .3s ease}.dynamic-content{min-height:20rem;opacity:1;transform:translateY(0);transition:all .3s cubic-bezier(.4,0,.2,1)}.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(24rem,1fr));grid-template-rows:repeat(2,auto);gap:1.5rem;width:100%;animation:fadeInUp .4s ease-out;overflow:hidden}@keyframes fadeInUp{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.ringeliste-grid{grid-template-columns:repeat(auto-fill,minmax(20rem,1fr));grid-template-rows:repeat(2,auto)}.no-data-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:#666;grid-column:1 / -1;background:#fafafa;border-radius:1rem;border:.125rem dashed #e0e0e0}.no-data-message h3{margin:1rem 0 .5rem;font-size:1.25rem;font-weight:600;color:#333}.no-data-message p{margin:0;font-size:.95rem;color:#888}.ringeliste-card{background:#fff;border-radius:1rem;padding:1.5rem;text-decoration:none;color:inherit;border:.125rem solid #f0f0f0;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem;min-height:12rem}.ringeliste-card:hover{transform:translateY(-.1875rem);box-shadow:0 .375rem 1.25rem #0000001a;border-color:#e0e0e0;background:var(--card-bg)}.ringeliste-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.ringeliste-details{display:flex;flex-direction:column;gap:.75rem;flex:1}.ringeliste-actions{display:flex;justify-content:flex-end;align-items:center}.priority-indicator{background:#fff3cd;color:#856404;padding:.375rem .75rem;border-radius:.5rem;font-size:.8rem;font-weight:500;border:.0625rem solid #ffeaa7}.dashboard-grid{display:flex;flex-direction:column;gap:2rem}.card-section{background:var(--card-bg);border-radius:20px;padding:32px;box-shadow:0 4px 12px #0000000d;border:1px solid #f0f0f0;transition:all .3s ease}.card-section:hover{box-shadow:0 8px 25px #00000014;border-color:#e0e0e0}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f8f8f8}.card-header h2{font-size:1.4rem;font-weight:600;color:#1a1a1a;margin:0}.view-all-link{color:#1a1a1a;text-decoration:none;font-weight:500;font-size:.9rem;padding:8px 16px;border-radius:8px;background:#f8f8f8;transition:all .2s ease}.view-all-link:hover{background:#1a1a1a;color:#fff}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px}.project-card-new{background:#fafafa;border-radius:16px;padding:24px;text-decoration:none;color:inherit;border:1px solid #f0f0f0;transition:all .3s ease;display:flex;flex-direction:column;gap:20px;min-height:220px}.project-card-new:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001a;border-color:#e0e0e0;background:var(--card-bg)}.project-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.project-name{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin:0;line-height:1.3}.status-badge-new{background:#f0f0f0;color:#666;padding:6px 12px;border-radius:8px;font-size:.75rem;font-weight:500;white-space:nowrap}.project-details{display:flex;flex-direction:column;gap:12px;flex:1}.project-customer,.project-address{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#666;margin:0}.project-dates{font-size:.85rem;color:#888;margin-top:8px}.project-progress-section{display:flex;flex-direction:column;gap:8px}.progress-info{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:.85rem;color:#666;font-weight:500}.progress-percentage{font-size:.9rem;font-weight:600;color:#1a1a1a}.progress-bar-new{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.dashboard-columns-new{display:grid;grid-template-columns:1fr 1fr;gap:32px}.tasks-list{display:flex;flex-direction:column;gap:16px}.task-card-new{background:#fafafa;border-radius:12px;padding:20px;border:1px solid #f0f0f0;transition:all .2s ease}.task-card-new:hover{background:var(--card-bg);border-color:#e0e0e0;box-shadow:0 2px 8px #0000000f}.task-main{margin-bottom:16px}.task-title{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0 0 8px}.task-description{font-size:.9rem;color:#666;margin:0;line-height:1.4}.task-meta-new{display:flex;gap:16px;flex-wrap:wrap}.task-project,.task-assignee{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#888}.todo-form-new{display:flex;gap:12px;margin-bottom:24px}.todo-input{flex:1;padding:14px 16px;border:1px solid #e0e0e0;border-radius:10px;font-size:.9rem;outline:none;transition:border-color .2s ease}.todo-input:focus{border-color:#1a1a1a}.todo-add-btn{padding:14px 16px;background:#1a1a1a;color:#fff;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.todo-add-btn:hover{background:#333}.todo-list-new{display:flex;flex-direction:column;gap:12px}.todo-item-new{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fafafa;border-radius:10px;border:1px solid #f0f0f0;transition:all .2s ease}.todo-item-new:hover{background:var(--card-bg);border-color:#e0e0e0}.todo-item-new.completed{opacity:.6}.todo-checkbox-new{background:none;border:none;color:#888;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.todo-checkbox-new:hover{color:#1a1a1a}.todo-item-new.completed .todo-checkbox-new{color:#4caf50}.todo-content{flex:1;display:flex;justify-content:space-between;align-items:center;gap:16px;min-width:0}.todo-text-new{flex:1;font-size:.9rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.todo-item-new.completed .todo-text-new{text-decoration:line-through;color:#888}.todo-meta{display:flex;align-items:center;gap:8px}.todo-created-at{font-size:.8rem;color:#888;white-space:nowrap}.todo-creator-initials{font-size:.75rem;color:#fff;background:#1a1a1a;padding:2px 6px;border-radius:10px;font-weight:500;white-space:nowrap;min-width:24px;text-align:center}.todo-delete-new{background:none;border:none;color:#f44336;cursor:pointer;opacity:0;transition:opacity .2s ease;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px}.todo-item-new:hover .todo-delete-new{opacity:1}.todo-delete-new:hover{background:#f443361a}@media (max-width: 75rem){.dashboard-page{padding:1.25rem 1.5rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:1.25rem;margin-bottom:2rem}.content-grid{grid-template-columns:repeat(auto-fill,minmax(20rem,1fr));gap:1.25rem}.dashboard-columns-new{grid-template-columns:1fr}}@media (max-width: 64rem){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(15rem,1fr))}.stat-card-new{padding:1.5rem;gap:1rem}.stat-card-icon{width:3rem;height:3rem;font-size:1.25rem}.stat-number{font-size:1.875rem}}@media (max-width: 48rem){.dashboard-page{padding:1rem}.stats-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.content-grid{grid-template-columns:1fr;gap:1rem}.ringeliste-grid{grid-template-columns:1fr}.card-section{padding:1.5rem}.stat-card-new{padding:1.25rem;gap:.875rem;flex-direction:row}.stat-number{font-size:1.75rem}.stat-label{font-size:.875rem}.dashboard-welcome{padding:1.5rem;margin-bottom:1.5rem}.dashboard-welcome h1{font-size:1.875rem}}@media (max-width: 30rem){.dashboard-page{padding:.75rem}.stats-grid{gap:.75rem;margin-bottom:1.25rem}.stat-card-new{padding:1rem;gap:.75rem;flex-direction:column;text-align:center;min-height:auto}.stat-card-icon{width:2.5rem;height:2.5rem;font-size:1.125rem;margin:0 auto}.stat-number{font-size:1.5rem;margin-bottom:.25rem}.stat-label{font-size:.8rem}.card-section{padding:1rem}.dashboard-welcome{padding:1rem;text-align:center}.dashboard-welcome h1{font-size:1.5rem}.dashboard-welcome p{font-size:.95rem}.no-data-message{padding:2rem 1rem}.no-data-message h3{font-size:1.125rem}.project-card-new,.ringeliste-card{padding:1rem;gap:.75rem;min-height:auto}}@media (hover: none) and (pointer: coarse){.stat-card-new:hover{transform:none;box-shadow:0 .125rem .5rem #0000000f}.stat-card-new:active{transform:translateY(.0625rem);transition:transform .1s ease}.stat-card-new.active{transform:translateY(0)}}.dashboard-content{display:flex;flex-direction:column;gap:32px;width:100%}.dashboard-columns{display:grid;grid-template-columns:1fr 1fr;gap:32px}.dashboard-section{background-color:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #00000014;padding:24px;border:1px solid #e0e0e0;transition:transform .2s,box-shadow .2s}.dashboard-section:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:20px;font-weight:600;margin:0}.view-all-link{font-size:15px;color:#2196f3;text-decoration:none;font-weight:500}.view-all-link:hover{text-decoration:underline}.project-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.project-card{background-color:#f9f9f9;border-radius:12px;padding:20px;text-decoration:none;color:#333;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:14px;min-height:200px;border:1px solid #e0e0e0}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.project-name{font-size:16px;font-weight:600;margin:0 0 4px}.project-customer{font-size:14px;color:#666;margin:0 0 4px}.project-address{font-size:14px;color:#666;margin:0 0 8px}.project-dates{font-size:14px;color:#888;margin-bottom:8px}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;background-color:var(--card-bg);color:#333}.project-progress{margin-top:8px}.progress-bar-container{height:6px;background-color:#f0f0f0;border-radius:3px;overflow:hidden;margin-bottom:4px}.progress-bar{height:100%;border-radius:3px}.progress-text{font-size:12px;color:#666}.task-list{display:flex;flex-direction:column;gap:12px}.task-item{background-color:#f9f9f9;border-radius:8px;padding:16px}.task-title{font-size:16px;font-weight:600;margin:0 0 4px}.task-description{font-size:14px;color:#666;margin:0 0 8px}.task-meta{display:flex;gap:16px}.task-project,.task-assignee{display:flex;align-items:center;gap:4px;font-size:12px;color:#888}.todo-form{display:flex;margin-bottom:16px}.todo-form input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:6px 0 0 6px;outline:none;font-size:14px}.todo-form button{background-color:#1a1a1a;color:#fff;border:none;border-radius:0 6px 6px 0;padding:0 12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.todo-items{display:flex;flex-direction:column;gap:8px}.todo-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;transition:background-color .2s}.todo-item:hover{background-color:#f0f0f0}.todo-item.completed .todo-text{text-decoration:line-through;color:#888}.todo-checkbox{background:none;border:none;color:#888;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.todo-checkbox:hover{color:#555}.todo-item.completed .todo-checkbox{color:#4caf50}.todo-text{flex:1;font-size:14px}.todo-delete{background:none;border:none;color:#f44336;cursor:pointer;opacity:0;transition:opacity .2s;padding:0;display:flex;align-items:center;justify-content:center}.todo-item:hover .todo-delete{opacity:1}.error-message{background-color:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:20px}.no-data-message{color:#888;text-align:center;padding:16px}.dashboard-welcome{background:var(--card-bg);border-radius:20px;padding:40px;margin-bottom:32px;box-shadow:0 4px 12px #0000000d;border:1px solid #f0f0f0;position:relative;overflow:hidden}.dashboard-welcome:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#1a1a1a,#333)}.dashboard-welcome h1{font-size:2.4rem;font-weight:700;color:#1a1a1a;margin:0 0 12px;background:linear-gradient(135deg,#1a1a1a,#333);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-welcome p{font-size:1.1rem;color:#666;margin:0;line-height:1.5}.stat-cards.modern{display:flex;gap:32px;margin-bottom:32px;flex-wrap:wrap;justify-content:center;width:100%}.stat-card.modern{background:#fff;border-radius:14px;box-shadow:0 2px 12px #0000000f;padding:28px 32px;display:flex;align-items:center;gap:20px;min-width:320px;flex:1;max-width:500px;border:1px solid #ececec;transition:box-shadow .2s,border .2s}.stat-card.modern:hover{box-shadow:0 4px 24px #0000001a;border:1px solid #bbb}.stat-icon.modern{background:#111;color:#fff;border-radius:10px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon.new-contracts.modern{background:#222}.stat-icon.tasks.modern{background:#444}.dashboard-content.modern{display:flex;gap:32px;align-items:flex-start;width:100%}@media (min-width: 1600px){.stat-cards{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:32px}.project-list{grid-template-columns:repeat(auto-fill,minmax(450px,1fr));gap:32px}.stat-card.modern{min-width:380px;max-width:600px}}@media (max-width: 1400px){.stat-cards.modern,.dashboard-content.modern{flex-direction:column;gap:24px}.dashboard-welcome{padding:24px 16px 16px}}@media (max-width: 900px){.stat-cards.modern,.dashboard-content.modern{flex-direction:column;gap:20px}.dashboard-welcome{padding:24px 12px 16px}}.chat-fab{position:fixed;bottom:32px;right:32px;background:#111;color:#fff;border:none;border-radius:50%;width:56px;height:56px;box-shadow:0 4px 16px #0000002e;display:flex;align-items:center;justify-content:center;z-index:1001;cursor:pointer;transition:background .2s}.chat-fab:hover{background:#222}.chat-window{position:fixed;bottom:100px;right:32px;width:340px;max-width:95vw;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000002e;z-index:1002;display:flex;flex-direction:column;overflow:hidden;border:1px solid #ececec;height:70vh}.chat-header{background:#111;color:#fff;padding:16px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.chat-header button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer}.chat-messages{padding:16px;flex:1;overflow-y:auto;background:#fafbfc;display:flex;flex-direction:column;gap:10px}.chat-bubble{max-width:80%;padding:10px 16px;border-radius:16px;font-size:1rem;line-height:1.4;word-break:break-word}.chat-bubble.user{background:#111;color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.chat-bubble.assistant{background:#eaeaea;color:#222;align-self:flex-start;border-bottom-left-radius:4px}.chat-input-row{display:flex;border-top:1px solid #ececec;background:#fff}.chat-input-row input{flex:1;border:none;padding:14px 12px;font-size:1rem;outline:none;background:#fff}.chat-input-row button{background:#111;color:#fff;border:none;padding:0 18px;font-size:1rem;cursor:pointer;border-radius:0 0 16px;transition:background .2s}.chat-input-row button:disabled{background:#888;cursor:not-allowed}@media (max-width: 600px){.chat-window{right:8px;width:98vw;bottom:120px}.chat-fab{right:8px;bottom:16px}}@media (max-width: 768px){.dashboard-header{padding:1.5rem 1.25rem;margin-bottom:1.5rem}.dashboard-header-content{flex-direction:column;align-items:flex-start;gap:1.5rem}.dashboard-header-right{align-self:stretch}.dashboard-datetime{width:100%;text-align:right;padding:1rem 1.25rem}.dashboard-title{font-size:2rem}.dashboard-subtitle{font-size:1rem}.dashboard-time{font-size:1.5rem}}@media (max-width: 480px){.dashboard-header{padding:1.25rem 1rem;border-radius:1rem}.dashboard-title{font-size:1.75rem}.dashboard-subtitle{font-size:.875rem}.dashboard-time{font-size:1.25rem}.dashboard-date{font-size:.75rem}}.chart-container{width:100%;max-width:100%;overflow:hidden;box-sizing:border-box;padding-bottom:1rem;flex:1;display:flex;flex-direction:column}.card-section .chart-container>div{min-width:0;max-width:100%}.chart-section{max-width:100%;overflow:hidden;box-sizing:border-box;display:flex;flex-direction:column}.chart-wrapper{width:100%;max-width:100%;height:100%;min-height:250px;position:relative;box-sizing:border-box;overflow:hidden;flex:1}@media (max-width: 768px){.chart-wrapper{min-height:200px}}[data-theme=dark] .dashboard-page{background:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] .dashboard-header{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 40px #00d4ff26,0 4px 20px #0000004d}[data-theme=dark] .dashboard-header:hover{box-shadow:0 0 60px #00d4ff40,0 8px 32px #0006}[data-theme=dark] .dashboard-title{color:var(--text-primary);text-shadow:0 0 30px rgba(0,212,255,.4)}[data-theme=dark] .dashboard-subtitle{color:var(--text-secondary)}[data-theme=dark] .dashboard-datetime{background:linear-gradient(135deg,#00d4ff0d,#7c3aed0d);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 20px #00d4ff33}[data-theme=dark] .dashboard-time{color:var(--accent-color);text-shadow:0 0 20px rgba(0,212,255,.5)}[data-theme=dark] .dashboard-date{color:var(--text-muted)}[data-theme=dark] .dashboard-search{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);box-shadow:0 0 20px #00d4ff1a}[data-theme=dark] .dashboard-search:focus-within{border-color:var(--accent-color);box-shadow:0 0 30px #00d4ff4d}[data-theme=dark] .dashboard-search input{background:transparent;color:var(--text-primary)}[data-theme=dark] .dashboard-search input::placeholder{color:var(--text-muted)}[data-theme=dark] .dashboard-grid,[data-theme=dark] .dashboard-stats-grid,[data-theme=dark] .dashboard-charts-grid{background:transparent}[data-theme=dark] .dashboard-card,[data-theme=dark] .stat-card,[data-theme=dark] .chart-card,[data-theme=dark] .activity-card,[data-theme=dark] .quick-actions-card{background:var(--card-bg);border:1px solid rgba(0,212,255,.15);box-shadow:0 0 30px #00d4ff1a,0 4px 15px #0000004d}[data-theme=dark] .dashboard-card:hover,[data-theme=dark] .stat-card:hover,[data-theme=dark] .chart-card:hover{border-color:#00d4ff4d;box-shadow:0 0 40px #00d4ff33,0 8px 25px #0006;transform:translateY(-2px)}[data-theme=dark] .card-header,[data-theme=dark] .stat-card-header{border-bottom:1px solid rgba(0,212,255,.15)}[data-theme=dark] .card-title,[data-theme=dark] .stat-label{color:var(--text-primary)}[data-theme=dark] .card-subtitle{color:var(--text-muted)}[data-theme=dark] .stat-value{color:var(--accent-color);text-shadow:0 0 20px rgba(0,212,255,.4)}[data-theme=dark] .stat-change{color:var(--text-secondary)}[data-theme=dark] .stat-change.positive{color:var(--success-color);text-shadow:0 0 10px rgba(0,255,136,.4)}[data-theme=dark] .stat-change.negative{color:var(--error-color)}[data-theme=dark] .stat-icon{background:var(--gradient-primary);box-shadow:0 0 20px #00d4ff66}[data-theme=dark] .quick-action-btn,[data-theme=dark] .action-button,[data-theme=dark] .btn{background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .quick-action-btn:hover,[data-theme=dark] .action-button:hover,[data-theme=dark] .btn:hover{background:#00d4ff33;border-color:var(--accent-color);box-shadow:0 0 25px #00d4ff66;color:var(--accent-color)}[data-theme=dark] .activity-item,[data-theme=dark] .notification-item,[data-theme=dark] .list-item{background:#00d4ff0d;border:1px solid rgba(0,212,255,.1)}[data-theme=dark] .activity-item:hover,[data-theme=dark] .notification-item:hover,[data-theme=dark] .list-item:hover{background:#00d4ff1a;border-color:#00d4ff33;box-shadow:0 0 20px #00d4ff33}[data-theme=dark] .activity-time,[data-theme=dark] .meta-text,[data-theme=dark] .secondary-text{color:var(--text-muted)}[data-theme=dark] .badge,[data-theme=dark] .status-badge{background:var(--gradient-primary);color:#fff;box-shadow:0 0 15px #00d4ff80}[data-theme=dark] table,[data-theme=dark] .data-table{background:var(--card-bg);border:1px solid rgba(0,212,255,.15)}[data-theme=dark] th,[data-theme=dark] .table-header{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);color:var(--text-primary);border-bottom:2px solid rgba(0,212,255,.3)}[data-theme=dark] .chart-container,[data-theme=dark] .chart-wrapper{background:#0f141980;border:1px solid rgba(0,212,255,.15)}.ringeliste-page{padding:1.5rem 2rem;max-width:87.5rem;margin:0 auto;width:100%;color:var(--text-primary);background:var(--bg-primary);min-height:100vh}.ringeliste-header{margin-bottom:2rem}.ringeliste-header h1{font-size:2.4rem;font-weight:700;color:var(--text-primary);margin:0 0 .75rem}.ringeliste-header .description{font-size:1.1rem;color:var(--text-secondary);margin:0;line-height:1.5}.filter-btn{font-weight:500;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:.5rem;min-height:2.75rem}.filter-btn:hover{background:var(--bg-tertiary);border-color:var(--border-color)}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.table-container{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.checkbox-container{display:flex;align-items:center;justify-content:center;cursor:pointer;margin:0}.checkbox-container input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--warning-color)}.project-number{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-weight:600;font-size:.875rem;background-color:var(--card-bg);color:var(--primary-color);padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border-color);display:inline-block}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background-color:var(--card-bg);white-space:nowrap;display:inline-block}.status-badge.draft{background-color:#f3f4f6;color:#374151}.status-badge.mottatt-bud{background-color:#e0f2fe;color:#0369a1}.ringeliste-content .projects-table th{background:#f3f4f6!important;color:#374151!important;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;border-bottom:1px solid #e5e7eb;background-image:none!important;background-clip:initial!important}.clickable-row.hidden-project:hover{opacity:.8;background-color:var(--bg-secondary)}.clickable-row.hidden-project .project-address,.clickable-row.hidden-project .customer-name{text-decoration:line-through;color:var(--text-tertiary)}.clickable-row.hidden-project .status-badge{opacity:.7}.error-message{background-color:#ffebee;color:#c62828;padding:16px;border-radius:8px;margin-bottom:24px}.loading-indicator{display:flex;justify-content:center;align-items:center;height:200px}.no-projects-message{display:flex;justify-content:center;align-items:center;background:var(--card-bg);border-radius:16px;padding:40px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;margin-top:32px;text-align:center}.no-projects-message p{font-size:1.1rem;color:#666}@media (max-width: 768px){.ringeliste-page{padding:16px}.ringeliste-header h1{font-size:2rem}.filter-buttons{flex-direction:column;gap:8px}.filter-btn{width:100%;text-align:center}.table-container{overflow-x:auto}.projects-table{min-width:600px}}.working-list-page{padding:2rem;max-width:1400px;margin:0 auto}.working-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.working-list-header h1{color:#1f2937;font-size:2rem;font-weight:700;margin:0}.search-filter-row{background:var(--card-bg);padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.search-filter-row input{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem}.search-filter-row input:focus{outline:none;border-color:#9ca3af;box-shadow:0 0 0 3px #9ca3af1a}.search-filter-row select{padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;background:var(--card-bg)}.search-filter-row select:focus{outline:none;border-color:#9ca3af;box-shadow:0 0 0 3px #9ca3af1a}.filter-label{color:#374151;font-weight:500;font-size:.95rem}.working-list-content{background:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-container{overflow-x:auto}.working-list-content .projects-table th{background:#f3f4f6!important;color:#374151!important;padding:1rem;text-align:left;font-weight:600;font-size:.9rem;border-bottom:1px solid #e5e7eb;background-image:none!important;background-clip:initial!important}.projects-table td{padding:1rem;border-bottom:1px solid #e5e7eb;font-size:.9rem;vertical-align:middle}.projects-table tr:hover{background-color:#f9fafb}.projects-table tr.hidden-project{opacity:.6;background-color:#f3f4f6}.projects-table tr.hidden-project:hover{background-color:#e5e7eb}.clickable-row{cursor:pointer;transition:background-color .2s ease}.project-number{font-weight:600;color:#374151}.checkbox-container{display:flex;align-items:center;cursor:pointer}.checkbox-container input[type=checkbox]{width:18px;height:18px;cursor:pointer}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.draft{background-color:#fef3c7;color:#92400e}.status-badge.anbudsrunde{background-color:#dbeafe;color:#1e40af}.status-badge.mottatt-bud{background-color:#d1fae5;color:#065f46}.status-badge.akseptert-oppdrag{background-color:#ecfdf5;color:#047857}.status-badge.oppstartsjekkliste{background-color:#fef7ff;color:#86198f}.status-badge.avsluttingsjekkliste{background-color:#fdf4ff;color:#a21caf}.status-badge.ferdig-prosjekt{background-color:#f0fdf4;color:#166534}.status-badge.betalt{background-color:#dcfce7;color:#14532d}.status-badge.tapt{background-color:#fee2e2;color:#991b1b}.status-badge.kansellert{background-color:#fecaca;color:#7f1d1d}.project-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.project-type-badge.anbudsrunde{background-color:#ede9fe;color:#5b21b6}.project-type-badge.single_bid{background-color:#fef3c7;color:#92400e}.bid-count{font-weight:600;color:#4b5563}.priority-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.priority-badge.high{background-color:#fee2e2;color:#991b1b}.priority-badge.medium{background-color:#fef3c7;color:#92400e}.priority-badge.low{background-color:#ecfdf5;color:#047857}.loading-indicator{text-align:center;padding:3rem;color:#6b7280}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:1rem 1.5rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.no-projects-message{text-align:center;padding:3rem;color:#6b7280;font-size:1.1rem}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.pagination-info{color:#6b7280;font-size:.9rem}.pagination-controls{display:flex;gap:.5rem;align-items:center}.pagination-btn{padding:.5rem .75rem;border:1px solid #d1d5db;background:var(--card-bg);color:#374151;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background:#6b7280;color:#fff;border-color:#6b7280}.pagination-pages{display:flex;gap:.25rem}@media (max-width: 768px){.working-list-page{padding:1rem}.working-list-header{flex-direction:column;align-items:flex-start;gap:1rem}.search-filter-row{flex-direction:column;align-items:stretch;gap:1rem}.pagination-container{flex-direction:column;gap:1rem}.pagination-controls{justify-content:center}.projects-table{font-size:.8rem}.projects-table th,.projects-table td{padding:.75rem .5rem}}.sluttgjennomgang-page{padding:1.5rem;max-width:100%;overflow-x:hidden}.sluttgjennomgang-header{margin-bottom:2rem}.sluttgjennomgang-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.page-description{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.4}.search-filter-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.search-filter-row input{flex:1;min-width:200px;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem}.project-count{font-size:.875rem;color:var(--text-secondary);font-weight:500}.sluttgjennomgang-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.payment-button{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px;text-align:center}.payment-button.pending{background-color:#6b7280;color:#fff}.payment-button.pending:hover{background-color:#4b5563}.payment-button.confirmed{background-color:#10b981;color:#fff;cursor:pointer}.payment-button.confirmed:hover{background-color:#059669}.payment-button:disabled{opacity:.8;cursor:not-allowed}.complete-button{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px;text-align:center}.complete-button.enabled{background-color:#3b82f6;color:#fff}.complete-button.enabled:hover{background-color:#2563eb}.complete-button.disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.clickable-row.completed-project{background-color:#10b9810d;border-left:3px solid #10b981}.clickable-row.hidden-project{opacity:.6;background-color:var(--bg-tertiary)}.clickable-row.hidden-project:hover{opacity:.8}.checkbox-container{display:flex;align-items:center;justify-content:center;cursor:pointer;gap:.5rem}.checkbox-container input[type=checkbox]{width:16px;height:16px;cursor:pointer}.checkbox-label{font-size:.75rem;color:#374151;white-space:nowrap}.remove-button{padding:.4rem .8rem;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px;text-align:center}.remove-button.enabled{background-color:#dc2626;color:#fff}.remove-button.enabled:hover{background-color:#b91c1c}.remove-button.disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem}.loading-indicator{text-align:center;padding:2rem;color:var(--text-secondary)}.no-projects-message{text-align:center;padding:3rem;color:var(--text-secondary)}.no-projects-message p{margin:0;font-size:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg);padding:2rem;border-radius:8px;max-width:400px;width:90%;box-shadow:0 10px 25px #0003}.modal-content h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-content p{margin:0 0 1.5rem;color:var(--text-secondary);line-height:1.5}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-primary,.btn-secondary{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover{background-color:#2563eb}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.project-number{font-weight:600;color:var(--text-primary)}@media (max-width: 768px){.sluttgjennomgang-page{padding:1rem}.search-filter-row{flex-direction:column;align-items:stretch}.search-filter-row input{width:100%;min-width:unset}.payment-button{min-width:80px;font-size:.7rem;padding:.3rem .6rem}.modal-content{margin:1rem;padding:1.5rem}.modal-actions{flex-direction:column;gap:.5rem}.btn-primary,.btn-secondary{width:100%}}.sluttgjennomgang-page .projects-table th:nth-child(5),.sluttgjennomgang-page .projects-table th:nth-child(6),.sluttgjennomgang-page .projects-table th:nth-child(7){min-width:120px;text-align:center}.sluttgjennomgang-page .projects-table td:nth-child(5),.sluttgjennomgang-page .projects-table td:nth-child(6),.sluttgjennomgang-page .projects-table td:nth-child(7){text-align:center;padding:.5rem}@media (prefers-color-scheme: dark){.modal-content{background:var(--bg-secondary);color:var(--text-primary)}.payment-button.pending{background-color:#4b5563}.payment-button.pending:hover{background-color:#374151}}.calendar-page{padding:.75rem;max-width:1400px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:transparent;min-height:100vh}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding:1.25rem 0;border-bottom:2px solid #f0f0f0;background:transparent}.header-title{display:flex;align-items:center;gap:.5rem}.header-title h1{margin:0;font-size:1.75rem;font-weight:700;color:#1d1d1f;letter-spacing:-.02em}.calendar-navigation{display:flex;align-items:center;gap:1rem}.nav-button{display:flex;align-items:center;justify-content:center;width:40px;height:32px;background:var(--card-bg);border:1.5px solid #e5e5e7;border-radius:6px;color:#1d1d1f!important;cursor:pointer;transition:all .2s ease;font-weight:500;box-shadow:0 1px 3px #0000001a}.nav-button:hover{background:#f8f8f8;border-color:#d1d1d6;transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.nav-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.nav-button svg{color:#1d1d1f!important;stroke:#1d1d1f!important;stroke-width:2.5;fill:none;width:16px;height:16px}.current-month{margin:0;font-size:1.25rem;font-weight:600;color:#1d1d1f;min-width:180px;text-align:center;letter-spacing:-.01em;transition:all .2s ease}.current-month:hover{color:#007aff}.calendar-info{display:flex;align-items:center;gap:.75rem;color:#6e6e73;font-size:.9rem;font-weight:500}.info-item{display:flex;align-items:center;gap:.25rem;font-weight:500}.info-tooltip{position:relative;display:flex;align-items:center;cursor:help}.tooltip-content{position:absolute;bottom:100%;right:0;margin-bottom:.5rem;padding:.75rem 1rem;background:#000c;color:#fff;border-radius:8px;font-size:.875rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:10}.info-tooltip:hover .tooltip-content{opacity:1;visibility:visible}.calendar-legend{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem;padding:0;background:transparent}.legend-label{font-weight:500;color:#6e6e73;font-size:.85rem}.legend-gradient{display:flex;align-items:center;gap:.75rem}.legend-start,.legend-end{font-size:.75rem;font-weight:400;color:#8e8e93}.gradient-bar{width:120px;height:4px;background:linear-gradient(to right,#2e7d32,#388e3c,#4caf50,#66bb6a,#ff9800,#ff7043,#e57373,#ef5350);border-radius:2px}.calendar-grid{background:transparent;border-radius:12px;border:1px solid #e5e5e7;overflow:hidden;transition:all .3s ease}.calendar-grid:hover{border-color:#d1d1d6;box-shadow:0 2px 8px #0000000a}.calendar-week-header{display:grid;grid-template-columns:repeat(7,1fr);background:transparent;border-bottom:1px solid #e5e5e7}.day-header{padding:.5rem .375rem;text-align:center;font-weight:600;color:#1d1d1f;text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);animation:fadeIn .4s ease-out}.calendar-day{position:relative;aspect-ratio:2.2;min-height:50px;border:1px solid #f2f2f7;display:flex;flex-direction:column;padding:.375rem;transition:all .2s ease;background:transparent}.calendar-day:hover{background:#00000005;border-color:#d1d1d6;transform:scale(1.01)}.calendar-day.empty{background:transparent;opacity:.4}.calendar-day.today{background:#007aff0d;border:2px solid #007aff;box-shadow:0 0 0 1px #007aff1a}.calendar-day.today .day-number{color:#007aff;font-weight:700}.day-number{font-size:.85rem;font-weight:700;color:#1d1d1f;margin-bottom:.125rem;line-height:1}.availability-bar{flex:1;min-height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;margin:.125rem 0;transition:all .3s ease;position:relative;box-shadow:0 1px 3px #0000001a;border:1px solid rgba(255,255,255,.1)}.availability-bar:hover{transform:translateY(-1px);box-shadow:0 3px 8px #0003;border-color:#fff3}.bar-percentage{font-size:.65rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8);letter-spacing:.3px}.day-details{margin-top:auto;text-align:center}.working-count{font-size:.6rem;color:#666;text-align:center;margin-top:.125rem;padding:.125rem .25rem;background:#ffffffe6;border-radius:3px;font-weight:500}.calendar-summary{margin-top:.75rem;padding:.75rem 1rem;background:transparent;border-radius:8px;border:1px solid #e5e5e7}.summary-stats{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.125rem}.stat-label{font-size:.7rem;color:#6e6e73;font-weight:400}.stat-value{font-size:1rem;font-weight:600;color:#1d1d1f}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.loading-spinner{width:24px;height:24px;border:2px solid #f2f2f7;border-top:2px solid #007aff;border-radius:50%;animation:spin 1s linear infinite}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;padding:2rem;background:transparent;border-radius:12px;border:1px solid #e5e5e7;text-align:center}.error-message{color:#ff3b30;font-size:1rem;font-weight:500}.retry-button{background:#007aff;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:#0056b3;transform:scale(1.05)}.calendar-day.clickable{transition:all .2s ease}.calendar-day.clickable:hover{background:#0000000d;transform:scale(1.02);box-shadow:0 2px 8px #0000001a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--card-bg);border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e5e7}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1d1d1f}.modal-close{background:none;border:none;font-size:1.5rem;color:#8e8e93;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:#f2f2f7;color:#1d1d1f}.modal-body{padding:1.5rem}.contractors-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.contractor-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#f8f9fa;border-radius:8px;border:1px solid #e5e5e7}.contractor-info{display:flex;flex-direction:column;gap:.25rem}.contractor-name{font-weight:600;color:#1d1d1f;font-size:.9rem}.contractor-rating{display:flex;gap:.125rem}.star-filled{opacity:1;font-size:.75rem}.star-empty{opacity:.3;font-size:.75rem}.modal-summary{padding:1rem;background:#f8f9fa;border-radius:8px;text-align:center}.modal-summary p{margin:0;color:#666;font-size:.9rem;font-weight:500}@media (max-width: 768px){.calendar-page{padding:.5rem}.calendar-header{padding:.75rem 0;flex-direction:column;gap:.75rem}.header-title h1{font-size:1.25rem}.current-month{font-size:1rem;min-width:auto}.nav-button{width:36px;height:28px}.calendar-day{min-height:40px;padding:.25rem}.day-header{padding:.375rem .25rem;font-size:.7rem}.legend-gradient{gap:.5rem}.gradient-bar{width:80px;height:6px}.summary-stats{gap:1rem;flex-direction:column}.availability-bar{min-height:16px}}@media (max-width: 480px){.calendar-day{min-height:35px;padding:.125rem}.day-number{font-size:.75rem}.availability-bar{min-height:14px;border-radius:4px}.bar-percentage{font-size:.55rem}.working-count{font-size:.55rem;padding:.0625rem .125rem}.header-title h1{font-size:1rem}.current-month{font-size:.9rem}}.executive-summary-card{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000001a}.summary-title{font-size:18px;font-weight:600;color:#111827;margin:0 0 20px}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.metric-display{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:all .2s ease}.metric-display:hover{box-shadow:0 2px 8px #00000014}.metric-clickable{cursor:pointer}.metric-clickable:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626}.metric-header{display:flex;justify-content:space-between;align-items:center}.metric-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.metric-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-good{background-color:#10b981;box-shadow:0 0 0 3px #10b98133}.status-warning{background-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.status-critical{background-color:#ef4444;box-shadow:0 0 0 3px #ef444433}.metric-value-row{display:flex;align-items:baseline;gap:4px}.metric-value{font-size:32px;font-weight:700;color:#111827;line-height:1}.metric-unit{font-size:14px;font-weight:500;color:#6b7280}.metric-footer{display:flex;justify-content:space-between;align-items:center;gap:8px}.metric-trend{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:600}.trend-icon{font-size:16px}.trend-up{color:#10b981}.trend-down{color:#ef4444}.trend-flat{color:#6b7280}.trend-percentage{font-size:13px}.metric-sparkline{width:60px;height:24px;flex-shrink:0}.metric-sparkline svg{width:100%;height:100%}.trend-up+.metric-sparkline{color:#10b981}.trend-down+.metric-sparkline{color:#ef4444}.trend-flat+.metric-sparkline{color:#6b7280}.metric-skeleton{pointer-events:none}.skeleton-line{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}.skeleton-label{height:12px;width:60%}.skeleton-value{height:32px;width:80%;margin:8px 0}.skeleton-trend{height:14px;width:40%}@media (max-width: 768px){.executive-summary-card{padding:16px}.summary-title{font-size:16px;margin-bottom:16px}.metrics-grid{gap:12px}.metric-display{padding:12px;gap:10px}.metric-value{font-size:28px}.metric-label{font-size:11px}.metric-sparkline{width:50px;height:20px}}@media (max-width: 480px){.metric-value{font-size:24px}.metric-unit,.metric-trend{font-size:12px}.trend-icon{font-size:14px}.metric-sparkline{width:40px;height:18px}}.metric-clickable:focus{outline:2px solid #3b82f6;outline-offset:2px}.metric-clickable:focus:not(:focus-visible){outline:none}@keyframes metric-update{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.metric-value{animation:metric-update .3s ease-out}.forecast-chart-card{background:var(--color-background, #ffffff);border:1px solid var(--color-neutral-200, #e5e7eb);border-radius:8px;padding:var(--card-padding, 20px);margin-bottom:var(--section-gap, 24px)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.chart-tabs{display:flex;gap:8px;border-bottom:2px solid var(--color-neutral-200, #e5e7eb)}.tab-button{background:none;border:none;padding:12px 20px;font-size:14px;font-weight:500;color:var(--color-neutral-600, #6b7280);cursor:pointer;position:relative;transition:all .2s ease;border-bottom:2px solid transparent;margin-bottom:-2px}.tab-button:hover{color:var(--color-neutral-900, #111827);background-color:var(--color-neutral-50, #f9fafb)}.tab-button.active{color:var(--color-primary, #3b82f6);font-weight:600;border-bottom-color:var(--color-primary, #3b82f6)}.tab-button:focus{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.chart-controls{display:flex;align-items:center;gap:12px}.time-range-selector{display:flex;gap:4px;background:var(--color-neutral-100, #f3f4f6);border-radius:6px;padding:4px}.range-button{background:transparent;border:none;padding:8px 16px;font-size:13px;font-weight:500;color:var(--color-neutral-600, #6b7280);cursor:pointer;border-radius:4px;transition:all .2s ease;white-space:nowrap}.range-button:hover{background:var(--color-neutral-200, #e5e7eb);color:var(--color-neutral-900, #111827)}.range-button.active{background:var(--color-background, #ffffff);color:var(--color-primary, #3b82f6);font-weight:600;box-shadow:0 1px 2px #0000000d}.range-button:focus{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.export-dropdown{position:relative}.export-button{display:flex;align-items:center;gap:6px;background:var(--color-background, #ffffff);border:1px solid var(--color-neutral-200, #e5e7eb);padding:8px 16px;font-size:13px;font-weight:500;color:var(--color-neutral-700, #374151);cursor:pointer;border-radius:6px;transition:all .2s ease}.export-button:hover{background:var(--color-neutral-50, #f9fafb);border-color:var(--color-neutral-300, #d1d5db)}.export-button:focus{outline:2px solid var(--color-primary, #3b82f6);outline-offset:2px}.export-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--color-background, #ffffff);border:1px solid var(--color-neutral-200, #e5e7eb);border-radius:6px;box-shadow:0 4px 6px #0000001a;min-width:150px;z-index:10;overflow:hidden}.export-menu button{display:block;width:100%;background:none;border:none;padding:10px 16px;font-size:14px;color:var(--color-neutral-700, #374151);text-align:left;cursor:pointer;transition:background .2s ease}.export-menu button:hover{background:var(--color-neutral-50, #f9fafb)}.chart-title{margin-bottom:16px}.chart-title h3{font-size:16px;font-weight:600;color:var(--color-neutral-900, #111827);margin:0}.chart-container{width:100%;min-height:400px;position:relative}.chart-container.empty{display:flex;align-items:center;justify-content:center;background:var(--color-neutral-50, #f9fafb);border-radius:8px;padding:40px 20px}.empty-state{text-align:center;max-width:400px}.empty-state svg{margin-bottom:16px}.empty-state h3{font-size:18px;font-weight:600;color:var(--color-neutral-900, #111827);margin:0 0 8px}.empty-state p{font-size:14px;color:var(--color-neutral-600, #6b7280);margin:4px 0}.empty-hint{font-size:13px;color:var(--color-neutral-500, #9ca3af);font-style:italic}.chart-footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-neutral-200, #e5e7eb)}.chart-metadata{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--color-neutral-600, #6b7280)}.metadata-item{display:flex;align-items:center;gap:4px}.metadata-item strong{color:var(--color-neutral-900, #111827);font-weight:600}.metadata-separator{color:var(--color-neutral-400, #9ca3af)}.forecast-tooltip{background:var(--color-background, #ffffff);border:1px solid var(--color-neutral-200, #e5e7eb);border-radius:6px;padding:12px;box-shadow:0 4px 6px #0000001a;min-width:180px}.tooltip-date{font-size:13px;font-weight:600;color:var(--color-neutral-900, #111827);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--color-neutral-200, #e5e7eb)}.tooltip-entry{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:4px 0;font-size:13px}.tooltip-label{font-weight:500}.tooltip-value{font-weight:600;color:var(--color-neutral-900, #111827)}.tooltip-confidence{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-neutral-200, #e5e7eb)}.tooltip-confidence .tooltip-entry{font-size:12px;color:var(--color-neutral-600, #6b7280)}.forecast-chart-card .skeleton{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-line{background:var(--color-neutral-200, #e5e7eb);border-radius:4px;margin:8px 0}.chart-tabs.skeleton{display:flex;gap:8px}.chart-container.skeleton{background:var(--color-neutral-50, #f9fafb);border-radius:8px;display:flex;align-items:center;justify-content:center}@media (max-width: 1024px){.chart-header{flex-direction:column;align-items:flex-start}.chart-controls{width:100%;justify-content:space-between}.chart-container{min-height:350px}}@media (max-width: 768px){.forecast-chart-card{padding:16px}.chart-header{margin-bottom:16px}.chart-tabs{width:100%;justify-content:space-between}.tab-button{padding:10px 12px;font-size:13px;flex:1;text-align:center}.chart-controls{flex-direction:column;align-items:stretch;gap:8px}.time-range-selector{width:100%;justify-content:space-between}.range-button{flex:1;padding:10px 12px;font-size:12px}.export-button{width:100%;justify-content:center}.chart-title h3{font-size:14px}.chart-container{min-height:300px}.chart-metadata{flex-direction:column;align-items:flex-start;gap:8px}.metadata-separator{display:none}.forecast-tooltip{font-size:12px;padding:10px;min-width:160px}.tooltip-date,.tooltip-entry{font-size:12px}.tooltip-confidence .tooltip-entry{font-size:11px}}@media (max-width: 768px){.tab-button,.range-button,.export-button{min-height:48px;min-width:48px}}@media (max-width: 480px){.forecast-chart-card{padding:12px}.tab-button{padding:8px;font-size:12px}.range-button{padding:8px 10px;font-size:11px}.chart-container{min-height:280px}}.skeleton-card{background:var(--color-background, #ffffff);border:1px solid var(--color-neutral-200, #e5e7eb);border-radius:8px;padding:var(--card-padding, 20px)}.skeleton-line{background:linear-gradient(90deg,#f3f4f6,#e5e7eb,#f3f4f6);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.metric-skeleton{background:transparent;border:1px solid #f3f4f6;padding:16px;border-radius:8px}.metric-skeleton .skeleton-label,.metric-skeleton .skeleton-value{margin-bottom:8px}.insight-card.skeleton{padding:24px;min-height:200px}.insight-card.skeleton .skeleton-line{margin-bottom:8px}.skeleton-chart{background:#f9fafb;border-radius:8px;overflow:hidden}.skeleton-bar{background:linear-gradient(90deg,#e5e7eb,#d1d5db,#e5e7eb);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:2px 2px 0 0}.action-skeleton{display:flex;flex-direction:column;align-items:center;text-align:center;padding:20px;background:transparent;border:1px solid #f3f4f6}.action-skeleton .skeleton-icon{margin-bottom:12px}@media (prefers-reduced-motion: reduce){.skeleton-line,.skeleton-bar{animation:none;background:#f3f4f6}}.skeleton-overlay{position:relative;pointer-events:none;opacity:.6}.skeleton-title{height:24px;margin-bottom:16px}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-button{height:40px;border-radius:8px}:root{--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #dbeafe;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-neutral-900: #111827;--color-neutral-600: #6b7280;--color-neutral-400: #9ca3af;--color-neutral-200: #e5e7eb;--color-neutral-100: #f3f4f6;--color-neutral-50: #f9fafb;--color-background: var(--card-bg);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 32px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--section-gap: var(--space-6);--card-padding: var(--space-5);--element-gap: var(--space-3);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-base: .3s ease-in-out;--transition-slow: .5s ease-in-out;--ease-out-cubic: cubic-bezier(.33, 1, .68, 1);--ease-in-out-cubic: cubic-bezier(.65, 0, .35, 1)}.ai-dashboard-page{padding:var(--section-gap);max-width:1400px;margin:0 auto;background:var(--card-bg);min-height:100vh;font-family:var(--font-sans);display:flex;flex-direction:column;gap:var(--section-gap)}.toast-container{position:fixed;top:var(--section-gap);right:var(--section-gap);z-index:9999;display:flex;flex-direction:column;gap:var(--element-gap);max-width:400px;pointer-events:none}.toast{background:var(--color-background);padding:var(--card-padding);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--element-gap);font-size:var(--text-sm);animation:slideIn var(--transition-base);border-left:4px solid var(--color-primary);pointer-events:auto;color:var(--color-neutral-900)}.toast-info{border-left-color:var(--color-primary)}.toast-success{border-left-color:var(--color-success)}.toast-warning{border-left-color:var(--color-warning)}.toast-error{border-left-color:#ef4444}.toast-close{background:none;border:none;cursor:pointer;padding:var(--space-1);display:flex;align-items:center;justify-content:center;color:var(--color-neutral-600);transition:color var(--transition-fast);flex-shrink:0}.toast-close:hover{color:var(--color-neutral-900)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--section-gap);border-bottom:1px solid var(--color-neutral-200)}.header-content{flex:1}.dashboard-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-neutral-900);margin:0 0 var(--space-2) 0;line-height:1.2}.dashboard-subtitle{font-size:var(--text-base);color:var(--color-neutral-600);margin:0;line-height:1.5}.fiks-avatar-container{width:var(--space-10);height:var(--space-10);overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-fast)}.fiks-avatar-container:hover{transform:scale(1.05)}.fiks-avatar-small{width:var(--space-10);height:var(--space-10);object-fit:contain}.error-card{background:var(--color-background);border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:var(--radius-md);padding:var(--card-padding);text-align:center;box-shadow:var(--shadow-sm);animation:fadeIn var(--transition-base)}.error-card h3{color:#ef4444;font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-2) 0;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.error-card h3:before{content:"⚠️";font-size:var(--text-2xl)}.error-card p{color:var(--color-neutral-600);font-size:var(--text-sm);margin:0 0 var(--space-4) 0;line-height:1.5}.error-card .error-details{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:var(--space-3);margin:var(--space-3) 0;font-size:var(--text-xs);color:var(--color-neutral-600);font-family:var(--font-mono);text-align:left;max-height:100px;overflow-y:auto}.retry-button{background:var(--color-primary);color:var(--color-background);border:none;padding:10px var(--card-padding);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.retry-button:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.retry-button:active{transform:scale(.98)}.retry-button:disabled{background:var(--color-neutral-400);cursor:not-allowed;transform:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dashboard-footer{text-align:center;padding:var(--section-gap) 0;color:var(--color-neutral-400);font-size:var(--text-sm);margin-top:auto}.last-updated{font-style:italic}@media (min-width: 768px) and (max-width: 1024px){.ai-dashboard-page{padding:var(--card-padding)}.dashboard-title{font-size:var(--text-2xl)}}@media (max-width: 768px){.ai-dashboard-page{padding:var(--space-4);gap:var(--space-4)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--space-4);padding-bottom:var(--space-4)}.dashboard-title{font-size:var(--text-2xl)}.dashboard-subtitle{font-size:var(--text-sm)}.fiks-avatar-container{position:absolute;top:var(--space-4);right:var(--space-4)}.toast-container{top:var(--space-4);right:var(--space-4);left:var(--space-4);max-width:none}.toast{font-size:13px;padding:var(--space-3) var(--space-4)}.dashboard-footer{padding:var(--space-4) 0}.retry-button,.toast-close{min-height:48px;min-width:48px}}@media (max-width: 480px){.ai-dashboard-page{padding:var(--element-gap);gap:var(--space-4)}.dashboard-header{padding-bottom:var(--space-3)}.dashboard-title{font-size:var(--text-xl)}.dashboard-subtitle{font-size:13px}.toast{font-size:12px;padding:var(--space-2) var(--space-3)}}@media (min-width: 1024px){.ai-dashboard-page{padding:var(--space-8)}}.notification-page{padding:2rem;max-width:1100px;margin:0 auto}.notification-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.notification-header h1{margin:0;font-size:2rem;color:#111827}.notification-header .muted{margin:.25rem 0 0}.actions{display:flex;gap:.5rem}.ghost{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem .9rem;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;color:#000;cursor:pointer}.ghost:hover{background:#f3f4f6}.ghost:disabled{opacity:.5;cursor:not-allowed}.ghost.danger{color:#000;border-color:#fecdd3}.notification-card{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;background:#fff;box-shadow:0 1px 3px #00000014}.notification-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.badge-row{display:inline-flex;align-items:center;gap:.4rem;font-weight:600}.filters{display:inline-flex;align-items:center;gap:.35rem;color:#6b7280}.notification-list{display:flex;flex-direction:column;max-height:70vh;overflow-y:auto}.notification-item{padding:1rem 1.25rem;border-bottom:1px solid #f3f4f6;position:relative;transition:background .2s ease}.notification-item.clickable{cursor:pointer}.notification-item:hover{background:#f9fafb}.notification-item.clickable:hover{background:#eff6ff}.notification-item.unread{background:#f8fafc}.notification-item.read{opacity:.9}.item-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.nav-icon{color:#3b82f6;flex-shrink:0}.timestamp{color:#6b7280;font-size:.9rem}.item-body h3{margin:.35rem 0 .2rem;color:#111827}.item-body p{margin:0;color:#4b5563}.pill{padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;background:#e5e7eb;color:#111827}.pill-pipeline{background:#e0f2fe;color:#075985}.pill-callList{background:#ffedd5;color:#9a3412}.pill-workList{background:#fef9c3;color:#854d0e}.pill-signature{background:#dcfce7;color:#166534}.pill-memoryPoint{background:#f3e8ff;color:#6b21a8}.pill-deviation{background:#fee2e2;color:#b91c1c}.pill-review{background:#e0e7ff;color:#3730a3}.pill-contractor{background:#cffafe;color:#0e7490}.pill-summaryWeekly{background:#ecfccb;color:#3f6212}.pill-summaryMonthly{background:#dbeafe;color:#1d4ed8}.pill-summaryYearly{background:#f5d0fe;color:#a21caf}.pill-aiStrategy{background:#e0e7ff;color:#4338ca}.pill-aiDailyPriorities{background:#fce7f3;color:#9f1239}.dot{position:absolute;top:1.25rem;right:1.25rem;width:10px;height:10px;border-radius:50%;background:#ef4444}.empty-state{text-align:center;padding:2rem;color:#6b7280}.date-section-header{padding:.75rem 1.25rem;background:#f9fafb;font-weight:600;font-size:.875rem;color:#374151;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:1}.chat-page{--chat-primary: #0f172a;--chat-primary-dark: #0b1220;--chat-primary-soft: #eef2f6;--chat-surface: #ffffff;--chat-panel: #f7f8fb;--chat-border: #e5e7eb;--chat-text: #0f172a;--chat-text-secondary: #6b7280;--chat-muted: #9ca3af;display:flex;height:calc(100vh - 60px);background:linear-gradient(180deg,#f8fafc,#fff 22%,#f8fafc);color:var(--chat-text)}.chat-sidebar{width:320px;background:linear-gradient(180deg,#f8fafc,#f5f7fb 45%,#f8fafc);border-right:1px solid #e4e7ec;display:flex;flex-direction:column;padding:6px 0 10px;box-shadow:12px 0 40px #0f172a0f}.conversation-list{display:flex;flex-direction:column;height:100%;gap:4px}.conversation-list-header{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid #e4e7ec;position:sticky;top:0;background:linear-gradient(180deg,#f8fafc,#f5f7fb);z-index:2}.conversation-list-header h2{margin:0;font-size:15px;letter-spacing:.04em;text-transform:uppercase;font-weight:700;color:var(--chat-text)}.new-chat-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;height:auto;border-radius:12px;border:1px solid var(--chat-primary-dark);background:var(--chat-primary);color:#fff;cursor:pointer;line-height:1;font-weight:600;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;box-shadow:0 12px 26px #0f172a26}.new-chat-btn span{font-size:13px}.new-chat-btn:hover{background:var(--chat-primary-dark);box-shadow:0 16px 32px #0f172a33;transform:translateY(-1px)}.new-chat-btn:active{transform:translateY(0)}.conversation-items{flex:1;overflow-y:auto;padding:6px 8px 12px;display:flex;flex-direction:column;gap:4px}.no-conversations{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:32px 20px;text-align:center;color:var(--chat-muted);background:var(--card-bg);border:1px solid #eceff1;border-radius:12px}.no-conversations svg{color:#cfd3da;margin-bottom:16px}.no-conversations button{margin-top:16px;padding:10px 20px;background:var(--chat-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease;box-shadow:0 10px 20px #0f172a1f}.no-conversations button:hover{background:var(--chat-primary-dark);box-shadow:0 2px 6px #00000026}.conversation-item{display:flex;align-items:center;padding:12px 14px;cursor:pointer;border:1px solid transparent;border-radius:12px;transition:background-color .2s,transform .1s ease-in-out,border-color .2s,box-shadow .2s;color:var(--chat-text);background:transparent;gap:12px}.conversation-item:hover{background-color:var(--card-bg);border-color:#e5e7eb;box-shadow:0 10px 18px #0f172a0a;transform:translateY(-1px)}.conversation-item.active{background:var(--chat-primary);border-color:var(--chat-primary);box-shadow:0 16px 30px #0f172a29;color:#fff}.conversation-item.unread{background:#f0f4f8;font-weight:600;border-color:#e2e8f0}.conv-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#111827,#1f2937);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0;box-shadow:0 10px 18px #0f172a14}.conv-avatar img{width:100%;height:100%;object-fit:contain;border-radius:50%}.conv-avatar:has(img){background:transparent}.conv-info{flex:1;min-width:0}.conv-name{font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px;color:var(--chat-text)}.unread-badge{background:#111827;color:#fff;font-size:11px;padding:3px 7px;border-radius:999px;font-weight:700}.conv-preview{font-size:12px;color:var(--chat-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px;letter-spacing:.01em}.conversation-item.active .conv-name,.conversation-item.active .conv-preview{color:#fff}.conversation-item.active .conv-avatar{background:var(--card-bg);color:var(--chat-primary);box-shadow:none}.conversation-item.active .unread-badge{background:var(--card-bg);color:var(--chat-primary)}.chat-main{flex:1;display:flex;flex-direction:column;background:var(--chat-surface)}.chat-header{display:flex;align-items:center;padding:14px 18px;border-bottom:1px solid #e5e7eb;background:var(--card-bg);box-shadow:0 8px 24px #0f172a0a}.back-btn{background:none;border:none;padding:4px;cursor:pointer;margin-right:8px;display:none!important}.mobile-only{display:none!important}.chat-header-info{flex:1}.chat-title{font-weight:700;font-size:17px;display:flex;align-items:center;gap:8px;color:var(--chat-text);letter-spacing:-.01em}.chat-participants{font-size:12px;color:var(--chat-muted);margin-top:4px}.message-list{flex:1;overflow-y:auto;padding:24px 28px 32px;display:flex;flex-direction:column;gap:12px;background:var(--card-bg)}.load-more-btn{background:#f8fafc;border:1px solid #e5e7eb;padding:9px 18px;border-radius:999px;cursor:pointer;color:var(--chat-text);margin:0 auto 14px;font-size:13px;font-weight:700;transition:all .2s ease;box-shadow:0 8px 18px #0f172a14}.load-more-btn:hover{background:var(--card-bg);border-color:var(--chat-primary);color:var(--chat-primary);transform:translateY(-1px)}.date-divider{display:flex;align-items:center;justify-content:center;margin:18px 0 10px}.date-divider span{background:#f1f5f9;border:1px solid #e5e7eb;padding:5px 14px;border-radius:999px;font-size:12px;color:var(--chat-muted);font-weight:700;letter-spacing:.02em;text-transform:uppercase}.message{max-width:68%;display:flex;flex-direction:column;gap:6px}.message.own{align-self:flex-end;align-items:flex-end}.message.other{align-self:flex-start;align-items:flex-start}.message-sender{font-size:11px;font-weight:700;margin-bottom:2px;color:var(--chat-muted);letter-spacing:.02em;text-transform:uppercase}.message-content{word-wrap:break-word;line-height:1.5;padding:12px 16px;border-radius:14px;background:#f8fafc;color:var(--chat-text);border:1px solid #e5e7eb;box-shadow:0 12px 28px #0f172a14}.message.own .message-content{background:var(--chat-primary);color:#fff;border:1px solid var(--chat-primary-dark);box-shadow:0 12px 28px #0f172a1f}.message.other .message-content{background:#f8fafc}.project-reference{display:inline-flex;align-items:center;gap:6px;background:var(--card-bg);padding:4px 12px;border-radius:999px;font-weight:700;margin:0 4px;text-decoration:none;color:var(--chat-primary);border:1px solid #d1d5db;cursor:pointer;box-shadow:none;transition:all .2s ease;pointer-events:auto;position:relative;z-index:1;font-size:.875rem;line-height:1}.project-reference:hover{background:var(--chat-primary);color:#fff;border-color:var(--chat-primary);transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.project-reference:active{transform:translateY(0);box-shadow:0 1px 3px #667eea33}.message.own .project-reference{background:#ffffff24;color:#fff;border-color:#fff3}.message.own .project-reference:hover{background:var(--card-bg);color:var(--chat-primary);border-color:#fff}.message.other .project-reference{background:var(--card-bg);color:var(--chat-primary);border-color:var(--chat-border)}.message-time{display:block;font-size:11px;letter-spacing:.01em;margin:2px 0 0;color:var(--chat-muted)}.message.own .message-time{color:#ffffffb3;align-self:flex-end}.message.other .message-time{color:var(--chat-text-secondary)}.chat-input-container{position:relative;border-top:1px solid #e5e7eb;background:linear-gradient(180deg,#f8fafc,#f4f6f9);box-shadow:0 -12px 28px #0f172a14}.chat-input{display:flex;align-items:center;padding:14px 16px;gap:12px}.chat-input input{flex:1;padding:12px 16px;border:1px solid #d9dde3;border-radius:14px;font-size:14px;outline:none;background:var(--card-bg);color:var(--chat-text);box-shadow:inset 0 1px #fffc,0 10px 26px #0f172a0f}.chat-input input:focus{border-color:var(--chat-primary);box-shadow:0 0 0 3px #0f172a1f}.chat-input button{width:44px;height:44px;border-radius:12px;border:1px solid var(--chat-primary-dark);background:var(--chat-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 12px 22px #0f172a29}.chat-input button:hover:not(:disabled){background:var(--chat-primary-dark);box-shadow:0 14px 26px #0f172a2e;transform:translateY(-1px)}.chat-input button:disabled{background:#d1d5db;cursor:not-allowed;box-shadow:none}.project-picker{position:absolute;bottom:100%;left:16px;right:16px;background:var(--card-bg);border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 18px 32px #0f172a29;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.project-picker-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--chat-border);background:#f8fafc;font-weight:700;color:var(--chat-text)}.project-picker-header button{background:none;border:none;cursor:pointer;padding:4px;color:var(--chat-text-secondary);transition:color .2s ease}.project-picker-header button:hover{color:var(--chat-text)}.project-picker-results{overflow-y:auto;max-height:240px;background:var(--card-bg)}.project-result{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--chat-border);color:var(--chat-text)}.project-result:hover{background:#f9fafb}.project-nr{font-weight:600;color:var(--chat-primary)}.project-details{font-size:13px;color:var(--chat-muted);margin-top:4px}.project-details .address{display:block;font-style:italic}.loading,.no-results{padding:24px;text-align:center;color:var(--chat-text-secondary)}.no-chat-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--chat-text-secondary);text-align:center;background:linear-gradient(180deg,#f8fafc,#fff 60%,#f8fafc);border:1px solid #eef1f5;border-radius:16px;margin:24px;box-shadow:0 20px 40px #0f172a14}.no-chat-selected svg{color:#d1d5db;margin-bottom:16px}.no-chat-selected h3{margin:0 0 8px;color:var(--chat-text)}.no-chat-selected p{margin:0 0 24px;color:var(--chat-text-secondary)}.no-chat-selected button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--chat-primary);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;box-shadow:0 12px 22px #0f172a29}.no-chat-selected button:hover{background:var(--chat-primary-dark);box-shadow:0 2px 6px #00000026}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--card-bg);border-radius:16px;border:1px solid #e5e7eb;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;margin:16px;box-shadow:0 24px 48px #0f172a2e}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e5e7eb;font-weight:700}.modal-header h3{margin:0}.modal-header button{background:none;border:none;cursor:pointer;padding:4px;color:#666}.modal-body{flex:1;overflow-y:auto;padding:16px}.search-users{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:16px;background:#f8fafc}.search-users input{flex:1;border:none;outline:none;font-size:14px}.user-list{display:flex;flex-direction:column;gap:4px}.user-item{display:flex;align-items:center;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background-color .2s,border-color .2s,transform .15s ease;border:1px solid transparent}.user-item:hover{background:#f1f5f9;border-color:#e5e7eb;transform:translateY(-1px)}.user-item.selected{background:var(--chat-primary);border-color:var(--chat-primary);box-shadow:0 10px 20px #0f172a24}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#111827,#1f2937);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;margin-right:12px}.user-name{flex:1;font-weight:600}.user-role{font-size:12px;color:#4b5563;background:#eef2f6;padding:2px 8px;border-radius:999px}.user-item.selected .user-name,.user-item.selected .user-role{color:#fff}.user-item.selected .user-role{background:#ffffff24}.group-options{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.group-options label{display:block;font-size:13px;font-weight:500;color:#666;margin-bottom:8px}.group-options input[type=text]{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px;border-top:1px solid #e5e7eb}.btn-secondary{padding:10px 20px;background:var(--card-bg);color:var(--chat-text);border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.btn-secondary:hover{background:#f9fafb;border-color:var(--chat-primary);color:var(--chat-primary)}.btn-primary{padding:10px 20px;background:var(--chat-primary);color:#fff;border:1px solid var(--chat-primary-dark);border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;box-shadow:0 10px 22px #0f172a24}.btn-primary:hover:not(:disabled){background:var(--chat-primary-dark);box-shadow:0 12px 26px #0f172a2e}.btn-primary:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed}@media (max-width: 768px){.chat-sidebar{position:absolute;left:0;top:0;bottom:0;width:100%;z-index:10;display:none}.chat-sidebar.mobile-visible{display:flex}.chat-main{display:none}.chat-main.mobile-visible{display:flex}.back-btn,.mobile-only{display:block!important}.message{max-width:85%}.no-chat-selected{margin:12px}}.ai-chat-page{display:flex;flex-direction:column;height:calc(100vh - 60px);background:linear-gradient(135deg,#f5f7fa,#e8ecf1);overflow:hidden}.ai-chat-header{background:var(--card-bg);padding:24px 32px;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.ai-chat-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}.ai-chat-title h1{margin:0;font-size:28px;font-weight:600;color:#1f2937}.ai-icon{color:#6b7280;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.ai-chat-subtitle{margin:0;font-size:14px;color:#6b7280}.ai-chat-container{flex:1;display:flex;flex-direction:column;max-width:1200px;width:100%;margin:0 auto;padding:24px;overflow:hidden}.ai-chat-container :global(.chatkit-container){height:100%;border-radius:16px;box-shadow:0 4px 6px #00000012,0 10px 20px #0000000d;background:var(--card-bg);overflow:hidden}.ai-chat-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 60px);gap:16px;color:#6b7280}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-chat-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100vh - 60px);gap:16px;color:#ef4444}.ai-chat-error button{padding:10px 20px;background:#6b7280;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:background-color .2s}.ai-chat-error button:hover{background:#4b5563}@media (max-width: 768px){.ai-chat-header{padding:16px 20px}.ai-chat-title h1{font-size:22px}.ai-chat-container{padding:16px}.ai-chat-container :global(.chatkit-container){border-radius:12px}}@media (prefers-color-scheme: dark){.ai-chat-page{background:linear-gradient(135deg,#1f2937,#111827)}.ai-chat-header{background:#1f2937;border-bottom-color:#374151}.ai-chat-title h1{color:#f9fafb}.ai-chat-subtitle{color:#9ca3af}.ai-chat-container :global(.chatkit-container){background:#1f2937}}.handover-request-card{background:var(--card-bg);border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:1rem;transition:box-shadow .2s}.handover-request-card:hover{box-shadow:0 4px 6px -1px #0000001a}.handover-request-card.pending{border-left:4px solid #f59e0b}.handover-request-card.accepted{border-left:4px solid #10b981}.handover-request-card.rejected{border-left:4px solid #ef4444}.handover-card-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.handover-icon{flex-shrink:0;width:40px;height:40px;background:#eff6ff;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#3b82f6}.handover-info{flex:1;min-width:0}.project-title{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:#111827}.handover-details{margin:0 0 .25rem;font-size:.875rem;color:#6b7280}.handover-details strong{color:#374151}.handover-date{margin:0;font-size:.75rem;color:#9ca3af}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;white-space:nowrap}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.accepted{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fee2e2;color:#991b1b}.project-details{background:#f9fafb;border-radius:.375rem;padding:.75rem;margin-bottom:1rem}.project-details p{margin:.25rem 0;font-size:.875rem;color:#374151}.project-details strong{color:#111827}.handover-actions{display:flex;gap:.5rem;flex-wrap:wrap}.handover-actions button{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.view-project-button{background:var(--card-bg);color:#3b82f6;border:1px solid #3b82f6}.view-project-button:hover:not(:disabled){background:#eff6ff}.accept-button{background:#10b981;color:#fff}.accept-button:hover:not(:disabled){background:#059669}.reject-button{background:#ef4444;color:#fff}.reject-button:hover:not(:disabled){background:#dc2626}.cancel-button{background:#6b7280;color:#fff}.cancel-button:hover:not(:disabled){background:#4b5563}.handover-actions button:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:.75rem;background:#fee2e2;border:1px solid #fecaca;border-radius:.375rem;color:#991b1b;font-size:.875rem;margin-bottom:1rem}.my-day-page-new{padding:2rem;max-width:1600px;margin:0 auto}.my-day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.my-day-header h1{margin:0 0 .5rem;font-size:2rem;color:#111827}.welcome-text{margin:0;color:#6b7280;font-size:1rem}.header-date{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.widgets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.widget{background:var(--card-bg);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.widget-header h3{margin:0;font-size:1rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem}.add-task-btn{background:#3b82f6;color:#fff;border:none;border-radius:.375rem;padding:.375rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.add-task-btn:hover{background:#2563eb}.view-all-btn{background:none;border:none;color:#3b82f6;font-size:.875rem;cursor:pointer;transition:color .2s}.view-all-btn:hover{color:#2563eb}.tasks-list{max-height:400px;overflow-y:auto}.task-item{display:flex;align-items:center;gap:.75rem;padding:.75rem .5rem;border-radius:.5rem;margin-bottom:.5rem;transition:all .2s ease;position:relative}.task-item:hover{background:#f9fafb;padding-left:.75rem}.task-item.completed{opacity:.5}.task-item.completed .task-description{text-decoration:line-through}.task-checkbox{background:none;border:none;color:#3b82f6;cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0;transition:transform .15s ease}.task-checkbox:hover{color:#2563eb;transform:scale(1.1)}.task-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.task-description{font-size:.875rem;color:#111827;line-height:1.4;word-break:break-word}.task-due-date{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:#6b7280}.task-actions{display:flex;align-items:center;gap:.25rem;opacity:0;transition:opacity .2s ease;margin-left:.5rem}.task-item:hover .task-actions{opacity:1}.task-project-link,.task-edit,.task-delete{background:none;border:none;cursor:pointer;padding:.375rem;border-radius:.375rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.task-project-link{color:#3b82f6}.task-project-link:hover{background-color:#dbeafe;color:#2563eb}.task-edit{color:#6b7280}.task-edit:hover{background-color:#f3f4f6;color:#111827}.task-delete{color:#ef4444}.task-delete:hover{background:#fee2e2;color:#dc2626}.widget-list{max-height:350px;overflow-y:auto}.widget-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:.375rem;margin-bottom:.5rem;cursor:pointer;transition:background .2s;border:1px solid #f3f4f6}.widget-list-item:hover{background:#f9fafb;border-color:#e5e7eb}.widget-list-item strong{display:block;font-size:.875rem;color:#111827;margin-bottom:.25rem}.widget-list-item p{margin:0;font-size:.75rem;color:#6b7280}.age-badge,.source-badge{padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;white-space:nowrap}.age-badge{background:#fef3c7;color:#92400e}.source-badge{color:#fff}.empty-state{text-align:center;color:#9ca3af;font-size:.875rem;padding:2rem 1rem}.handover-section{margin-bottom:2rem}.handover-group{margin-bottom:1.5rem}.handover-group h3{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.125rem;color:#111827}.responsible-projects-section{background:var(--card-bg);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.section-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#111827;display:flex;align-items:center;gap:.5rem}.section-filters{display:flex;gap:1rem;align-items:center}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:var(--card-bg);cursor:pointer}.search-input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;min-width:200px}.projects-table-container{overflow-x:auto}.projects-table td{padding:1rem;font-size:.875rem;color:#111827;border-bottom:1px solid #f3f4f6;vertical-align:middle}.project-nr{font-weight:600;color:#3b82f6}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;white-space:nowrap}.pill-select{padding:.35rem .75rem;border-radius:999px;border:1px solid #d1d5db;background:#f9fafb;font-size:.85rem}.followup-input input[type=date]{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:.375rem}.clear-followup{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid #e5e7eb;background:#fff;border-radius:999px;cursor:pointer}.clear-followup:hover{background:#f3f4f6}.view-project-btn{background:#3b82f6;color:#fff;border:none;border-radius:.375rem;padding:.375rem .75rem;font-size:.875rem;cursor:pointer;transition:background .2s}.view-project-btn:hover{background:#2563eb}.loading,.error-message{text-align:center;padding:3rem;font-size:1rem;color:#6b7280}.error-message{color:#ef4444;background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem}@media (max-width: 1024px){.widgets-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width: 768px){.my-day-page-new{padding:1rem}.my-day-header{flex-direction:column;align-items:flex-start;gap:1rem}.widgets-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start}.section-filters{width:100%;flex-direction:column}.search-input{width:100%}.projects-table-container{overflow-x:scroll}.projects-table{min-width:800px}}.leads-page{padding:2rem;max-width:1600px;margin:0 auto}.leads-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.leads-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.leads-subtitle{color:#666;font-size:1rem}.leads-stats{display:flex;gap:1rem}.stat-card{background:var(--card-bg);padding:1rem 1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center;min-width:100px}.stat-value{font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.leads-loading,.leads-error{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.leads-error{color:#d32f2f}.leads-filters{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9375rem;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#667eea}.filter-select{padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:8px;font-size:.9375rem;background:var(--card-bg);cursor:pointer;transition:border-color .2s ease}.filter-select:focus{outline:none;border-color:#667eea}.leads-table-container{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.leads-table{width:100%;border-collapse:collapse}.leads-table thead{background:#f8f9fa}.leads-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e0e0e0}.leads-table tbody tr{border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease}.leads-table tbody tr:hover{background-color:#f8f9fa}.leads-table td{padding:1rem;font-size:.9375rem;color:#1a1a1a}.source-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.address-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge.status-mottatt_bud{background:#e8f5e9;color:#388e3c}.responsible-user{color:#1a1a1a;font-weight:500}.unassigned{color:#999;font-style:italic}.view-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.view-btn:hover{background:#5568d3;transform:translateY(-1px)}.no-leads{text-align:center;padding:3rem;color:#999;font-style:italic}@media (max-width: 1200px){.leads-header{flex-direction:column;gap:1.5rem}.leads-stats{width:100%;justify-content:space-between}}@media (max-width: 768px){.leads-page{padding:1rem}.leads-filters{flex-direction:column}.leads-table-container{overflow-x:auto}.leads-table{min-width:800px}.stat-card{min-width:auto;flex:1}}.team-dashboard-page{padding:2rem;max-width:1400px;margin:0 auto}.team-header{margin-bottom:2rem}.back-btn{padding:.5rem 1rem;background:var(--card-bg);color:#667eea;border:2px solid #667eea;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:1rem;display:inline-flex;align-items:center;gap:.5rem}.back-btn:hover{background:#f0f0ff;transform:translate(-2px)}.team-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.toggle-all-btn{padding:.75rem 1.5rem;background:var(--card-bg);color:#667eea;border:2px solid #667eea;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.toggle-all-btn:hover{background:#f0f0ff}.toggle-all-btn.active{background:#667eea;color:#fff}.team-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.team-subtitle{color:#666;font-size:1rem}.team-loading,.team-error{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.team-error{color:#d32f2f}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.team-member-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.team-member-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.team-member-card.hidden-user{opacity:.6;border:2px dashed #999}.hidden-badge{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;background:#ef4444;color:#fff;font-size:.625rem;font-weight:600;text-transform:uppercase;border-radius:4px}.team-member-card{position:relative}.member-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:600;margin-bottom:1rem}.member-info{margin-bottom:1rem}.member-info h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-bottom:.25rem}.member-email{font-size:.875rem;color:#666;margin-bottom:.5rem}.member-role{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.member-role.role-admin{background:#fef3c7;color:#92400e}.member-role.role-user{background:#dbeafe;color:#1e40af}.member-stats{display:flex;gap:2rem;margin-bottom:1rem;padding:1rem 0;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;width:100%;justify-content:center}.stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-icon{font-size:1.5rem}.stat-label{font-size:.75rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.view-day-btn{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s ease;width:100%}.view-day-btn:hover{background:#5568d3}@media (max-width: 768px){.team-dashboard-page{padding:1rem}.team-grid{grid-template-columns:1fr}}.team-member-day-page{padding:2rem;max-width:1400px;margin:0 auto}.team-member-header{margin-bottom:2rem}.back-btn{padding:.5rem 1rem;background:var(--card-bg);border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;margin-bottom:1rem;font-size:.9375rem;transition:background .2s ease}.back-btn:hover{background:#f8f9fa}.team-member-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.25rem}.member-email{color:#666;font-size:.9375rem}.team-member-loading,.team-member-error{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.team-member-error{color:#d32f2f}.team-member-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.widget{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.widget h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.tasks-list,.projects-list{display:flex;flex-direction:column;gap:.75rem}.tasks-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.tasks-add{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.editing-hint{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#fef3c7;color:#92400e;border:1px solid #f59e0b;border-radius:8px;font-size:.9rem}.editing-hint button{background:transparent;border:none;color:#92400e;cursor:pointer;text-decoration:underline}.tasks-add input{padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:6px}.tasks-add button{padding:.45rem .9rem;border:none;background:#667eea;color:#fff;border-radius:6px;cursor:pointer}.task-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8f9fa;border-radius:6px}.task-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.task-item span{flex:1;font-size:.9375rem}.task-item span.completed{text-decoration:line-through;color:#999}.task-edit{display:flex;gap:.5rem;align-items:center;flex:1}.task-edit input{padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:6px}.task-edit-actions{display:flex;gap:.5rem}.edit-btn{padding:.25rem .6rem;background:#e0e7ff;border:none;border-radius:4px;cursor:pointer}.project-link-btn{padding:.25rem .5rem;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer}.due-date{font-size:.8125rem;color:#666;padding:.25rem .5rem;background:var(--card-bg);border-radius:4px}.project-item{padding:1rem;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:background .2s ease}.project-item:hover{background:#e9ecef}.projects-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.projects-filters{display:flex;gap:.75rem;align-items:center}.projects-filters select,.projects-filters input{padding:.5rem .75rem;border:1px solid #e0e0e0;border-radius:6px;font-size:.95rem}.projects-filters input{min-width:220px}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.project-header strong{color:#667eea;font-weight:600}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.status-badge.status-draft{background:#e3f2fd;color:#1976d2}.status-badge.status-anbudsrunde{background:#fff3e0;color:#f57c00}.project-details{display:flex;flex-direction:column;gap:.25rem}.project-customer{font-size:.9375rem;color:#1a1a1a}.project-address{font-size:.875rem;color:#666}.no-items{text-align:center;color:#999;padding:2rem;font-style:italic}.projects-widget-table{grid-column:1 / -1}.projects-table-container{overflow-x:auto;margin-top:1rem}.projects-table{width:100%;border-collapse:collapse}.projects-table thead{background:#f9fafb}.projects-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb}.projects-table td{padding:1rem;font-size:.9375rem;color:#1a1a1a;border-bottom:1px solid #f3f4f6;vertical-align:middle}.projects-table tbody tr{transition:background .2s}.projects-table tbody tr.clickable-row{cursor:pointer}.projects-table tbody tr:hover{background:#f9fafb}.projects-table tbody tr.clickable-row:hover{background:#eff6ff}.project-nr{font-weight:600;color:#667eea}.status-draft{background:#f3f4f6;color:#4b5563}.status-bidding{background:#dbeafe;color:#1e40af}.status-bid-received{background:#fef3c7;color:#92400e}.status-accepted{background:#d1fae5;color:#065f46}.status-starting,.status-finishing{background:#e0e7ff;color:#3730a3}.status-completed,.status-paid{background:#d1fae5;color:#065f46}.status-lost,.status-cancelled{background:#fee2e2;color:#991b1b}.status-default{background:#f3f4f6;color:#6b7280}.pill-select-wrapper{display:inline-flex;align-items:center}.pill-select{padding:.35rem .75rem;border-radius:999px;border:1px solid #d1d5db;background:#f9fafb;font-size:.85rem;cursor:pointer}.pill-select:disabled{opacity:.5;cursor:not-allowed}.followup-input{display:flex;align-items:center;gap:.35rem}.followup-input input[type=date]{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.followup-input input[type=date]:disabled{opacity:.5;cursor:not-allowed}.clear-followup{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid #e5e7eb;background:#fff;border-radius:999px;cursor:pointer;transition:background .2s}.clear-followup:hover:not(:disabled){background:#f3f4f6}.clear-followup:disabled{opacity:.5;cursor:not-allowed}.empty-row{text-align:center;color:#9ca3af;padding:3rem 1rem!important}@media (max-width: 1024px){.team-member-grid{grid-template-columns:1fr}}@media (max-width: 768px){.team-member-day-page{padding:1rem}}.admin-settings-page{padding:2rem;max-width:1400px;margin:0 auto}.admin-header{margin-bottom:3rem}.admin-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.admin-subtitle{color:#666;font-size:1rem}.admin-loading,.admin-error{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.admin-error{color:#d32f2f}.settings-section{background:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.settings-section h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.section-description{color:#666;font-size:.9375rem;margin-bottom:1.5rem}.create-rule-form{display:flex;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.create-rule-form input,.create-rule-form select{flex:1;padding:.75rem;border:1px solid #e0e0e0;border-radius:6px;font-size:.9375rem}.create-rule-form button{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s ease}.create-rule-form button:hover{background:#5568d3}.input-with-icon{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:6px;background:var(--card-bg)}.input-with-icon input,.input-with-icon select{border:none;outline:none;flex:1;background:transparent;font-size:.9375rem}.rules-table-container{overflow-x:auto}.rules-table{width:100%;border-collapse:collapse}.rules-table thead{background:#f8f9fa}.rules-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e0e0e0}.rules-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.rules-table tbody tr:hover{background-color:#f8f9fa}.rules-table td{padding:1rem;font-size:.9375rem;color:#1a1a1a}.customer-type{font-weight:600;color:#667eea}.date-cell{color:#666;font-size:.875rem}.delete-btn{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease}.delete-btn:hover{background:#c82333}.no-rules{text-align:center;padding:2rem;color:#999;font-style:italic}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.user-visibility-card{padding:1.5rem;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600}.user-info h4{font-size:1rem;font-weight:600;color:#1a1a1a;margin-bottom:.25rem}.user-email{font-size:.875rem;color:#666;margin-bottom:.25rem}.user-role{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.user-role.role-admin{background:#fef3c7;color:#92400e}.user-role.role-user{background:#dbeafe;color:#1e40af}.visibility-toggle{display:flex;align-items:center;gap:.75rem;cursor:pointer}.visibility-toggle input[type=checkbox]{display:none}.toggle-slider{position:relative;width:50px;height:26px;background:#ccc;border-radius:13px;transition:background .3s ease}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:var(--card-bg);top:3px;left:3px;transition:transform .3s ease}.visibility-toggle input[type=checkbox]:checked+.toggle-slider{background:#667eea}.visibility-toggle input[type=checkbox]:checked+.toggle-slider:before{transform:translate(24px)}.toggle-label{font-size:.875rem;font-weight:500;color:#666}@media (max-width: 768px){.admin-settings-page{padding:1rem}.create-rule-form{flex-direction:column}.users-grid{grid-template-columns:1fr}.user-visibility-card{flex-direction:column;align-items:flex-start;gap:1rem}}[data-theme=dark] .page,[data-theme=dark] .container,[data-theme=dark] .main-content,[data-theme=dark] .content-wrapper{background:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] .card,[data-theme=dark] .panel,[data-theme=dark] .section,[data-theme=dark] .box,[data-theme=dark] .widget{background:var(--card-bg);border:1px solid rgba(0,212,255,.15);box-shadow:0 0 30px #00d4ff1a,0 4px 15px #0000004d}[data-theme=dark] .card:hover,[data-theme=dark] .panel:hover,[data-theme=dark] .section:hover{border-color:#00d4ff4d;box-shadow:0 0 40px #00d4ff33,0 8px 25px #0006}[data-theme=dark] .header,[data-theme=dark] .page-header,[data-theme=dark] .section-header,[data-theme=dark] .card-header{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 40px #00d4ff26}[data-theme=dark] .title,[data-theme=dark] .heading,[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4,[data-theme=dark] h5,[data-theme=dark] h6{color:var(--text-primary)}[data-theme=dark] .title.main,[data-theme=dark] h1{text-shadow:0 0 30px rgba(0,212,255,.4)}[data-theme=dark] .subtitle,[data-theme=dark] .description,[data-theme=dark] .text-secondary{color:var(--text-secondary)}[data-theme=dark] .text-muted,[data-theme=dark] .meta,[data-theme=dark] .small-text{color:var(--text-muted)}[data-theme=dark] .btn,[data-theme=dark] button:not(.btn-primary):not(.btn-danger):not(.btn-success){background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .btn:hover,[data-theme=dark] button:not(.btn-primary):not(.btn-danger):not(.btn-success):hover{background:#00d4ff33;border-color:var(--accent-color);box-shadow:0 0 25px #00d4ff66;color:var(--accent-color)}[data-theme=dark] .btn-primary,[data-theme=dark] .primary-button{background:var(--gradient-primary);border:none;box-shadow:0 0 30px #00d4ff66}[data-theme=dark] .btn-primary:hover,[data-theme=dark] .primary-button:hover{box-shadow:0 0 40px #00d4ff99}[data-theme=dark] .btn-danger{background:#ff5c5c33;border:1px solid rgba(255,92,92,.3);color:var(--error-color)}[data-theme=dark] .btn-danger:hover{background:#ff5c5c4d;box-shadow:0 0 25px #ff5c5c66}[data-theme=dark] .btn-success{background:#0f83;border:1px solid rgba(0,255,136,.3);color:var(--success-color)}[data-theme=dark] .btn-success:hover{background:#00ff884d;box-shadow:0 0 25px #0f86}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d;background:#0f1419e6}[data-theme=dark] .form-group label,[data-theme=dark] .input-label{color:var(--text-primary)}[data-theme=dark] table,[data-theme=dark] .table,[data-theme=dark] .data-table{background:var(--card-bg);border:1px solid rgba(0,212,255,.15)}[data-theme=dark] th,[data-theme=dark] .table-header,[data-theme=dark] thead{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);color:var(--text-primary);border-bottom:2px solid rgba(0,212,255,.3)}[data-theme=dark] td,[data-theme=dark] .table-cell{color:var(--text-secondary);border-bottom:1px solid rgba(0,212,255,.1)}[data-theme=dark] tr:hover,[data-theme=dark] .table-row:hover{background:#00d4ff0d}[data-theme=dark] .list-item,[data-theme=dark] .item,[data-theme=dark] li{background:#00d4ff0d;border:1px solid rgba(0,212,255,.1)}[data-theme=dark] .badge,[data-theme=dark] .tag,[data-theme=dark] .label{background:var(--gradient-primary);color:#fff;box-shadow:0 0 15px #00d4ff80}[data-theme=dark] .badge.success,[data-theme=dark] .status-success{background:#0f83;color:var(--success-color);border:1px solid rgba(0,255,136,.3)}[data-theme=dark] .badge.error,[data-theme=dark] .badge.danger,[data-theme=dark] .status-error{background:#ff5c5c33;color:var(--error-color);border:1px solid rgba(255,92,92,.3)}[data-theme=dark] .badge.warning,[data-theme=dark] .status-warning{background:#ffb83633;color:var(--warning-color);border:1px solid rgba(255,184,54,.3)}[data-theme=dark] .badge.info,[data-theme=dark] .status-info{background:#00d4ff33;color:var(--info-color);border:1px solid rgba(0,212,255,.3)}[data-theme=dark] .chart-container,[data-theme=dark] .chart-wrapper,[data-theme=dark] .graph-container{background:#0f141980;border:1px solid rgba(0,212,255,.15)}[data-theme=dark] .empty-state,[data-theme=dark] .no-data,[data-theme=dark] .placeholder{color:var(--text-muted)}[data-theme=dark] .loading,[data-theme=dark] .spinner{border-color:#00d4ff33;border-top-color:var(--accent-color)}[data-theme=dark] .tooltip,[data-theme=dark] .popover{background:var(--card-bg);border:1px solid rgba(0,212,255,.3);box-shadow:0 0 30px #00d4ff4d;color:var(--text-primary)}[data-theme=dark] .tab,[data-theme=dark] .nav-tab{color:var(--text-secondary);border-bottom:2px solid transparent}[data-theme=dark] .tab:hover,[data-theme=dark] .nav-tab:hover{color:var(--accent-color);background:#00d4ff0d}[data-theme=dark] .tab.active,[data-theme=dark] .nav-tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color);box-shadow:0 2px 15px #00d4ff4d}[data-theme=dark] .alert,[data-theme=dark] .notification,[data-theme=dark] .toast{background:var(--card-bg);border:1px solid rgba(0,212,255,.2);box-shadow:0 0 25px #00d4ff33}[data-theme=dark] .alert-success{background:#00ff8826;border-color:#00ff884d;color:var(--success-color)}[data-theme=dark] .alert-error,[data-theme=dark] .alert-danger{background:#ff5c5c26;border-color:#ff5c5c4d;color:var(--error-color)}[data-theme=dark] .alert-warning{background:#ffb83626;border-color:#ffb8364d;color:var(--warning-color)}[data-theme=dark] .alert-info{background:#00d4ff26;border-color:#00d4ff4d;color:var(--info-color)}[data-theme=dark] .search-box,[data-theme=dark] .search-input{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);box-shadow:0 0 20px #00d4ff1a}[data-theme=dark] .search-box:focus-within,[data-theme=dark] .search-input:focus{border-color:var(--accent-color);box-shadow:0 0 30px #00d4ff4d}[data-theme=dark] .progress,[data-theme=dark] .progress-bar{background:#00d4ff1a}[data-theme=dark] input[type=checkbox]:checked,[data-theme=dark] input[type=radio]:checked{background:var(--gradient-primary);border-color:var(--accent-color);box-shadow:0 0 10px #00d4ff66}[data-theme=dark] ::-webkit-scrollbar{background:#0f141980}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#00d4ff4d;border:1px solid rgba(0,212,255,.2)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#00d4ff80}.sidebar{display:flex;flex-direction:column;height:100vh;background:var(--card-bg);color:#1a1a1a;border-right:1px solid #e5e5e5;transition:all .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;z-index:1000;box-shadow:var(--shadow-lg);width:15.625rem}.sidebar.open{width:15.625rem}.sidebar.closed{width:3.75rem}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-md);border-bottom:1px solid #e5e5e5;background:var(--card-bg);position:relative;overflow:hidden;min-height:4rem}.sidebar-logo{height:2.5rem;width:auto;max-width:100%;object-fit:contain;padding:.25rem .5rem;background:var(--card-bg);border-radius:8px;box-shadow:0 2px 10px #0000001a;position:relative;z-index:1}.sidebar.closed .sidebar-logo{display:none}.sidebar-toggle{background:#f7fafc;border:1px solid #e2e8f0;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#4a5568;padding:var(--spacing-sm);transition:all .3s ease;position:relative;z-index:1;min-width:2.75rem;min-height:2.75rem}.sidebar-toggle:hover{background:#edf2f7;transform:scale(1.05);box-shadow:0 4px 15px #0000001a;color:#2d3748}.sidebar-content{flex:1 1 auto;overflow-y:auto;min-height:0}.sidebar-main{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.sidebar-section{display:flex;flex-direction:column;padding:var(--spacing-sm) 0}.sidebar-section-header{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-sm);margin:0 var(--spacing-sm);position:relative;overflow:hidden;min-height:2.75rem;color:#ffffffd9}.sidebar-section-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#fff6;opacity:0;transition:opacity .3s ease}.sidebar-section-header:hover{background:#ffffff1f;transform:translate(4px)}.sidebar-section-header:hover:before{opacity:1}.sidebar-section-header span{margin-left:var(--spacing-sm)}.sidebar.closed .sidebar-section-header span{display:none}.sidebar-links{display:flex;flex-direction:column;flex:1;min-height:0}.sidebar-links a{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 2.5rem;color:#4a5568;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-sm);margin:var(--spacing-xs) var(--spacing-sm);position:relative;overflow:hidden;min-height:3rem;flex:1;justify-content:flex-start}.sidebar-links a:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#000;opacity:0;transition:opacity .3s ease}.sidebar-links a:hover{background:#f7fafc;transform:translate(4px);box-shadow:var(--shadow-sm);color:#2d3748}.sidebar-links a:hover:before{opacity:1}.sidebar-links a.active{background:#edf2f7;color:#000;font-weight:600;box-shadow:var(--shadow-md)}.sidebar-links a.active:before{opacity:1;background:#000}.sidebar.closed .sidebar-links{padding-left:0}.sidebar.closed .sidebar-links a{padding:var(--spacing-sm);justify-content:center}.sidebar.closed .sidebar-links a span{display:none}.sidebar-links a span{margin-left:var(--spacing-sm)}.nav-label-row{display:inline-flex;align-items:center;gap:.5rem}.badge{background:#ef4444;color:#fff;border-radius:999px;padding:.1rem .45rem;font-size:.75rem;font-weight:700;line-height:1.2}.section-label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs)}.sidebar.closed .section-label{display:none}.sidebar-footer{flex-shrink:0;position:relative;z-index:2;background:#f7fafc;border-top:1px solid #e2e8f0;padding:var(--spacing-sm)}.user-info{display:flex;align-items:center;padding:var(--spacing-sm);background:#edf2f7;border-radius:var(--radius-sm);margin-bottom:var(--spacing-sm);text-decoration:none;color:#2d3748;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.user-info:hover{background:#e2e8f0;transform:translateY(-1px)}.user-info.active{background:#000;color:#fff}.user-info.active .user-role{color:#fffc}.user-avatar{width:2rem;height:2rem;border-radius:50%;background:#000;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:var(--spacing-sm);flex-shrink:0}.user-details{min-width:0;flex:1}.settings-icon{margin-left:var(--spacing-sm);opacity:.6;transition:opacity .3s ease}.user-info:hover .settings-icon{opacity:1}.sidebar.closed .settings-icon{display:none}.user-name{font-weight:600;color:#1a202c;font-size:var(--font-sm);margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--font-xs);color:#1a202c;text-transform:capitalize;font-weight:600}.sidebar.closed .user-info{flex-direction:column;padding:var(--spacing-sm)}.sidebar.closed .user-avatar{margin-right:0;margin-bottom:var(--spacing-xs)}.sidebar.closed .user-details{display:none}.sidebar-actions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-actions a,.logout-button{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-sm);color:#ffffffe0;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-sm);border:none;background:none;cursor:pointer;font-size:var(--font-sm);width:100%;text-align:left;min-height:2.75rem}.sidebar-actions a:hover,.logout-button:hover{background:#ffffff29;transform:translate(2px)}.logout-button{color:#e53e3e;font-weight:600}.logout-button:hover{background:#fed7d7;color:#c53030}.sidebar-actions a span,.logout-button span{margin-left:var(--spacing-sm)}.sidebar.closed .sidebar-actions a,.sidebar.closed .logout-button{justify-content:center;padding:var(--spacing-sm)}.sidebar.closed .sidebar-actions a span,.sidebar.closed .logout-button span{display:none}.content-with-sidebar{margin-left:15.625rem;transition:margin-left .3s ease}.sidebar-overlay,.sidebar-overlay.active{display:none}.mobile-menu-button{display:none;position:fixed;top:var(--spacing-md);left:var(--spacing-md);z-index:1001;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);padding:var(--spacing-sm);cursor:pointer;box-shadow:var(--shadow-md);transition:all .3s ease;min-width:2.75rem;min-height:2.75rem}.mobile-menu-button:hover{background:var(--primary-hover);transform:scale(1.05)}@media (max-width: 768px){.mobile-menu-button{display:flex;align-items:center;justify-content:center}.sidebar{transform:translate(-100%);transition:transform .3s ease;z-index:1000;width:15.625rem!important}.sidebar.open{transform:translate(0)}.sidebar.closed{transform:translate(-100%);width:15.625rem!important}.sidebar.closed .sidebar-header h1,.sidebar.closed .sidebar-section-header span,.sidebar.closed .sidebar-links a span,.sidebar.closed .section-label,.sidebar.closed .user-details,.sidebar.closed .settings-icon,.sidebar.closed .sidebar-actions a span,.sidebar.closed .logout-button span{display:block!important}.sidebar.closed .sidebar-links a{padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 2.5rem!important;justify-content:flex-start!important}.sidebar.closed .sidebar-actions a,.sidebar.closed .logout-button{justify-content:flex-start!important;padding:var(--spacing-sm) var(--spacing-sm)!important}.sidebar.closed .user-info{flex-direction:row!important;padding:var(--spacing-sm)!important}.sidebar.closed .user-avatar{margin-right:var(--spacing-sm)!important;margin-bottom:0!important}.content-with-sidebar{margin-left:0!important;width:100%!important;transition:none}.content-with-sidebar.sidebar-closed{margin-left:0!important;width:100%!important}.sidebar-header .sidebar-toggle{display:none}.sidebar-header{padding:var(--spacing-md);justify-content:center}.sidebar-section-header,.sidebar-links a,.sidebar-actions a,.logout-button{min-height:3rem}.user-avatar{width:2.5rem;height:2.5rem}}@media (min-width: 769px) and (max-width: 1024px){.sidebar.open{width:15rem}.content-with-sidebar{margin-left:15rem}.content-with-sidebar.sidebar-closed{margin-left:3.5rem}.sidebar.closed{width:3.5rem}}@media (min-width: 1400px){.sidebar.open{width:17rem}.content-with-sidebar{margin-left:17rem}}.sidebar.has-admin-links .sidebar-links a{min-height:2.5rem}.section-label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs)}.sidebar-quick-actions{display:flex;justify-content:center;gap:1rem;padding:.75rem;border-bottom:1px solid #e5e5e5;background:#fafafa}.quick-action-btn{position:relative;display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;border-radius:50%;background:var(--card-bg);color:#4a5568;border:1px solid #e2e8f0;cursor:pointer;transition:all .2s ease;text-decoration:none}.quick-action-btn:hover{background:#edf2f7;transform:scale(1.05);box-shadow:0 2px 8px #0000001a}.quick-action-btn.active{background:#000;color:#fff;border-color:#000}.quick-action-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;border:2px solid white}.sidebar.closed .sidebar-quick-actions{flex-direction:column;padding:.5rem;gap:.5rem}.sidebar.closed .quick-action-btn{width:2.25rem;height:2.25rem}[data-theme=dark] .sidebar{background:var(--card-bg);border-right:1px solid rgba(0,212,255,.1);box-shadow:2px 0 20px #00d4ff0d}[data-theme=dark] .sidebar-header{border-bottom:1px solid rgba(0,212,255,.15);background:linear-gradient(135deg,#0f1419f2,#1a1f29f2)}[data-theme=dark] .sidebar-logo{background:#00d4ff0d;box-shadow:0 0 20px #00d4ff33,0 0 40px #7c3aed1a;animation:aiGlow 3s ease-in-out infinite}@keyframes aiGlow{0%,to{box-shadow:0 0 20px #00d4ff33,0 0 40px #7c3aed1a}50%{box-shadow:0 0 30px #00d4ff66,0 0 60px #7c3aed33}}[data-theme=dark] .sidebar-toggle{background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);color:var(--accent-color)}[data-theme=dark] .sidebar-toggle:hover{background:#00d4ff33;box-shadow:0 0 20px #00d4ff4d;color:#fff}[data-theme=dark] .sidebar-section-header{color:var(--text-primary)}[data-theme=dark] .sidebar-section-header:before{background:var(--gradient-primary)}[data-theme=dark] .sidebar-section-header:hover{background:#00d4ff14;box-shadow:inset 0 0 20px #00d4ff1a}[data-theme=dark] .sidebar-links a{color:var(--text-secondary)}[data-theme=dark] .sidebar-links a:before{background:var(--gradient-primary);box-shadow:0 0 10px #00d4ff80}[data-theme=dark] .sidebar-links a:hover{background:#00d4ff14;color:var(--accent-color);box-shadow:inset 0 0 20px #00d4ff1a,0 2px 10px #0000004d}[data-theme=dark] .sidebar-links a.active{background:linear-gradient(135deg,#00d4ff26,#7c3aed26);color:var(--accent-color);box-shadow:inset 0 0 30px #00d4ff33,0 4px 15px #0006;font-weight:600}[data-theme=dark] .sidebar-links a.active:before{opacity:1;background:var(--gradient-primary);box-shadow:0 0 15px #00d4ffcc}[data-theme=dark] .section-label{color:var(--text-muted);text-shadow:0 0 10px rgba(0,212,255,.3)}[data-theme=dark] .sidebar-footer{background:#0f1419cc;border-top:1px solid rgba(0,212,255,.15);box-shadow:0 -2px 20px #00d4ff0d}[data-theme=dark] .user-info{background:#00d4ff14;color:var(--text-primary);border:1px solid rgba(0,212,255,.15)}[data-theme=dark] .user-info:hover{background:#00d4ff1f;box-shadow:0 0 20px #00d4ff33,0 4px 15px #0000004d}[data-theme=dark] .user-info.active{background:var(--gradient-primary);color:#fff;box-shadow:0 0 30px #00d4ff66,0 4px 20px #0006}[data-theme=dark] .user-avatar{background:var(--gradient-primary);box-shadow:0 0 15px #00d4ff80}[data-theme=dark] .user-name{color:var(--text-primary)}[data-theme=dark] .user-role,[data-theme=dark] .sidebar-actions a,[data-theme=dark] .logout-button{color:var(--text-secondary)}[data-theme=dark] .sidebar-actions a:hover{background:#00d4ff1a;color:var(--accent-color);box-shadow:inset 0 0 15px #00d4ff26}[data-theme=dark] .logout-button{color:var(--error-color)}[data-theme=dark] .logout-button:hover{background:#ff5c5c26;color:#ff8a8a;box-shadow:0 0 20px #ff5c5c4d}[data-theme=dark] .badge{background:var(--gradient-primary);box-shadow:0 0 10px #00d4ff80;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{box-shadow:0 0 10px #00d4ff80}50%{box-shadow:0 0 20px #00d4ffcc}}[data-theme=dark] .sidebar-quick-actions{border-bottom:1px solid rgba(0,212,255,.15);background:#0f141980}[data-theme=dark] .quick-action-btn{background:#00d4ff14;color:var(--text-secondary);border:1px solid rgba(0,212,255,.2)}[data-theme=dark] .quick-action-btn:hover{background:#00d4ff26;box-shadow:0 0 20px #00d4ff4d;color:var(--accent-color)}[data-theme=dark] .quick-action-btn.active{background:var(--gradient-primary);color:#fff;border-color:var(--accent-color);box-shadow:0 0 25px #00d4ff80}[data-theme=dark] .quick-action-badge{background:var(--gradient-primary);border:2px solid var(--bg-primary);box-shadow:0 0 15px #00d4ff99}[data-theme=dark] .mobile-menu-button{background:var(--gradient-primary);box-shadow:0 0 20px #00d4ff66}[data-theme=dark] .mobile-menu-button:hover{box-shadow:0 0 30px #00d4ff99}.App{min-height:100vh;background-color:var(--bg-primary);width:100%}.App.with-sidebar{display:flex}.content-with-sidebar{flex:1;margin-left:15.625rem;transition:margin-left .3s ease;min-height:100vh;padding:var(--spacing-md);box-sizing:border-box;overflow-x:auto}.content-with-sidebar.sidebar-closed{margin-left:3.75rem}.project-detail-container,.stats-page-container{max-width:100vw;overflow-x:auto;box-sizing:border-box}@media (max-width: 768px){.App.with-sidebar{display:block;position:relative}.content-with-sidebar{margin-left:0;width:100%;padding:var(--spacing-sm);transition:transform .3s ease}.content-with-sidebar.sidebar-closed{margin-left:0;width:100%}.content-with-sidebar.sidebar-open-mobile{transform:translate(15.625rem)}}@media (min-width: 769px) and (max-width: 1024px){.content-with-sidebar{padding:var(--spacing-md)}.content-with-sidebar.sidebar-closed{margin-left:3.75rem;width:calc(100% - 3.75rem)}}[data-theme=dark] .App{background:var(--bg-primary);position:relative}[data-theme=dark] .App:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 20%,rgba(0,212,255,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(124,58,237,.03) 0%,transparent 50%);pointer-events:none;z-index:0;animation:aiBackground 20s ease-in-out infinite}@keyframes aiBackground{0%,to{opacity:1}50%{opacity:.7}}[data-theme=dark] .content-with-sidebar{background:transparent;position:relative;z-index:1}.chatkit-advanced-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:900px;height:90%;max-height:700px;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden;z-index:1001}.chatkit-advanced-header{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.chatkit-advanced-header-content{display:flex;align-items:center;gap:12px}.chatkit-advanced-avatar{width:48px;height:48px;border-radius:50%;background:var(--card-bg);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 2px 8px #0000001a}.chatkit-advanced-avatar-img{width:100%;height:100%;object-fit:cover}.chatkit-advanced-title-section{display:flex;flex-direction:column}.chatkit-advanced-title{margin:0;font-size:20px;font-weight:600}.chatkit-advanced-subtitle{margin:0;font-size:14px;opacity:.9}.chatkit-advanced-close{background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.chatkit-advanced-close:hover{background:#fff3}.chatkit-advanced-messages{flex:1;overflow-y:auto;padding:20px;background:#f9fafb;display:flex;flex-direction:column}.chatkit-advanced-message{display:flex;gap:12px;margin-bottom:16px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chatkit-advanced-message.user{flex-direction:row-reverse}.chatkit-advanced-message-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--card-bg);box-shadow:0 2px 4px #0000001a}.chatkit-advanced-message-avatar img{width:100%;height:100%;object-fit:cover}.chatkit-advanced-message-content{max-width:70%;padding:12px 16px;border-radius:12px;line-height:1.5}.chatkit-advanced-message.assistant .chatkit-advanced-message-content{background:var(--card-bg);color:#1f2937;box-shadow:0 2px 4px #0000000d}.chatkit-advanced-message.user .chatkit-advanced-message-content{background:#6b7280;color:#fff}.chatkit-advanced-reasoning{margin:0 0 16px;align-self:flex-start}.chatkit-advanced-reasoning-toggle{background:#0f172a;color:#fff;border:none;border-radius:10px;padding:8px 12px;font-weight:600;cursor:pointer;box-shadow:0 8px 16px #0f172a26;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.chatkit-advanced-reasoning-toggle:hover{background:#111827;transform:translateY(-1px);box-shadow:0 12px 20px #0f172a2e}.chatkit-advanced-reasoning-body{margin-top:10px;background:var(--card-bg);border:1px solid #e5e7eb;border-radius:12px;padding:12px;box-shadow:0 12px 24px #0f172a14}.chatkit-advanced-message-content p{margin:0}.chatkit-advanced-message-content ul,.chatkit-advanced-message-content ol{margin:8px 0;padding-left:20px}.chatkit-advanced-message-content li{margin:4px 0}.chatkit-advanced-typing{display:flex;gap:4px;padding:8px 0}.chatkit-advanced-typing span{width:8px;height:8px;border-radius:50%;background:#6b7280;animation:typing 1.4s infinite}.chatkit-advanced-typing span:nth-child(2){animation-delay:.2s}.chatkit-advanced-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-10px);opacity:1}}.chatkit-advanced-starters{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 12px;background:#f9fafb}.chatkit-advanced-starter-btn{padding:8px 16px;background:var(--card-bg);border:1px solid #e5e7eb;border-radius:20px;font-size:14px;color:#4b5563;cursor:pointer;transition:all .2s}.chatkit-advanced-starter-btn:hover{background:#6b7280;color:#fff;border-color:#6b7280}.chatkit-advanced-input-container{padding:16px 20px;background:var(--card-bg);border-top:1px solid #e5e7eb}.chatkit-advanced-error{padding:12px 16px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chatkit-advanced-error-content{display:flex;align-items:center;gap:8px;flex:1;color:#dc2626;font-size:14px}.chatkit-advanced-error-icon{font-size:16px;flex-shrink:0}.chatkit-advanced-error-message{line-height:1.4}.chatkit-advanced-error-retry{padding:6px 12px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s;flex-shrink:0;white-space:nowrap}.chatkit-advanced-error-retry:hover{background:#b91c1c}.chatkit-advanced-input-wrapper{display:flex;gap:8px;align-items:center}.chatkit-advanced-input{flex:1;padding:12px 16px;border:1px solid #e5e7eb;border-radius:24px;font-size:14px;outline:none;transition:border-color .2s}.chatkit-advanced-input:focus{border-color:#6b7280}.chatkit-advanced-input:disabled{background:#f9fafb;cursor:not-allowed}.chatkit-advanced-send-btn{width:40px;height:40px;border-radius:50%;background:#6b7280;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;flex-shrink:0}.chatkit-advanced-send-btn:hover:not(:disabled){background:#4b5563}.chatkit-advanced-send-btn:disabled{background:#d1d5db;cursor:not-allowed}@media (max-width: 768px){.chatkit-advanced-container{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0}.chatkit-advanced-message-content{max-width:85%}.chatkit-advanced-starters{flex-direction:column}.chatkit-advanced-starter-btn{width:100%}}.fiks-chat-fab{position:fixed;bottom:24px;right:24px;width:64px;height:64px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #0000001f;transition:all .3s ease;z-index:1000;padding:0;border-radius:50%}.fiks-chat-fab:hover{transform:scale(1.1);box-shadow:0 12px 40px #0000002e}.fiks-chat-fab:active{transform:scale(1.05)}.fiks-chat-fab-img{width:64px;height:64px;object-fit:contain;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.fiks-chat-fab:hover .fiks-chat-fab-img{animation:float 3s ease-in-out infinite,pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@media (max-width: 768px){.fiks-chat-fab{bottom:20px;right:20px;width:56px;height:56px}.fiks-chat-fab-img{width:56px;height:56px}}.fiks-chat-fab-tooltip{position:absolute;right:72px;background:#1f2937;color:#fff;padding:8px 12px;border-radius:8px;font-size:14px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease}.fiks-chat-fab:hover .fiks-chat-fab-tooltip{opacity:1}.fiks-chat-fab-tooltip:after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:6px solid #1f2937;border-top:6px solid transparent;border-bottom:6px solid transparent}@media (max-width: 768px){.fiks-chat-fab-tooltip{display:none}}[data-theme=dark] .component,[data-theme=dark] .wrapper,[data-theme=dark] .container{background:var(--card-bg);color:var(--text-primary)}[data-theme=dark] .card,[data-theme=dark] .panel,[data-theme=dark] .box{background:var(--card-bg);border:1px solid rgba(0,212,255,.15);box-shadow:0 0 30px #00d4ff1a,0 4px 15px #0000004d}[data-theme=dark] .card:hover,[data-theme=dark] .panel:hover{border-color:#00d4ff4d;box-shadow:0 0 40px #00d4ff33,0 8px 25px #0006}[data-theme=dark] .header,[data-theme=dark] .card-header,[data-theme=dark] .panel-header{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);border-bottom:1px solid rgba(0,212,255,.15)}[data-theme=dark] .title,[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4,[data-theme=dark] h5,[data-theme=dark] h6{color:var(--text-primary)}[data-theme=dark] .subtitle,[data-theme=dark] .description{color:var(--text-secondary)}[data-theme=dark] .muted,[data-theme=dark] .text-muted{color:var(--text-muted)}[data-theme=dark] .btn,[data-theme=dark] button{background:#00d4ff1a;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] .btn:hover,[data-theme=dark] button:hover{background:#00d4ff33;border-color:var(--accent-color);box-shadow:0 0 25px #00d4ff66;color:var(--accent-color)}[data-theme=dark] .btn-primary{background:var(--gradient-primary);border:none;box-shadow:0 0 30px #00d4ff66}[data-theme=dark] .btn-primary:hover{box-shadow:0 0 40px #00d4ff99}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background:#0f1419cc;border:1px solid rgba(0,212,255,.2);color:var(--text-primary)}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{border-color:var(--accent-color);box-shadow:0 0 20px #00d4ff4d}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-muted)}[data-theme=dark] label{color:var(--text-primary)}[data-theme=dark] .list-item,[data-theme=dark] .item{background:#00d4ff0d;border:1px solid rgba(0,212,255,.1)}[data-theme=dark] .list-item:hover,[data-theme=dark] .item:hover{background:#00d4ff1a;border-color:#00d4ff33;box-shadow:0 0 20px #00d4ff33}[data-theme=dark] .badge,[data-theme=dark] .tag{background:var(--gradient-primary);color:#fff;box-shadow:0 0 15px #00d4ff80}[data-theme=dark] .badge.success{background:#0f83;color:var(--success-color);border:1px solid rgba(0,255,136,.3)}[data-theme=dark] .badge.error,[data-theme=dark] .badge.danger{background:#ff5c5c33;color:var(--error-color);border:1px solid rgba(255,92,92,.3)}[data-theme=dark] .badge.warning{background:#ffb83633;color:var(--warning-color);border:1px solid rgba(255,184,54,.3)}[data-theme=dark] .icon-wrapper,[data-theme=dark] .icon-box{background:var(--gradient-primary);box-shadow:0 0 20px #00d4ff66}[data-theme=dark] .divider,[data-theme=dark] hr{border-color:#00d4ff26}[data-theme=dark] a{color:var(--accent-color)}[data-theme=dark] a:hover{color:#fff;text-shadow:0 0 10px rgba(0,212,255,.6)}[data-theme=dark] table{background:var(--card-bg);border:1px solid rgba(0,212,255,.15)}[data-theme=dark] th{background:linear-gradient(135deg,#00d4ff14,#7c3aed14);color:var(--text-primary);border-bottom:2px solid rgba(0,212,255,.3)}[data-theme=dark] td{color:var(--text-secondary);border-bottom:1px solid rgba(0,212,255,.1)}[data-theme=dark] tr:hover{background:#00d4ff0d}[data-theme=dark] .progress{background:#00d4ff1a}[data-theme=dark] .progress-fill{background:var(--gradient-primary);box-shadow:0 0 15px #00d4ff80}[data-theme=dark] .tooltip{background:var(--card-bg);border:1px solid rgba(0,212,255,.3);box-shadow:0 0 30px #00d4ff4d;color:var(--text-primary)}[data-theme=dark] .empty-state,[data-theme=dark] .no-data{color:var(--text-muted)}
