@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg-base: #070d1a;--bg-surface: #0e1829;--bg-elevated: #162035;--bg-overlay: #1c2a44;--bg-modal: #0b1422;--border: rgba(30, 70, 120, .45);--border-hover: rgba(0, 180, 216, .35);--border-active: rgba(0, 180, 216, .7);--accent: #00b4d8;--accent-dark: #0077a8;--accent-dim: rgba(0, 180, 216, .12);--accent-glow: rgba(0, 180, 216, .25);--blue: #3b82f6;--blue-dim: rgba(59, 130, 246, .12);--s-pending: #64748b;--s-submit: #3b82f6;--s-review: #f59e0b;--s-approved: #10b981;--s-revise: #f97316;--s-rejected: #ef4444;--s-pending-bg: rgba(100, 116, 139, .12);--s-submit-bg: rgba(59, 130, 246, .12);--s-review-bg: rgba(245, 158, 11, .12);--s-approved-bg: rgba(16, 185, 129, .12);--s-revise-bg: rgba(249, 115, 22, .12);--s-rejected-bg: rgba(239, 68, 68, .12);--bic-you: #00b4d8;--bic-pm: #a855f7;--bic-gc: #3b82f6;--bic-engineer: #14b8a6;--bic-architect:#6366f1;--bic-vendor: #f59e0b;--p-high: #ef4444;--p-medium: #f59e0b;--p-low: #475569;--text: #e2e8f0;--text-sub: #94a3b8;--text-muted: #475569;--text-dim: #334155;--text-accent:#00b4d8;--nav-w: 60px;--sidebar-w: 248px;--panel-w: 380px;--shadow: 0 4px 24px rgba(0,0,0,.5);--shadow-lg: 0 8px 40px rgba(0,0,0,.7);--glow-sm: 0 0 12px rgba(0,180,216,.2);--glow: 0 0 24px rgba(0,180,216,.3);--t: .15s ease;--t-med: .25s ease;--font: "Inter", system-ui, -apple-system, sans-serif;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg-base);color:var(--text);height:100vh;overflow:hidden;background-image:radial-gradient(rgba(0,180,216,.04) 1px,transparent 1px);background-size:28px 28px}.app-shell{display:flex;height:100vh;width:100vw;overflow:hidden}.nav-rail{width:var(--nav-w);height:100vh;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:4px;flex-shrink:0;z-index:100}.nav-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;color:#000;letter-spacing:-.5px;margin-bottom:16px;box-shadow:0 0 16px #00b4d866;flex-shrink:0}.nav-btn{width:40px;height:40px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t);position:relative}.nav-btn:hover{background:var(--accent-dim);color:var(--text)}.nav-btn.active{background:var(--accent-dim);color:var(--accent);box-shadow:var(--glow-sm)}.nav-btn.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;box-shadow:2px 0 8px var(--accent)}.nav-spacer{flex:1}.nav-tooltip{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--bg-overlay);border:1px solid var(--border);color:var(--text);padding:4px 10px;border-radius:var(--radius-sm);font-size:11px;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--t);z-index:200}.nav-btn:hover .nav-tooltip{opacity:1}.main-stage{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.top-bar{height:52px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}.top-bar-title{font-size:13px;font-weight:600;color:var(--text)}.top-bar-sub{font-size:12px;color:var(--text-muted)}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.breadcrumb-sep{color:var(--text-dim)}.breadcrumb-active{color:var(--text);font-weight:500}.stage-body{flex:1;overflow-y:auto;padding:24px}.search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 12px;height:32px;min-width:280px;transition:border-color var(--t)}.search-wrap:focus-within{border-color:var(--border-hover)}.search-wrap input{background:none;border:none;outline:none;color:var(--text);font-size:12px;font-family:var(--font);width:100%}.search-wrap input::-moz-placeholder{color:var(--text-muted)}.search-wrap input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;padding:7px 14px;transition:all var(--t);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:#000}.spec-hub{height:100vh;display:flex;flex-direction:column}.spec-dropzone{width:100%;max-width:500px;margin:0 auto;border:2px dashed var(--border);border-radius:24px;padding:60px 40px;background:var(--bg-surface);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:12px}.spec-dropzone:hover{border-color:var(--accent);background:var(--bg-surface-elevated);transform:translateY(-2px);box-shadow:0 12px 40px -12px #00ccff26}.spec-dropzone-icon{width:48px;height:48px;color:var(--accent);opacity:.8;margin-bottom:12px}.spec-discovery-grid{display:grid;grid-template-columns:1fr 320px;min-height:500px;max-height:70vh;box-shadow:0 20px 50px -12px #0000004d}.spec-section-list{overflow-y:auto}.div-header{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.checkbox-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.checkbox-item:hover{background:var(--bg-surface-elevated)}.checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.skeleton-circle{border-radius:50%;animation:pulse-ring 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse-ring{0%{box-shadow:0 0 #0cf6}70%{box-shadow:0 0 0 20px #0cf0}to{box-shadow:0 0 #0cf0}}.btn-primary:hover{background:#22d3ee;box-shadow:0 0 16px #00b4d866}.btn-ghost{background:transparent;color:var(--text-sub);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-elevated);border-color:var(--border-hover);color:var(--text)}.btn-danger{background:#ef44441a;color:var(--s-rejected);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:#ef444433}.btn-icon{width:32px;height:32px;padding:0;justify-content:center;background:transparent;color:var(--text-muted);border:1px solid transparent;border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--bg-elevated);border-color:var(--border);color:var(--text)}.btn-sm{padding:4px 10px;font-size:11px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--t-med),box-shadow var(--t-med)}.card:hover{border-color:var(--border-hover);box-shadow:0 4px 24px #0006}.card-glow:hover{box-shadow:var(--glow-sm),0 4px 24px #0006}.stat-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.stat-chip-val{font-size:24px;font-weight:800;letter-spacing:-1px;line-height:1}.stat-chip-label{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge-not_started{background:#3341554d;color:#64748b}.badge-pending{background:var(--s-pending-bg);color:var(--s-pending)}.badge-working{background:#06b6d41f;color:#06b6d4}.badge-submitted{background:var(--s-submit-bg);color:var(--s-submit)}.badge-in_review{background:var(--s-review-bg);color:var(--s-review)}.badge-approved{background:var(--s-approved-bg);color:var(--s-approved)}.badge-revise_resubmit{background:var(--s-revise-bg);color:var(--s-revise)}.badge-rejected{background:var(--s-rejected-bg);color:var(--s-rejected)}.bic-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.bic-you{background:#00b4d81f;color:var(--bic-you)}.bic-pm{background:#a855f71f;color:var(--bic-pm)}.bic-gc{background:#3b82f61f;color:var(--bic-gc)}.bic-engineer{background:#14b8a61f;color:var(--bic-engineer)}.bic-architect{background:#6366f11f;color:var(--bic-architect)}.bic-vendor{background:#f59e0b1f;color:var(--bic-vendor)}.priority-chip{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:5px;font-size:10px;font-weight:800;letter-spacing:0}.priority-chip-high{background:#ef444426;color:var(--p-high)}.priority-chip-medium{background:#f59e0b26;color:var(--p-medium)}.priority-chip-low{background:#47556933;color:var(--p-low)}.priority-bar{width:3px;border-radius:2px;flex-shrink:0;align-self:stretch}.priority-high{background:var(--p-high);box-shadow:0 0 6px #ef444480}.priority-medium{background:var(--p-medium)}.priority-low{background:var(--p-low)}.dash-stats{display:flex;gap:16px;margin-bottom:28px;flex-wrap:wrap}.dash-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;min-width:120px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all var(--t-med);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity var(--t-med)}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--glow-sm),var(--shadow);transform:translateY(-1px)}.project-card:hover:before{opacity:1}.project-card-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:3px}.project-card-meta{font-size:11px;color:var(--text-muted);margin-bottom:16px}.project-card-stats{display:flex;gap:12px}.project-mini-stat{display:flex;flex-direction:column;gap:1px}.project-mini-stat-val{font-size:18px;font-weight:800;letter-spacing:-.5px}.project-mini-stat-label{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.progress-bar-wrap{height:3px;background:var(--bg-elevated);border-radius:2px;overflow:hidden;margin-bottom:16px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#22d3ee);border-radius:2px;transition:width .6s ease}.project-layout{display:flex;height:calc(100vh - 52px);overflow:hidden}.spec-sidebar{width:var(--sidebar-w);height:100%;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.spec-sidebar-header{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.spec-sidebar-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:10px}.spec-list{flex:1;overflow-y:auto;padding:8px}.spec-item{padding:9px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--t);display:flex;flex-direction:column;gap:2px}.spec-item:hover{background:var(--bg-elevated)}.spec-item.active{background:var(--accent-dim);border:1px solid var(--border-hover)}.spec-item-code{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.5px}.spec-item-title{font-size:11px;color:var(--text-sub);line-height:1.3}.spec-item.active .spec-item-title{color:var(--text)}.spec-count{font-size:9px;color:var(--text-muted);margin-top:1px}.submittal-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.submittal-main-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;background:var(--bg-surface)}.submittal-main-title{font-size:13px;font-weight:700;color:var(--text);flex:1}.table-wrap{flex:1;overflow-y:auto}table.submittal-table{width:100%;border-collapse:collapse;font-size:12px}.submittal-table thead th{padding:10px 12px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);background:var(--bg-base);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:10}.submittal-table tbody tr{border-bottom:1px solid rgba(30,70,120,.3);cursor:pointer;transition:background var(--t)}.submittal-table tbody tr:hover{background:var(--bg-elevated)}.submittal-table tbody tr.selected{background:var(--accent-dim);border-color:#00b4d833}.submittal-table tbody tr.row-approved{background:#10b9810a}.submittal-table tbody tr.row-approved:hover{background:#10b98114}.submittal-table tbody tr.row-approved.selected{background:#10b9811a;border-color:#10b98140}.submittal-table tbody tr.om-sub-row{background:#10b98105;border-bottom:1px solid rgba(30,70,120,.2);cursor:default}.submittal-table tbody tr.om-sub-row:hover{background:#10b9810d}.submittal-table td{padding:11px 12px;vertical-align:middle}.td-priority{width:4px;padding:0}.td-name{font-size:12px;font-weight:500;color:var(--text);max-width:280px}.td-name-sub{font-size:10px;color:var(--text-muted);margin-top:1px}.td-date{font-size:11px;color:var(--text-sub);white-space:nowrap}.td-date.overdue{color:var(--s-rejected);font-weight:600}.td-round{font-size:11px;color:var(--text-sub);text-align:center}.section-group-header{background:var(--bg-base);padding:8px 12px}.section-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);opacity:.8}.row-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--t)}tr:hover .row-actions{opacity:1}.empty-state{text-align:center;padding:64px 24px;color:var(--text-muted)}.empty-state-icon{width:56px;height:56px;background:var(--bg-elevated);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.empty-state-title{font-size:15px;font-weight:700;color:var(--text-sub);margin-bottom:6px}.empty-state-sub{font-size:12px;line-height:1.6;max-width:320px;margin:0 auto}.detail-panel{width:var(--panel-w);height:100%;background:var(--bg-surface);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transform:translate(100%);transition:transform var(--t-med);position:relative;overflow:hidden}.detail-panel.open{transform:translate(0)}.detail-panel-header{padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.detail-panel-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:10px}.detail-panel-body{flex:1;overflow-y:auto;display:block}.detail-section{padding:14px 16px;border-bottom:1px solid var(--border)}.detail-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:10px}.field-row{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.field-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.field-select,.field-input,.field-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:12px;padding:7px 10px;outline:none;transition:border-color var(--t);width:100%}.field-select:focus,.field-input:focus,.field-textarea:focus{border-color:var(--border-active)}.field-textarea{resize:vertical;min-height:60px;line-height:1.5}.field-select option{background:var(--bg-overlay)}.field-row-2{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.activity-feed{height:250px;max-height:250px;overflow-y:auto;overflow-x:hidden;padding:12px 16px;display:flex;flex-direction:column;gap:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-deep);margin-bottom:10px}.activity-entry{display:flex;flex-direction:column;gap:2px}.activity-meta{display:flex;align-items:center;gap:6px}.activity-author{font-size:11px;font-weight:700;color:var(--text-accent)}.activity-time{font-size:10px;color:var(--text-muted)}.activity-msg{font-size:13px;color:var(--text);line-height:1.6;padding-left:0;white-space:pre-wrap}.activity-divider{display:flex;align-items:center;gap:8px;margin:4px 0}.activity-divider-line{flex:1;height:1px;background:var(--border)}.activity-divider-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.activity-add{flex-shrink:0;padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:flex-end}.activity-add textarea{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:12px;padding:8px 10px;outline:none;resize:none;line-height:1.5;min-height:38px;max-height:100px;transition:border-color var(--t)}.activity-add textarea:focus{border-color:var(--border-active)}.activity-add textarea::-moz-placeholder{color:var(--text-muted)}.activity-add textarea::placeholder{color:var(--text-muted)}.attachment-list{display:flex;flex-direction:column;gap:6px}.attachment-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--t)}.attachment-item:hover{border-color:var(--border-hover)}.attachment-name{flex:1;font-size:11px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-zone{border:1px dashed var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;cursor:pointer;transition:all var(--t);font-size:11px;color:var(--text-muted)}.upload-zone:hover{border-color:var(--border-hover);background:var(--accent-dim);color:var(--text-accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal{background:var(--bg-modal);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:460px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:16px;font-weight:800;color:var(--text)}.modal-body{display:flex;flex-direction:column;gap:14px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:11px;font-weight:600;color:var(--text-sub)}.form-required{color:var(--s-revise);margin-left:2px}.form-input,.form-select,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:13px;padding:9px 12px;outline:none;transition:border-color var(--t);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-active);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder{color:var(--text-muted)}.form-select option{background:var(--bg-overlay)}.form-textarea{resize:vertical;min-height:80px;line-height:1.6}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.settings-section-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:14px}.contact-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px}.contact-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.contact-name{font-size:12px;font-weight:600;color:var(--text)}.contact-meta{font-size:11px;color:var(--text-muted)}@keyframes pulse-subtle{0%{transform:scale(1);box-shadow:0 0 #f59e0b66}70%{transform:scale(1.05);box-shadow:0 0 0 10px #f59e0b00}to{transform:scale(1);box-shadow:0 0 #f59e0b00}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-overlay) 50%,var(--bg-elevated) 75%);background-size:400% 100%;border-radius:4px;animation:shimmer 1.5s infinite}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--t);white-space:nowrap;font-family:var(--font)}.filter-chip:hover{background:var(--bg-elevated);color:var(--text);border-color:var(--border-hover)}.filter-chip.active{background:var(--accent-dim);color:var(--accent);border-color:var(--border-active)}.filter-chip-count{background:var(--bg-elevated);color:var(--text-muted);padding:0 5px;border-radius:10px;font-size:10px;font-weight:700}.filter-chip.active .filter-chip-count{background:#00b4d826;color:var(--accent)}.filter-chip-approved.active{color:var(--s-approved);border-color:#10b98166;background:#10b98114}.filter-chip-in_review.active{color:var(--s-review);border-color:#f59e0b66;background:#f59e0b14}.filter-chip-submitted.active{color:var(--s-submit);border-color:#3b82f666;background:#3b82f614}.filter-chip-working.active{color:#06b6d4;border-color:#06b6d466;background:#06b6d414}.filter-chip-revise_resubmit.active{color:var(--s-revise);border-color:#f9731666;background:#f9731614}.filter-chip-rejected.active{color:var(--s-rejected);border-color:#ef444466;background:#ef444414}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-overlay);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@keyframes spin{to{transform:rotate(360deg)}}.animate-in{animation:slideUp .2s ease}@media print{.nav-rail,.top-bar,.row-actions,.filter-chip,.search-wrap,.btn,.detail-panel-overlay,.detail-panel,.btn-icon{display:none!important}.app-container,.main-content,.project-layout,.submittal-main,.table-wrap{display:block!important;margin:0!important;padding:0!important;background:#fff!important;color:#000!important;height:auto!important;overflow:visible!important}body,#root{background:#fff!important}.submittal-table{width:100%!important;border-collapse:collapse!important;color:#000!important;background:#fff!important;margin-top:20px}.submittal-table th,.submittal-table td{border:1px solid #cbd5e1!important;color:#000!important;padding:8px!important;background:transparent!important}.status-badge{border:1px solid #94a3b8!important;color:#000!important;background:transparent!important;padding:2px 6px!important}}.user-switcher{width:44px;display:flex;flex-direction:column;align-items:center;gap:4px;background:transparent;border:none;cursor:pointer;padding:8px 0;transition:transform var(--t);margin-bottom:8px}.user-switcher:hover{transform:scale(1.05)}.user-avatar{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 0 10px #0000004d}.tag-pm{background:linear-gradient(135deg,#a855f7,#7e22ce);border-color:#a855f7}.tag-gc{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-color:#3b82f6}.tag-arch{background:linear-gradient(135deg,#6366f1,#4338ca);border-color:#6366f1}.tag-eng{background:linear-gradient(135deg,#14b8a6,#0f766e);border-color:#14b8a6}.tag-vendor{background:linear-gradient(135deg,#f59e0b,#b45309);border-color:#f59e0b}.user-label{font-size:8px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.spec-hub{display:flex;flex-direction:column;height:100%;background:var(--bg-base)}.spec-dropzone{margin:32px auto;width:100%;max-width:600px;height:200px;border:2px dashed var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all var(--t-med);background:var(--bg-surface)}.spec-dropzone:hover{border-color:var(--accent);background:var(--accent-dim);box-shadow:var(--glow-sm)}.spec-dropzone-icon{width:48px;height:48px;color:var(--accent);opacity:.6}.spec-discovery-grid{display:grid;grid-template-columns:320px 1fr;flex:1;overflow:hidden;border-top:1px solid var(--border)}.spec-section-list{background:var(--bg-surface);border-right:1px solid var(--border);overflow-y:auto;padding:16px}.spec-wizard-step{margin-bottom:24px}.checkbox-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t)}.checkbox-item:hover{background:var(--bg-elevated)}.checkbox-item input{accent-color:var(--accent);width:14px;height:14px}.div-header{font-size:10px;font-weight:700;color:var(--accent);margin:16px 0 8px 4px;text-transform:uppercase;letter-spacing:1px}.role-pill{font-size:8px;font-weight:800;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;background:#ffffff0d;color:var(--text-muted);border:1px solid rgba(255,255,255,.1)}.role-pill-pm{background:#a855f726;color:#c084fc;border-color:#a855f733}.role-pill-gc{background:#3b82f626;color:#60a5fa;border-color:#3b82f633}.role-pill-arch{background:#6366f126;color:#818cf8;border-color:#6366f133}.role-pill-eng{background:#14b8a626;color:#2dd4bf;border-color:#14b8a633}.role-pill-vendor{background:#f59e0b26;color:#fbbf24;border-color:#f59e0b33}.role-pill-super{background:#ec489926;color:#f472b6;border-color:#ec489933}.role-pill-system{background:#6b728026;color:#9ca3af;border-color:#6b728033}.tag-pm{background:var(--bic-pm);color:#fff}.tag-gc{background:var(--bic-gc);color:#fff}.tag-arch{background:var(--bic-architect);color:#fff}.tag-eng{background:var(--bic-engineer);color:#fff}.tag-vendor{background:var(--bic-vendor);color:#fff}.tag-super{background:#ec4899;color:#fff}.activity-author-name{font-size:11px;font-weight:600;color:var(--text)}.activity-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.activity-entry{padding:12px;background:var(--bg-surface);border-radius:12px;margin-bottom:8px;border:1px solid var(--border)}.activity-time{font-size:10px;color:var(--text-dim)}.sparkle-icon{color:var(--accent);filter:drop-shadow(0 0 5px var(--accent-glow));animation:sparkle-pulse 2s infinite ease-in-out}@keyframes sparkle-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1) rotate(10deg)}}.ai-shimmer{position:relative;overflow:hidden}.ai-shimmer:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(14,165,233,.1),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.ai-populated{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent-dim)!important;animation:field-pop .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes field-pop{0%{transform:scale(.98);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 768px){:root{--nav-w: 0px;--panel-w: 100vw}.app-shell{flex-direction:column-reverse;height:100dvh}.nav-rail{width:100vw;height:calc(65px + env(safe-area-inset-bottom,20px));flex-direction:row;border-right:none;border-top:1px solid var(--border);padding:0 16px;padding-bottom:env(safe-area-inset-bottom,20px);justify-content:space-around;z-index:999;flex-shrink:0}.nav-logo,.nav-spacer,.nav-tooltip,.nav-divider{display:none!important}.command-center{flex-direction:row!important;width:auto!important;padding-bottom:0!important;gap:8px!important}.main-stage{flex:1;height:0}.stage-body{padding:16px!important}.top-bar{padding:env(safe-area-inset-top,10px) 16px 0 16px!important;height:calc(56px + env(safe-area-inset-top,10px))!important}.dash-stats{flex-direction:column;gap:12px}.projects-grid{grid-template-columns:1fr;gap:12px}.project-layout{flex-direction:column;height:calc(100vh - 121px)}.spec-sidebar{width:100%;height:140px;border-right:none;border-bottom:1px solid var(--border);flex-shrink:0}.spec-list{display:flex;flex-direction:row;overflow-x:auto;padding:12px;gap:8px}.spec-item{min-width:180px;height:100%;justify-content:center;border:1px solid var(--border)}.table-wrap{width:100%;overflow-x:auto;touch-action:pan-x pan-y;overscroll-behavior-x:contain;overscroll-behavior-y:contain}.submittal-table{min-width:800px}.detail-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;transform:translateY(100%);width:100vw;height:100vh;height:100dvh;border-left:none;padding-bottom:env(safe-area-inset-bottom,20px)}.detail-panel.open{transform:translateY(0)}.detail-panel-header{padding-top:calc(14px + env(safe-area-inset-top,10px))!important}.detail-panel-content{padding:16px 16px 80px}.floating-chat-container{display:none!important}input,textarea,select,.field-input,.field-select,.field-textarea{font-size:16px!important}.form-grid-2{grid-template-columns:1fr;gap:12px}.modal{width:95%!important;margin:10px;padding:20px!important}.search-wrap{min-width:0!important;width:100%!important}.top-bar-controls{flex-direction:column;align-items:flex-end;gap:8px}}
