@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--accent: #004C85;--accent-hover: #003A6A;--accent-light: #E8F0F7;--accent-lighter: #F0F6FC;--accent-border: #B8D0E8;--accent-glow: rgba(0,76,133,.12);--success: #16A34A;--success-light: #DCFCE7;--success-dark: #166534;--warning: #D97706;--warning-light: #FEF3C7;--warning-dark: #92400E;--destructive: #DC2626;--destructive-light: #FEE2E2;--destructive-dark: #991B1B;--surface-base: #F0F2F5;--surface-raised: #FFFFFF;--surface-overlay: #E8ECF1;--surface-hover: #F3F4F6;--surface-hero: linear-gradient(135deg, #004C85 0%, #1D4ED8 100%);--text-primary: #111827;--text-secondary: #6B7280;--text-tertiary: #9CA3AF;--text-inverse: #FFFFFF;--border-default: #E5E7EB;--border-strong: #D1D5DB;--sidebar-width: 240px;--header-height: 56px;--content-max: 1440px;--radius-sm: 6px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.08), 0 10px 10px -5px rgba(0,0,0,.04);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--transition-fast: .15s var(--ease-out);--transition: .2s var(--ease-out);--transition-slow: .3s var(--ease-out)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-family:var(--font);font-size:14px;font-weight:400;background:var(--surface-base);color:var(--text-primary);line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:14px}#app{display:flex;min-height:100dvh}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition)}.main-wrapper.full{margin-left:0}.view-container{width:100%;padding:0;flex:1}.content{padding:24px 28px;max-width:var(--content-max);width:100%;margin:0 auto}@media (max-width:1280px){.content{padding:20px 24px}}@media (max-width:768px){.content{padding:16px 14px 80px}}.sidebar{width:var(--sidebar-width);background:var(--surface-raised);border-right:1px solid var(--border-default);display:flex;flex-direction:column;position:fixed;height:100dvh;z-index:100;transition:transform var(--transition)}.sidebar.hidden{display:none}.sidebar-logo{height:var(--header-height);padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-default);flex-shrink:0}.sidebar-logo img{width:28px;height:28px;border-radius:6px;object-fit:contain}.sidebar-logo span{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-section{margin-bottom:12px}.nav-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:6px 10px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius);color:var(--text-secondary);font-size:13px;font-weight:400;transition:all var(--transition-fast);cursor:pointer;position:relative;border:none;width:100%;text-align:left}.nav-item svg{width:18px;height:18px;flex-shrink:0;opacity:.7}.nav-item span{flex:1}.nav-item:hover{background:var(--surface-hover);color:var(--text-primary)}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:500}.nav-item.active svg{opacity:1;color:var(--accent)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0}.nav-item .badge{margin-left:auto;font-size:10px;padding:2px 6px;background:var(--accent);color:#fff;border-radius:var(--radius-pill);font-weight:600}.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border-default);display:flex;align-items:center;gap:10px;flex-shrink:0}.user-avatar{width:34px;height:34px;border-radius:var(--radius);background:var(--surface-hero);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--text-tertiary);font-weight:500}.header{height:var(--header-height);background:var(--surface-raised);border-bottom:1px solid var(--border-default);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb}.header.hidden{display:none}.header-left{display:flex;align-items:center;gap:14px}.header-right{display:flex;align-items:center;gap:8px}.breadcrumb{font-size:13px;color:var(--text-tertiary);display:flex;align-items:center;gap:6px}.breadcrumb span{cursor:pointer;transition:color var(--transition-fast)}.breadcrumb span:hover{color:var(--text-secondary)}.breadcrumb span:last-child{color:var(--text-primary);font-weight:600}.breadcrumb .sep{color:var(--text-tertiary);opacity:.4;font-size:14px}.page-header{margin-bottom:20px}.page-header-flex{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.page-kicker{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:4px}.page-title{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1.15}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.stats-grid{grid-template-columns:1fr;gap:10px}}.stat-card{background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:18px 20px;transition:all var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-border)}.stat-card.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.stat-card.success{background:var(--success);color:#fff;border-color:var(--success)}.stat-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-icon svg{width:20px;height:20px}.stat-icon.accent-bg{background:var(--accent-light);color:var(--accent)}.stat-icon.success-bg{background:var(--success-light);color:var(--success)}.stat-icon.warning-bg{background:var(--warning-light);color:var(--warning)}.stat-icon.blue-bg{background:#dbeafe;color:#1d4ed8}.stat-icon.purple-bg{background:#ede9fe;color:#7c3aed}.stat-value{font-size:30px;font-weight:800;line-height:1;margin-bottom:4px;font-variant-numeric:tabular-nums}.stat-card.accent .stat-value,.stat-card.success .stat-value{color:#fff}.stat-label{font-size:12px;color:var(--text-secondary);font-weight:500}.stat-card.accent .stat-label,.stat-card.success .stat-label{color:#fffc}.card{background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:20px;margin-bottom:16px;transition:all var(--transition-fast)}.card:hover{box-shadow:var(--shadow)}.card-flush{padding:0}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:15px;font-weight:700;color:var(--text-primary)}.card-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.card-body{padding:0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;gap:10px}}.dashboard-grid{display:grid;grid-template-columns:1fr 380px;gap:16px}@media (max-width:1200px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width:1200px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.projects-grid{grid-template-columns:1fr;gap:10px}}.units-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (max-width:768px){.units-grid{grid-template-columns:1fr;gap:10px}}.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width:640px){.quick-grid{grid-template-columns:1fr}}.project-card{background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:16px 18px;box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer;position:relative;display:flex;flex-direction:column;gap:10px}.project-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent-border)}.project-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.project-no{font-size:15px;font-weight:700;color:var(--accent);letter-spacing:-.02em}.project-customer{font-size:13px;color:var(--text-secondary);margin-top:2px;line-height:1.3}.project-meta{display:flex;gap:14px;font-size:12px;color:var(--text-tertiary)}.project-meta span{display:flex;align-items:center;gap:4px}.project-progress{height:5px;background:var(--surface-overlay);border-radius:99px;overflow:hidden;margin-top:2px}.project-progress span{display:block;height:100%;border-radius:99px;transition:width 1s var(--ease-out)}.project-actions{display:flex;gap:6px;margin-top:4px}.project-actions .btn{flex:1;justify-content:center}.unit-card{background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:16px 18px;box-shadow:var(--shadow-sm);transition:all var(--transition)}.unit-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent-border)}.unit-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px}.unit-job{font-size:14px;font-weight:700;color:var(--accent)}.unit-name{font-size:13px;color:var(--text-secondary);margin-top:2px}.unit-spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px}@media (max-width:640px){.unit-spec-grid{grid-template-columns:repeat(2,1fr)}}.unit-spec-grid div{background:var(--surface-base);border-radius:var(--radius);padding:8px 10px}.unit-spec-grid label{display:block;font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:2px}.unit-spec-grid span{font-size:12px;color:var(--text-primary);font-weight:500}.unit-actions{display:flex;gap:6px}.project-hero{background:var(--surface-hero);color:#fff;padding:24px 28px;border-radius:var(--radius-2xl);margin-bottom:20px;position:relative;overflow:hidden}.project-hero-grid{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;position:relative;z-index:1}@media (max-width:768px){.project-hero-grid{grid-template-columns:1fr}}.project-hero-kicker{font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.7;font-weight:600;margin-bottom:4px}.project-hero-title{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:4px}.project-hero-customer{font-size:15px;opacity:.85;margin-bottom:6px}.project-hero-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.project-hero-progress{margin-top:14px}.project-hero-progress .progress-bar{height:5px;background:#fff3;border-radius:99px;overflow:hidden}.project-hero-progress .progress-bar span{display:block;height:100%;background:#fff;border-radius:99px}.project-hero-progress small{font-size:11px;opacity:.7;margin-top:4px;display:block}.project-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}@media (max-width:768px){.project-kpis{grid-template-columns:repeat(2,1fr)}}.project-kpis .stat-card{padding:14px 16px;margin-bottom:0}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-default)}table{width:100%;border-collapse:collapse;background:var(--surface-raised)}th{text-align:left;padding:12px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);background:var(--surface-base);border-bottom:1px solid var(--border-default)}td{padding:14px 16px;font-size:13px;color:var(--text-primary);border-bottom:1px solid var(--border-default);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-hover)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-success{background:var(--success-light);color:var(--success-dark)}.badge-warning{background:var(--warning-light);color:var(--warning-dark)}.badge-destructive{background:var(--destructive-light);color:var(--destructive-dark)}.badge-neutral{background:var(--surface-overlay);color:var(--text-secondary);font-weight:500}.badge-white{background:#ffffff26;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;min-height:40px}.btn:focus{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface-raised);color:var(--text-primary);border:1.5px solid var(--border-default)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-hover);color:var(--text-primary)}.btn-sm{padding:7px 14px;font-size:12px;min-height:34px}.btn-xs{padding:4px 10px;font-size:11px;min-height:28px;border-radius:var(--radius-sm)}.btn svg{width:16px;height:16px}.btn-block{width:100%;justify-content:center}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border-default);border-radius:var(--radius);font-size:14px;color:var(--text-primary);background:var(--surface-raised);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group input::placeholder{color:var(--text-tertiary)}.form-inline{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.form-inline input,.form-inline select{flex:1;min-width:160px;padding:10px 14px;border:1.5px solid var(--border-default);border-radius:var(--radius);font-size:13px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-default);margin-bottom:20px}.tab{padding:10px 18px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);margin-bottom:-1px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.icon-btn{width:36px;height:36px;border-radius:var(--radius);border:none;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.icon-btn svg{width:20px;height:20px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface-raised);border-radius:var(--radius-2xl);padding:28px;max-width:520px;width:100%;box-shadow:var(--shadow-xl);animation:slideUp .2s var(--ease-out)}@keyframes slideUp{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-lg{max-width:680px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:18px;font-weight:700}.timeline{display:flex;align-items:center;justify-content:space-between;position:relative;padding:0 20px}.timeline:before{content:"";position:absolute;top:16px;left:28px;right:28px;height:2px;background:var(--border-default)}.timeline-step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1}.step-circle{width:32px;height:32px;border-radius:50%;background:var(--surface-raised);border:2px solid var(--border-default);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-tertiary);transition:all var(--transition)}.timeline-step.active .step-circle{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 4px var(--accent-glow)}.timeline-step.done .step-circle{background:var(--success);border-color:var(--success);color:#fff}.step-label{font-size:11px;color:var(--text-tertiary);text-align:center;max-width:72px;font-weight:500}.timeline-step.active .step-label,.timeline-step.done .step-label{color:var(--text-primary);font-weight:600}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{background:linear-gradient(90deg,var(--surface-overlay) 25%,var(--surface-hover) 50%,var(--surface-overlay) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius);color:transparent!important;pointer-events:none;-webkit-user-select:none;user-select:none}.skeleton-pulse{animation:pulse 2s var(--ease-in-out) infinite;background:var(--surface-overlay)!important}.skeleton-page{padding:24px 0}.skeleton-header{margin-bottom:28px}.skeleton-title{height:32px;width:320px;margin-bottom:10px}.skeleton-subtitle{height:16px;width:200px}.skeleton-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}@media (max-width:1024px){.skeleton-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.skeleton-stats{grid-template-columns:1fr}}.skeleton-stat{height:110px;border-radius:var(--radius-xl)}.skeleton-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width:1200px){.skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.skeleton-grid{grid-template-columns:1fr}}.skeleton-card-item{height:170px;border-radius:var(--radius-xl)}.skeleton-text{height:14px;margin-bottom:10px}.skeleton-text.w200{width:200px}.skeleton-text.w120{width:120px}.skeleton-text.w80{width:80px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-height:80vh;overflow-y:auto}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);min-width:320px;max-width:420px;transform:translate(120%);opacity:0;transition:transform .3s var(--ease-out),opacity .2s}.toast.show{transform:translate(0);opacity:1}.toast svg{width:20px;height:20px;flex-shrink:0}.toast span{flex:1;font-size:13px;color:var(--text-primary);line-height:1.4}.toast-success svg{color:var(--success)}.toast-error svg{color:var(--destructive)}.toast-warning svg{color:var(--warning)}.toast-info svg{color:var(--accent)}.toast-close{background:none;border:none;color:var(--text-tertiary);font-size:18px;cursor:pointer;padding:4px;opacity:.5;transition:opacity var(--transition-fast)}.toast-close:hover{opacity:1}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.empty-icon{width:64px;height:64px;margin-bottom:16px;color:var(--text-tertiary);opacity:.5}.empty-icon svg{width:100%;height:100%}.empty-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.empty-desc{font-size:14px;color:var(--text-secondary);margin-bottom:20px;max-width:320px;line-height:1.5}.settings-grid{display:grid;grid-template-columns:200px 1fr;gap:24px}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}}.settings-nav{display:flex;flex-direction:column;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;width:100%;text-align:left}.settings-nav-item:hover{background:var(--surface-hover);color:var(--text-primary)}.settings-nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}.settings-nav-item svg{width:18px;height:18px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border-default)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.toggle-desc{font-size:12px;color:var(--text-secondary)}.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:12px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.inspection-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}@media (max-width:640px){.inspection-steps{grid-template-columns:repeat(2,1fr)}}.inspection-step-item{border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:10px 8px;text-align:center;background:#fff;transition:all var(--transition-fast)}.inspection-step-item span{display:inline-flex;width:26px;height:26px;border-radius:999px;align-items:center;justify-content:center;font-weight:700;background:var(--accent-light);color:var(--accent);margin-bottom:4px;font-size:12px}.inspection-step-item small{display:block;font-size:11px;color:var(--text-secondary);font-weight:500}.inspection-step-item.active{border-color:var(--accent);background:var(--accent-lighter)}.inspection-step-item.active span{background:var(--accent);color:#fff}.inspection-step-item.done{border-color:var(--success);background:var(--success-light)}.inspection-step-item.done span{background:var(--success);color:#fff}.inspection-section{margin-bottom:16px}.inspection-section h3{font-size:15px;font-weight:700;margin-bottom:10px;color:var(--text-primary)}.photo-checklist{display:grid;grid-template-columns:1fr;gap:8px}.check-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border-default);border-radius:var(--radius-lg);background:#fff;transition:all var(--transition-fast)}.check-left{display:flex;gap:10px;align-items:flex-start}.check-index{width:26px;height:26px;border-radius:999px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.check-title{font-size:13px;font-weight:600;color:var(--text-primary)}.check-sub{font-size:11px;color:var(--text-secondary);margin-top:2px}.check-actions{display:flex;gap:8px;align-items:center}.check-status{font-size:12px;color:var(--text-secondary);min-width:80px;text-align:right}.check-item.complete{border-color:var(--success);background:var(--success-light)}.check-item.complete .check-status{color:var(--success-dark);font-weight:700}.check-item.complete .check-index{background:var(--success);color:#fff}.report-option{padding:20px;border:1px solid var(--border-default);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition);text-align:center}.report-option:hover{border-color:var(--accent);background:var(--accent-lighter);transform:translateY(-2px);box-shadow:var(--shadow-md)}.report-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--surface-hover);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:var(--text-secondary);transition:all var(--transition)}.report-option:hover .report-icon{background:var(--accent);color:#fff;transform:scale(1.05)}.report-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.report-desc{font-size:12px;color:var(--text-tertiary)}.portal-wrapper{max-width:520px;margin:0 auto;padding:24px}.portal-header{text-align:center;margin-bottom:24px}.portal-header .portal-logo{font-size:32px;font-weight:800;color:var(--accent)}.portal-header .portal-subtitle{font-size:12px;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase;font-weight:600}.upload-zone{border:2px dashed var(--border-default);border-radius:var(--radius-xl);padding:40px 24px;text-align:center;cursor:pointer;transition:all var(--transition-fast)}.upload-zone:hover{border-color:var(--accent);background:var(--accent-lighter)}.upload-zone svg{color:var(--text-tertiary);margin-bottom:12px}.upload-zone p{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.upload-zone span{font-size:12px;color:var(--text-tertiary)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}@media (max-width:640px){.photo-grid{grid-template-columns:repeat(2,1fr)}}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;display:none;animation:fadeIn .2s ease}.sidebar-overlay.show{display:block}@media (max-width:768px){.sidebar{transform:translate(-100%);width:280px;z-index:101}.sidebar.mobile-open{transform:translate(0);box-shadow:var(--shadow-xl)}.main-wrapper{margin-left:0!important}#sidebar-toggle{display:flex!important}.search-box{display:none}.header{padding:0 14px}}@media (min-width:769px){#sidebar-toggle{display:none!important}}.hidden{display:none!important}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--text-secondary)}.text-accent{color:var(--accent)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.w-full{width:100%}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.fade-up{animation:fadeUp .4s var(--ease-out) both}.fade-up-1{animation:fadeUp .4s var(--ease-out) 50ms both}.fade-up-2{animation:fadeUp .4s var(--ease-out) .1s both}.fade-up-3{animation:fadeUp .4s var(--ease-out) .15s both}.fade-up-4{animation:fadeUp .4s var(--ease-out) .2s both}.inspection-hero{background:var(--surface-hero);color:#fff;padding:24px 28px;border-radius:var(--radius-2xl);margin-bottom:16px}.inspection-hero-grid{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start}@media (max-width:768px){.inspection-hero-grid{grid-template-columns:1fr}}.inspection-hero-side{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-content:flex-start}.inspection-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;background:#ffffff26;border:1px solid rgba(255,255,255,.25)}.section-panel{background:var(--surface-raised);border-radius:var(--radius-xl);padding:18px 20px;border:1px solid var(--border-default);margin-bottom:16px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.section-action{font-size:12px;color:var(--accent);font-weight:600;background:none;border:none;cursor:pointer}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f0f2f5,#e8f0fe);padding:24px;position:relative}.login-card{width:100%;max-width:400px;animation:slideUp .4s var(--ease-out)}.login-logo{width:80px;height:80px;margin:0 auto 16px;display:block;object-fit:contain;border-radius:var(--radius-xl);background:#fff;padding:8px;box-shadow:var(--shadow-md)}.login-form-wrap{padding:28px;border-radius:var(--radius-2xl);background:var(--surface-raised);box-shadow:0 8px 32px #0000000f}.login-title{font-size:22px;font-weight:800;text-align:center;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.02em}.login-subtitle{font-size:13px;text-align:center;color:var(--text-secondary);margin-bottom:24px;font-weight:500}.login-input{width:100%;padding:12px 16px;border:1.5px solid var(--border-default);border-radius:var(--radius);font-size:14px;transition:all var(--transition-fast);outline:none;background:var(--surface-base)}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.login-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:15px;font-weight:700;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px var(--accent-glow)}.login-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{text-align:center;margin-top:20px;font-size:13px;color:var(--text-secondary)}.login-footer a{color:var(--accent);font-weight:600;text-decoration:none}.status-bar-item{margin-bottom:10px}.status-bar-item:last-child{margin-bottom:0}.status-bar-head{display:flex;justify-content:space-between;margin-bottom:4px}.status-bar-label{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.status-bar-value{font-size:12px;font-weight:700}.status-bar-track{background:var(--surface-overlay);border-radius:99px;height:7px;overflow:hidden}.status-bar-fill{height:100%;border-radius:99px;transition:width 1s var(--ease-out)}.quick-btn{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid var(--border-default);border-radius:var(--radius-lg);background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left}.quick-btn:hover{background:var(--accent-lighter);border-color:var(--accent-border);transform:translate(4px)}.quick-btn svg{width:18px;height:18px;color:var(--accent);flex-shrink:0}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-default);flex-wrap:wrap}.info-row{display:flex;justify-content:space-between;padding:10px 0}.info-row:not(:last-child){border-bottom:1px solid var(--border-default)}.info-label{font-size:13px;color:var(--text-secondary)}.info-value{font-size:13px;font-weight:600;color:var(--text-primary)}.portal-footer{text-align:center;margin-top:24px;font-size:12px;color:var(--text-tertiary);padding-bottom:16px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.gallery-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-default);background:var(--surface-raised)}.gallery-img{width:100%;height:180px;object-fit:cover;display:block}.gallery-info{padding:10px 12px}@media (max-width:768px){body:after{content:" ";position:fixed;bottom:0;left:0;right:0;height:env(safe-area-inset-bottom,0px);background:transparent;z-index:9999;pointer-events:none}}@media (max-width:768px){.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;display:none;animation:fadeIn .15s ease}.sidebar-overlay.show{display:block}}
