: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}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-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:#fff;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%}}.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:#fff;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:#fff;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:#fff;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}body{margin:0;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}#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%}}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff}.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}}.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:#fff;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:#fff;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-header h3{margin:0}.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:#fff}.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:#fff;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:#fff;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:#fff;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:#fff;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-actions{display:flex;gap:.75rem}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.memory-item-modal:hover,.deviation-item-modal:hover{background:#fff;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:#fff;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}@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%}}.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:#fff;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:#fff;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}}.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:#fff}.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:#fff;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:#fafbfc;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:#fff;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:#f8f9fa}.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:#fff;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:#fff;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:#fff;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:#fff;color:var(--text-primary);transition:all .3s ease;min-height:2.75rem}.filter-controls{background:#fff;padding:2rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin-bottom:2rem}.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:#fff;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:#fff;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:#fff}.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:#fff;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:#fff;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}: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:#fff;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:#fff;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:#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 .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:#fff;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)}.actions{display:flex;gap:.5rem}.empty-state{padding:3rem;text-align:center;color:var(--text-secondary)}.empty-state p{font-size:1.125rem}.modal{background:#fff;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{margin-bottom:1.5rem}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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}.register-page{padding:2rem;max-width:1400px;margin:0 auto;background:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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}@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{display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:none;cursor:help;color:#9ca3af;transition:color .2s ease;outline:none}.info-tooltip-trigger:hover{color:#6b7280}.info-tooltip-trigger:focus{color:#6b7280}.info-tooltip-content{position:absolute;z-index:1000;min-width:280px;max-width:400px;padding:.875rem 1rem;background:#1f2937;color:#fff;border-radius:.5rem;font-size:.875rem;line-height:1.5;box-shadow:0 10px 25px #0000004d;pointer-events:auto}.info-tooltip-text{white-space:pre-wrap}.info-tooltip-top{bottom:calc(100% + .5rem);left:50%;transform:translate(-50%)}.info-tooltip-bottom{top:calc(100% + .5rem);left:50%;transform:translate(-50%)}.info-tooltip-left{right:calc(100% + .5rem);top:50%;transform:translateY(-50%)}.info-tooltip-right{left:calc(100% + .5rem);top:50%;transform:translateY(-50%)}.info-tooltip-arrow{position:absolute;width:0;height:0;border-style:solid}.info-tooltip-top .info-tooltip-arrow{bottom:-.375rem;left:50%;transform:translate(-50%);border-width:.375rem .375rem 0 .375rem;border-color:#1f2937 transparent transparent transparent}.info-tooltip-bottom .info-tooltip-arrow{top:-.375rem;left:50%;transform:translate(-50%);border-width:0 .375rem .375rem .375rem;border-color:transparent transparent #1f2937 transparent}.info-tooltip-left .info-tooltip-arrow{right:-.375rem;top:50%;transform:translateY(-50%);border-width:.375rem 0 .375rem .375rem;border-color:transparent transparent transparent #1f2937}.info-tooltip-right .info-tooltip-arrow{left:-.375rem;top:50%;transform:translateY(-50%);border-width:.375rem .375rem .375rem 0;border-color:transparent #1f2937 transparent transparent}@media (max-width: 640px){.info-tooltip-content{min-width:240px;max-width:calc(100vw - 2rem)}.info-tooltip-top,.info-tooltip-bottom{left:auto;right:0;transform:none}.info-tooltip-top .info-tooltip-arrow,.info-tooltip-bottom .info-tooltip-arrow{left:auto;right:1rem;transform:none}}.reviews-performance-card{background:#fff;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:#fff;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:#fff;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}.metric-label.secondary{font-size:.75rem;color:#666;font-weight:600;margin:0}.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:#fff;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:#fff;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}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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))}}.partner-control-page{padding:2rem;max-width:1400px;margin:0 auto;background-color:#f9fafb;min-height:100vh}.page-header{background:#fff;color:#1f2937;padding:2rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a;border-left:4px solid #6b7280}.header-content{display:flex;align-items:center;gap:1.5rem}.header-content svg{color:#6b7280}.header-content h1{margin:0;font-size:2rem;font-weight:600;color:#1f2937}.header-content p{margin:.5rem 0 0;color:#6b7280;font-size:1rem}.filter-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.filter-section h2{display:flex;align-items:center;gap:.5rem;margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937;font-weight:600}.filter-section h2 svg{color:#6b7280}.date-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.date-input-group{display:flex;flex-direction:column;gap:.5rem}.date-input-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#1f2937;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.date-input-group label svg{color:#6b7280}.date-input{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s;width:100%;background:#fff;color:#1f2937}.date-input:focus{outline:none;border-color:#6b7280;box-shadow:0 0 0 3px #6b72801a}.date-input:hover{border-color:#9ca3af}.customer-type-filters{margin-bottom:1.5rem}.customer-type-filters>label{display:block;font-weight:600;color:#1f2937;margin-bottom:1rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.type-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:6px;cursor:pointer;transition:background-color .2s}.checkbox-label:hover{background-color:#f3f4f6}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#f97316}.checkbox-label span{font-size:.95rem;color:#374151}.more-types{margin-top:1rem;padding:1rem;background-color:#f9fafb;border-radius:8px}.more-types summary{cursor:pointer;font-weight:500;color:#6b7280;-webkit-user-select:none;user-select:none;list-style:none}.more-types summary::-webkit-details-marker{display:none}.more-types summary:before{content:"▶ ";display:inline-block;margin-right:.5rem;transition:transform .2s}.more-types[open] summary:before{transform:rotate(90deg)}.more-types .type-checkboxes{margin-top:1rem}.load-data-btn{width:100%;padding:1rem;background:#6b7280;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background-color .2s}.load-data-btn:hover:not(:disabled){background:#4b5563}.load-data-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:1rem;background-color:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;margin-bottom:2rem}.report-preview{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.preview-header h2{margin:0;font-size:1.75rem;color:#1f2937;font-weight:600}.generate-pdf-btn{padding:.75rem 1.5rem;background:#6b7280;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:background-color .2s}.generate-pdf-btn:hover:not(:disabled){background:#4b5563}.generate-pdf-btn:disabled{opacity:.5;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{padding:1.5rem;background:#fff;border-radius:6px;border:1px solid #e5e7eb;box-shadow:0 1px 2px #0000000d}.metric-card h3{margin:0 0 .75rem;font-size:.875rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metric-value{margin:0;font-size:2rem;font-weight:700;color:#1f2937}.metric-value.success{color:#059669}.metric-value.error{color:#dc2626}.conversion-section{margin-bottom:2rem}.conversion-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a}.conversion-bars{display:flex;flex-direction:column;gap:1.5rem}.conversion-bar label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.95rem}.bar-container{background-color:#e5e7eb;border-radius:8px;height:40px;overflow:hidden}.bar{height:100%;background:#6b7280;display:flex;align-items:center;justify-content:flex-end;padding-right:1rem;transition:width .5s ease;min-width:50px}.bar.success{background:#059669}.bar span{color:#fff;font-weight:600;font-size:.9rem}.distribution-section{margin-top:2rem}.distribution-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a}.distribution-table{overflow-x:auto}.distribution-table table{width:100%;border-collapse:collapse}.distribution-table th{background-color:#f3f4f6;padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.distribution-table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#1a1a1a}.distribution-table tr:hover{background-color:#f9fafb}.report-options-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.report-options-section h3{margin:0 0 1.5rem;font-size:1.25rem;color:#1f2937;font-weight:600}.options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.option-checkbox{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:6px;cursor:pointer;transition:background-color .2s;border:1px solid #e5e7eb}.option-checkbox:hover{background-color:#f9fafb}.option-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#6b7280}.option-checkbox label{cursor:pointer;font-size:.95rem;color:#374151;margin:0}.charts-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.charts-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937;font-weight:600}.chart-container{margin-bottom:2rem;padding:1rem;background:#f9fafb;border-radius:6px}.chart-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.reviews-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.reviews-section h3{margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937;font-weight:600}@media (max-width: 768px){.partner-control-page{padding:1rem}.page-header{padding:1.5rem}.header-content h1{font-size:1.5rem}.filter-section{padding:1.5rem}.metrics-grid,.date-filters{grid-template-columns:1fr}.preview-header{flex-direction:column;align-items:flex-start;gap:1rem}.generate-pdf-btn{width:100%}.options-grid{grid-template-columns:1fr}}.quick-date-selectors{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.quick-date-selectors label{display:block;font-weight:500;color:#374151;margin-bottom:.75rem;font-size:.95rem}.quick-date-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.quick-date-btn{padding:.5rem 1rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap}.quick-date-btn:hover{background:#e5e7eb;border-color:#9ca3af;color:#1f2937;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.quick-date-btn:active{transform:translateY(0);box-shadow:none}@media (max-width: 768px){.quick-date-buttons{flex-direction:column}.quick-date-btn{width:100%;text-align:center}}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff}.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:#fff;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:#fff}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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}}.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:#fff;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:#fff;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:#fff;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:#fff;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:#fff;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:#fff}.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:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table-container{overflow-x:auto}.projects-table{width:100%;border-collapse:collapse}.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:#fff;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:#fff;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:#fff;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}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.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)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.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:#fff;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:#fff;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:#fff;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: #ffffff;--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:#fff;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)}}.sidebar{display:flex;flex-direction:column;height:100vh;background:#fff;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:#fff;position:relative;overflow:hidden;min-height:4rem}.sidebar-logo{height:2.5rem;width:auto;max-width:100%;object-fit:contain;padding:.25rem .5rem;background:#fff;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)}.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)}.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)}}
