*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.relative{position:relative}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.border{border-width:1px}.bg-navy-900{--tw-bg-opacity: 1;background-color:rgb(5 12 24 / var(--tw-bg-opacity, 1))}.lowercase{text-transform:lowercase}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--blue-500: #3B82F6;--blue-600: #2563EB;--green-500: #10B981;--orange-500: #F59E0B;--red-500: #EF4444;--cyan-500: #06B6D4;--gray-900: #111827;--gray-800: #1F2937;--gray-700: #374151;--gray-500: #6B7280;--gray-300: #D1D5DB;--gray-100: #F3F4F6;--bg: #F9FAFB;--bg2: #FFFFFF;--surface: #FFFFFF;--surface2: #F3F4F6;--surface3: #E5E7EB;--border: #E5E7EB;--border2: #D1D5DB;--text: #111827;--text2: #374151;--text3: #6B7280;--accent: #3B82F6;--accent2: #2563EB;--accent3: #10B981;--warn: #F59E0B;--danger: #EF4444;--cyan: #06B6D4;--sidebar-bg: #0B1220;--sidebar-bg2: #111827;--sidebar-text: #9CA3AF;--sidebar-text2: #E5E7EB;--sidebar-border: #1F2937;--sidebar-active-bg: var(--accent);--sidebar-w: 240px;--sidebar-collapsed-w: 72px;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--font-ui: "Inter", system-ui, sans-serif;--radius-sm: 6px;--radius: 10px;--radius-lg: 12px;--radius-xl: 16px;--shadow-card: 0 4px 12px rgba(0,0,0,.08);--shadow-dropdown: 0 10px 30px rgba(0,0,0,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-ui);font-size:13px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);display:flex;flex-direction:column;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);transition:width .25s ease;flex-shrink:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-w)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:12px 14px;min-height:52px;border-bottom:1px solid var(--sidebar-border);position:relative}.brand-logo{width:30px;height:30px;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent),var(--cyan));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0;color:#fff}.brand-info{display:flex;flex-direction:column;min-width:0;flex:1}.brand-text{font-size:13px;font-weight:700;letter-spacing:-.3px;white-space:nowrap;color:#fff}.brand-user{font-size:10px;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.brand-version{font-size:9px;color:var(--text3);opacity:.6;font-weight:500;margin-left:2px}.text-accent{color:var(--accent)}.sidebar-toggle{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-text);cursor:pointer;transition:all .15s;flex-shrink:0}.sidebar-toggle:hover{color:#fff;background:#ffffff14}.sidebar.collapsed .brand-info{display:none}.sidebar.collapsed .sidebar-brand{justify-content:center;gap:0;padding:12px 8px}.sidebar.collapsed .sidebar-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%)}.sidebar-nav{flex:1;overflow-y:auto;padding:6px 10px}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:3px}.nav-section{margin-bottom:10px}.nav-section-title{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--sidebar-text);padding:6px 12px 4px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius);font-size:12px;color:var(--sidebar-text);text-decoration:none;transition:all .15s;cursor:pointer;white-space:nowrap;margin-bottom:2px}.nav-item:hover{color:var(--sidebar-text2);background:#ffffff0f}.nav-item.active{color:#fff;background:var(--sidebar-active-bg);font-weight:600}.nav-icon{flex-shrink:0;opacity:.75}.nav-item.active .nav-icon{opacity:1}.nav-label{overflow:hidden;text-overflow:ellipsis}.nav-badge{margin-left:auto;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:10px;font-weight:700;background:#ffffff26;color:var(--sidebar-text2);padding:0 6px}.nav-item.active .nav-badge{background:#ffffff40;color:#fff}.sidebar.collapsed .nav-section-title{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px 0}.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 0;margin-bottom:8px}.sidebar-user-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border:none;border-radius:var(--radius);background:transparent;cursor:pointer;transition:background .15s;text-align:left}.sidebar-user-btn:hover{background:#ffffff0f}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:var(--sidebar-bg2);display:flex;align-items:center;justify-content:center;color:var(--sidebar-text2);font-weight:700;font-size:14px;flex-shrink:0}.sidebar-user-info{min-width:0;flex:1}.sidebar-user-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--sidebar-text)}.user-dropdown{position:absolute;bottom:calc(100% + 8px);left:8px;right:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-dropdown);z-index:100;padding:4px;animation:dropUp .15s ease}@keyframes dropUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{display:flex;align-items:center;gap:10px;padding:10px 12px}.user-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.user-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text2);font-size:13px;font-family:var(--font-ui);cursor:pointer;transition:background .12s}.user-dropdown-item:hover{background:var(--surface2);color:var(--text)}.user-dropdown-danger{color:var(--danger)}.user-dropdown-danger:hover{background:#fef2f2;color:var(--danger)}.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-user-btn>svg{display:none}.sidebar-footer{position:relative}.main-content{flex:1;overflow-y:auto;background:var(--bg)}.page-content{padding:16px 20px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.page-header h1{font-size:18px;font-weight:800;display:flex;align-items:center;gap:6px;color:var(--text)}.page-subtitle{font-size:11px;color:var(--text3);margin-top:2px}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.search-box input{padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12px;outline:none;width:280px;transition:border-color .15s}.search-box input:focus{border-color:var(--accent)}.search-box input::-moz-placeholder{color:var(--text3)}.search-box input::placeholder{color:var(--text3)}.filter-chips{display:flex;gap:6px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid var(--border);border-radius:16px;background:var(--surface);color:var(--text3);font-size:11px;font-weight:500;font-family:var(--font-ui);cursor:pointer;transition:all .15s;white-space:nowrap}.chip:hover{border-color:var(--accent);color:var(--text)}.chip.active{background:#0066ff14;border-color:var(--accent);color:var(--accent);font-weight:600}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}thead{background:var(--surface2)}th{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--text3);text-transform:uppercase;padding:7px 10px;text-align:left;border-bottom:1px solid var(--border)}td{padding:7px 10px;font-size:12px;border-bottom:1px solid var(--border);color:var(--text2)}tbody tr{transition:background .12s}tbody tr:hover{background:#00000005}.td-mono{font-family:var(--font-mono);font-size:11px}.td-name{font-weight:600;color:var(--text)}.text-center{text-align:center}.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;color:var(--text3);font-size:13px;border:1px dashed var(--border2);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%)}.table-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;color:var(--text3);opacity:.6}.table-empty-title{font-size:15px;font-weight:700;color:var(--text2);margin-bottom:4px}.table-empty-subtitle{font-size:12px;color:var(--text3);max-width:280px;line-height:1.5}.skeleton-table{display:flex;flex-direction:column;gap:2px}.skeleton-row{height:42px;background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.badge-active{background:#e6f9f0;color:#059642;border:1px solid #b2e8cf}.badge-done{background:#e6f0ff;color:#0055d4;border:1px solid #b2d4ff}.badge-draft{background:#f0f2f5;color:#6b7a90;border:1px solid #d8dde4}.badge-warn,.badge-pending{background:#fff8e6;color:#b87800;border:1px solid #fce4a8}.badge-inprogress{background:#e6f0ff;color:#0055d4;border:1px solid #b2d4ff}.badge-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;font-size:12.5px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#0052cc;box-shadow:0 4px 16px #06f3}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}.btn-ghost:hover{color:var(--text);background:#0000000a}.btn-danger{background:#fef2f2;color:var(--danger);border-color:#fecaca}.btn-danger:hover{background:#fee2e2}.btn-success{background:#e6f9f0;color:var(--accent3);border-color:#b2e8cf}.btn-success:hover{background:#d1f5e2}.btn-sm{padding:4px 10px;font-size:11px}.btn-icon{padding:4px 6px}.btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:12px;width:100%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #00000080}.modal-lg{max-width:680px}.modal-xl{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:15px;font-weight:700}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text3);cursor:pointer;border-radius:6px;font-size:14px;transition:all .15s}.modal-close:hover{color:var(--text);background:#ffffff0f}.modal-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 16px}.tab{padding:10px 14px;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:all .15s}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-body{padding:16px 20px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.full-width{grid-column:span 2}.form-label{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.3px}.form-input,.form-select,.form-textarea{padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12.5px;outline:none;transition:border-color .15s;font-family:var(--font-ui)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-textarea{min-height:60px;resize:vertical}.form-select{cursor:pointer}option{background:var(--surface)}.combobox-trigger{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:border-color .15s;min-height:36px}.combobox-trigger:hover{border-color:var(--border2)}.combobox-trigger.active{border-color:var(--accent)}.combobox-trigger.disabled{opacity:.5;cursor:not-allowed}.combobox-value{font-size:12.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.combobox-value.placeholder{color:var(--text3)}.combobox-search{border:none;outline:none;background:transparent;font-size:12.5px;color:var(--text);font-family:var(--font-ui);width:100%;flex:1}.combobox-search::-moz-placeholder{color:var(--text3)}.combobox-search::placeholder{color:var(--text3)}.combobox-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;color:var(--text3)}.combobox-clear{cursor:pointer;border-radius:50%;padding:1px;transition:color .12s}.combobox-clear:hover{color:var(--danger)}.combobox-chevron{transition:transform .15s}.combobox-chevron.rotated{transform:rotate(180deg)}.combobox-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:4px;max-height:220px;overflow-y:auto;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-dropdown);padding:4px;animation:dropDown .12s ease}@keyframes dropDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.combobox-option{padding:7px 10px;font-size:12.5px;color:var(--text2);border-radius:5px;cursor:pointer;transition:background .1s}.combobox-option:hover{background:var(--surface2);color:var(--text)}.combobox-option.selected{background:#3b82f614;color:var(--accent);font-weight:600}.combobox-empty{padding:12px 10px;text-align:center;font-size:12px;color:var(--text3)}.combobox-create{display:flex;align-items:center;gap:6px;padding:8px 10px;font-size:12px;color:var(--accent);font-weight:600;border-top:1px solid var(--border);margin-top:4px;cursor:pointer;border-radius:5px;transition:background .1s}.combobox-create:hover{background:#3b82f60f}.combobox-loading{display:flex;align-items:center;gap:8px;padding:12px 10px;font-size:12px;color:var(--text3)}.detail-label{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.5px;margin-bottom:2px}.detail-value{font-size:13px;color:var(--text)}.detail-value.mono{font-family:var(--font-mono);font-size:12px}.section-title{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text3);margin-bottom:8px}.section-title{font-size:10px;font-weight:700;letter-spacing:.8px;color:var(--text3);text-transform:uppercase;margin-bottom:10px;margin-top:4px}.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.contact-card-mini{background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:9px 11px}.contact-role{font-size:9px;font-family:var(--font-mono);color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.contact-name{font-weight:700;margin-top:2px;font-size:12.5px;color:var(--text)}.contact-info{font-size:11px;color:var(--text3);margin-top:2px}.contact-card{background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:10px 12px;margin-bottom:6px}.contact-card-header{display:flex;justify-content:space-between;align-items:flex-start}.contact-add-form{margin-top:12px;padding:12px;background:var(--bg);border:1px dashed var(--border2);border-radius:8px}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;font-size:12px;color:var(--text3)}.pagination button{padding:5px 14px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;font-size:12px;transition:all .15s}.pagination button:hover:not(:disabled){color:var(--text);background:var(--surface2)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}.stat-card{padding:18px 20px;border-radius:10px;border:1px solid var(--border);background:linear-gradient(135deg,var(--card-color, var(--surface)) 0%,transparent 100%);position:relative;overflow:hidden}.stat-label{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--text3);text-transform:uppercase}.stat-value{font-size:28px;font-weight:800;margin-top:6px;font-family:var(--font-mono);color:var(--text)}.stat-sub{font-size:11px;color:var(--text3);margin-top:2px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.card-header{font-size:13px;font-weight:700;padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}.card-body{padding:14px 18px}.card-body-empty{padding:28px 18px;text-align:center;color:var(--text3);font-size:12px}.crm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.crm-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}.crm-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000014;border-color:var(--accent2)}.toast-container{position:fixed;top:16px;right:16px;z-index:10000;display:flex;flex-direction:column;gap:6px}.toast{padding:10px 16px;border-radius:8px;font-size:12px;font-weight:500;animation:slideIn .25s ease;max-width:360px}.toast-success{background:#e6f9f0;color:#059642;border:1px solid #b2e8cf}.toast-error{background:#fef2f2;color:#e53e3e;border:1px solid #fecaca}.toast-warn{background:#fff8e6;color:#b87800;border:1px solid #fce4a8}.toast-info{background:#e6f0ff;color:#0055d4;border:1px solid #b2d4ff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.login-page{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0b1220 url(/login-bg.png) center/cover no-repeat;position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 40%,rgba(59,130,246,.08),transparent 60%);pointer-events:none}.login-card{position:relative;width:100%;max-width:400px;background:#fffffff7;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:36px 32px 28px;box-shadow:0 24px 80px #0006,0 4px 16px #0003}.login-brand{margin-bottom:0}.login-brand-row{display:flex;align-items:center;gap:12px}.login-brand-name{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px}.login-brand-sub{font-size:11px;color:var(--text3);margin-top:1px}.login-divider{height:1px;background:var(--border);margin:20px 0}.login-brand p{font-size:12px;color:var(--text3);margin-top:4px}.login-error{padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:var(--danger);font-size:12px;margin-bottom:12px}.login-submit{width:100%;margin-top:20px;padding:10px 16px;justify-content:center}.login-quick{display:flex;align-items:center;gap:6px;margin-top:16px;padding-top:14px;border-top:1px dashed var(--border);flex-wrap:wrap}.login-quick-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.login-quick-btn{padding:4px 12px;font-size:11px;font-weight:600;border-radius:6px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .12s}.login-quick-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.login-footer{position:absolute;bottom:20px;font-size:11px;color:#ffffff4d;letter-spacing:.2px}.text-muted{color:var(--text3)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mb-16{margin-bottom:16px}.grid-2{display:grid;grid-template-columns:1fr 1fr}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.detail-field-label{font-size:10px;font-weight:600;letter-spacing:.5px;color:var(--text3);margin-bottom:2px}.detail-field-value{font-size:13px;color:var(--text)}.divider{border:none;border-top:1px solid var(--border);margin:14px 0}.font-mono{font-family:JetBrains Mono,monospace;font-size:12px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px}.tab{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border:none;background:transparent;color:var(--text3);font-size:12px;font-weight:500;font-family:var(--font-ui);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.clickable-row{cursor:pointer}.clickable-row:hover{background:#0066ff08}.skeleton-table{display:flex;flex-direction:column;gap:8px}.skeleton-row{height:44px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;border-radius:8px;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.sidebar{width:var(--sidebar-collapsed-w)}.sidebar .nav-section-title{display:none}.sidebar .nav-item{justify-content:center;padding:10px 0}.sidebar .nav-label,.sidebar .nav-badge,.sidebar .sidebar-user{display:none}.page-content{padding:16px}.page-header{flex-direction:column;gap:12px}.form-grid,.detail-grid,.dashboard-grid{grid-template-columns:1fr}.stat-grid,.dash-stats{grid-template-columns:1fr 1fr}.dash-grid-3,.contacts-grid{grid-template-columns:1fr}}.dash-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.dash-title{font-size:28px;font-weight:700;color:var(--text)}.dash-date{font-size:13px;color:var(--text3);margin-top:4px}.dash-header-actions{display:flex;gap:8px;align-items:center}.dash-search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text3)}.dash-search input{border:none;outline:none;background:transparent;color:var(--text);font-size:13px;font-family:var(--font-ui);width:140px}.dash-search input::-moz-placeholder{color:var(--text3)}.dash-search input::placeholder{color:var(--text3)}.dash-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:20px}.dash-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;transition:box-shadow .2s}.dash-stat-card:hover{box-shadow:var(--shadow-card)}.dash-stat-top{display:flex;align-items:flex-start;gap:12px}.dash-stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-stat-info{flex:1;min-width:0}.dash-stat-label{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text3);text-transform:uppercase;margin-bottom:4px}.dash-stat-value{font-size:22px;font-weight:700;color:var(--text);font-family:var(--font-mono);line-height:1.2}.dash-stat-more{border:none;background:none;color:var(--text3);cursor:pointer;padding:2px;border-radius:4px}.dash-stat-more:hover{color:var(--text)}.dash-stat-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--surface2);font-size:11px;color:var(--text3)}.trend-up{color:#10b981;font-weight:600}.trend-down{color:#ef4444;font-weight:600}.dash-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.dash-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border)}.dash-card-title{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--text);text-transform:uppercase}.dash-card-body{padding:16px 20px}.dash-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--accent);text-decoration:none;cursor:pointer}.dash-link:hover{text-decoration:underline}.dash-select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:12px;color:var(--text2);background:var(--surface);cursor:pointer;outline:none;font-family:var(--font-ui)}.donut-placeholder{width:160px;height:160px;border-radius:50%;background:conic-gradient(#3b82f6,#3b82f6 135deg,#f59e0b 135deg,#f59e0b 225deg,#10b981 225deg,#10b981 304deg,#ef4444 304deg,#ef4444 338deg,#6b7280 338deg,#6b7280 360deg);margin:0 auto 16px;position:relative}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100px;height:100px;border-radius:50%;background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-value{font-size:28px;font-weight:700;color:var(--text);font-family:var(--font-mono)}.donut-label{font-size:10px;color:var(--text3)}.donut-legend{text-align:left;display:inline-flex;flex-direction:column;gap:6px;margin-top:4px}.legend-item{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-table{width:100%;border-collapse:collapse}.dash-table th{font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text3);text-transform:uppercase;padding:10px 16px;text-align:left;border-bottom:1px solid var(--border)}.dash-table td{padding:10px 16px;font-size:12px;border-bottom:1px solid var(--surface2);color:var(--text2)}.dash-table tbody tr:hover{background:var(--surface2)}.dash-status-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px;vertical-align:middle}.activity-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--surface2)}.activity-item:last-child{border-bottom:none}.activity-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-type{font-size:11px;font-weight:700;color:var(--text);margin-right:8px}.activity-text{font-size:12px;color:var(--text2)}.activity-time{font-size:10px;color:var(--text3);white-space:nowrap}.chart-placeholder{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:8px}.chart-bar{flex:1;background:var(--surface2);border-radius:4px 4px 0 0;transition:background .2s}.chart-bar.active{background:var(--accent)}.chart-bar:hover{background:var(--accent);opacity:.8}.quick-reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.qr-item{text-align:center;padding:12px 8px;border:1px solid var(--border);border-radius:var(--radius)}.qr-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;margin-bottom:6px}.qr-label{font-size:11px;color:var(--text3);margin-bottom:2px}.qr-value{font-size:18px;font-weight:700;color:var(--text);font-family:var(--font-mono)}#global-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--cyan));z-index:99999;pointer-events:none;opacity:0;transition:none}#global-progress.loading{opacity:1;width:85%;transition:width 8s cubic-bezier(.1,.5,.3,1)}#global-progress.done{opacity:0;width:100%;transition:width .2s ease,opacity .3s ease .15s}.toast-container{position:fixed;top:16px;right:16px;z-index:99998;display:flex;flex-direction:column;gap:8px;max-width:380px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:0 8px 24px #0000001f;font-size:12.5px;color:var(--text);pointer-events:auto;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0}.toast-msg{flex:1;line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;border-radius:4px;display:flex;transition:color .15s}.toast-close:hover{color:var(--text)}.toast-success{border-left:3px solid var(--accent3)}.toast-success .toast-icon{color:var(--accent3)}.toast-error{border-left:3px solid var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-left:3px solid var(--warn)}.toast-warning .toast-icon{color:var(--warn)}.toast-info{border-left:3px solid var(--accent)}.toast-info .toast-icon{color:var(--accent)}.profile-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:flex-start}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 20px;display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--cyan));display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:1px}.profile-card-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}.profile-card-role{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--accent);font-weight:600;background:#3b82f614;padding:3px 12px;border-radius:12px;margin-bottom:16px}.profile-card-meta{width:100%;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.profile-meta-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text3)}.profile-meta-item svg{flex-shrink:0}.profile-card-status{padding-top:12px;border-top:1px solid var(--border);width:100%;display:flex;justify-content:center}.profile-card-status .badge{gap:4px}.profile-content{min-width:0}.profile-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--surface2);padding:4px;border-radius:var(--radius);width:-moz-fit-content;width:fit-content}.profile-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:none;border-radius:7px;background:transparent;color:var(--text3);font-size:12.5px;font-weight:600;font-family:var(--font-ui);cursor:pointer;transition:all .15s}.profile-tab:hover{color:var(--text)}.profile-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.profile-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.profile-form-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.profile-form-subtitle{font-size:12px;color:var(--text3)}.password-input-wrap{position:relative;display:flex;align-items:center}.password-field{width:100%;padding-right:36px!important}.password-toggle{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;background:transparent;color:var(--text3);cursor:pointer;transition:color .12s}.password-toggle:hover{color:var(--text)}@media(max-width:768px){.profile-layout{grid-template-columns:1fr}.profile-card{flex-direction:row;text-align:left;gap:16px;padding:16px}.profile-avatar-lg{width:52px;height:52px;font-size:18px;margin-bottom:0}.profile-card-meta{margin-bottom:0}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-header h1{font-size:20px;font-weight:700;display:flex;align-items:center;gap:8px;margin:0}.page-subtitle{font-size:12px;color:var(--text3);margin-top:4px}.page-header-actions{display:flex;gap:8px;align-items:center}.filter-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filter-select{max-width:200px;font-size:12px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text3);text-align:center}.empty-state svg{opacity:.3;margin-bottom:12px}.empty-state h3{font-size:16px;font-weight:600;color:var(--text1);margin:0 0 6px}.empty-state p{font-size:13px;margin:0}.empty-state-sm{display:flex;flex-direction:column;align-items:center;padding:30px 12px;color:var(--text3)}.empty-state-sm svg{opacity:.25;margin-bottom:8px}.empty-state-sm p{font-size:12px;margin:0}.skeleton-table{display:flex;flex-direction:column;gap:8px;padding:20px 0}.skeleton-row{height:40px;background:var(--bg2);border-radius:6px;animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;border:1px solid}.status-done{color:#10b981;background:#10b98115;border-color:#10b98130}.status-draft{color:#6b7280;background:#6b728015;border-color:#6b728030}.status-pending{color:#f59e0b;background:#f59e0b15;border-color:#f59e0b30}.status-overdue{color:#ef4444;background:#ef444415;border-color:#ef444430}.td-mono{font-family:var(--font-mono);font-size:12px}.td-bold{font-weight:600}.td-date{font-size:12px;color:var(--text2)}.td-muted{color:var(--text3);font-size:12px}.td-amount{font-family:var(--font-mono);font-weight:600;text-align:right}.row-overdue{background:#ef444408}.action-btns{display:flex;gap:4px}.btn-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text2);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--bg2);color:var(--text1)}.btn-icon.danger:hover{color:#ef4444;border-color:#ef444440;background:#ef444410}.btn-icon.success:hover{color:#10b981;border-color:#10b98140;background:#10b98110}.overdue-icon{color:#ef4444;margin-left:4px;vertical-align:middle}.route-cell{display:flex;align-items:center;gap:4px;font-size:12px}.route-arrow{color:var(--text3);font-size:11px}.milestone-mini{display:flex;gap:2px;align-items:center}.milestone-dot{width:14px;height:14px;display:flex;align-items:center;justify-content:center;border-radius:50%}.milestone-dot.done{color:#10b981}.milestone-dot.current{color:#3b82f6}.milestone-dot.pending{color:var(--text3);opacity:.4}.job-detail{padding:8px 0}.job-section{margin-bottom:16px}.section-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:12px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}.milestone-timeline{display:flex;gap:0;overflow-x:auto;padding:8px 0}.timeline-step{display:flex;flex-direction:column;align-items:center;position:relative;min-width:70px;flex:1}.timeline-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);background:var(--bg1);z-index:1;transition:all .2s}.timeline-step.done .timeline-dot{border-color:#10b981;color:#10b981;background:#10b98115}.timeline-step.current .timeline-dot{border-color:#3b82f6;color:#3b82f6;background:#3b82f615;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 #3b82f64d}50%{box-shadow:0 0 0 6px #3b82f600}}.timeline-label{font-size:10px;color:var(--text3);margin-top:6px;text-align:center;white-space:nowrap}.timeline-step.done .timeline-label{color:#10b981}.timeline-step.current .timeline-label{color:#3b82f6;font-weight:600}.timeline-line{position:absolute;top:12px;left:50%;right:-50%;height:2px;background:var(--border)}.timeline-step.done .timeline-line{background:#10b981}.detail-value{font-size:13px;color:var(--text1);padding:6px 0}.pl-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.pl-card{padding:16px;border-radius:8px;border:1px solid var(--border);text-align:center}.pl-label{font-size:11px;color:var(--text3);margin-bottom:4px;text-transform:uppercase}.pl-value{font-size:20px;font-weight:700;font-family:var(--font-mono)}.pl-card.revenue .pl-value{color:#3b82f6}.pl-card.cost .pl-value{color:#ef4444}.pl-card.profit .pl-value{color:#10b981}.pl-card.margin .pl-value{color:#f59e0b}.doc-type-grid{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.doc-type-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg1);cursor:pointer;transition:all .15s;min-width:80px;font-size:11px;color:var(--text2)}.doc-type-card:hover{border-color:var(--accent);background:var(--accent-soft)}.doc-type-card.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);font-weight:600;box-shadow:0 0 0 1px var(--accent)}.doc-type-icon{font-size:20px}.doc-type-label{white-space:nowrap}.doc-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px}.fob-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}@media(max-width:900px){.fob-layout{grid-template-columns:1fr}}.fob-results{display:grid;gap:12px}.fob-result-item{padding:16px;border-radius:8px;border:1px solid var(--border)}.fob-result-item.highlight{border-color:var(--accent);background:var(--accent-soft)}.fob-result-label{font-size:11px;text-transform:uppercase;color:var(--text3);margin-bottom:4px;letter-spacing:.5px}.fob-result-value{font-size:22px;font-weight:700;font-family:var(--font-mono);color:var(--text1)}.fob-result-item.highlight .fob-result-value{color:var(--accent)}.fob-result-formula{font-size:10px;color:var(--text3);margin-top:4px;font-family:var(--font-mono)}.margin-ref-grid{display:flex;gap:8px}.margin-ref-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;border-radius:8px;border:1px solid var(--border);background:var(--bg1);cursor:pointer;transition:all .15s;font-size:12px;color:var(--text2)}.margin-ref-btn strong{font-size:16px;color:var(--text1)}.margin-ref-btn:hover{border-color:var(--accent)}.margin-ref-btn.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.margin-ref-btn.active strong{color:var(--accent)}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:900px){.report-grid{grid-template-columns:1fr}}.chart-note{font-size:11px;color:var(--text3);text-align:center;margin-top:8px;font-style:italic}.status-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.status-summary-card{text-align:center;padding:14px 8px;border-radius:8px;border:1px solid var(--border)}.ss-value{font-size:24px;font-weight:700;font-family:var(--font-mono);color:var(--text1)}.ss-label{font-size:11px;color:var(--text3);margin-top:2px}.status-summary-card.tier-a{border-color:#10b98130}.status-summary-card.tier-a .ss-value{color:#10b981}.status-summary-card.tier-b{border-color:#f59e0b30}.status-summary-card.tier-b .ss-value{color:#f59e0b}.status-summary-card.tier-c{border-color:#ef444430}.status-summary-card.tier-c .ss-value{color:#ef4444}.perm-table td{text-align:center}.perm-yes{color:#10b981;font-weight:700;font-size:14px}.perm-no{color:var(--text3);opacity:.4}.badge-pol{color:#3b82f6;background:#3b82f615;border-color:#3b82f630}.badge-pod{color:#f59e0b;background:#f59e0b15;border-color:#f59e0b30}.badge-both{color:#10b981;background:#10b98115;border-color:#10b98130}@media(max-width:768px){.page-header{flex-direction:column;gap:10px}.pl-summary{grid-template-columns:repeat(2,1fr)}.doc-type-grid{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px}.milestone-timeline{padding-bottom:12px}.fob-layout,.report-grid{grid-template-columns:1fr}.margin-ref-grid{flex-direction:column}}.pwa-install-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:12px 16px;animation:pwa-slide-up .4s ease-out}@keyframes pwa-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.pwa-install-content{max-width:600px;margin:0 auto;display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:12px;background:#0a1428eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(56,189,248,.25);box-shadow:0 -4px 24px #0000004d,0 0 0 1px #38bdf81a inset}.pwa-install-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,#0ea5e9,#6366f1);color:#fff;flex-shrink:0}.pwa-install-text{flex:1;min-width:0}.pwa-install-text strong{display:block;font-size:13px;font-weight:600;color:#f1f5f9;margin-bottom:2px}.pwa-install-text span{font-size:11px;color:#94a3b8;line-height:1.3}.pwa-install-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-sm{padding:6px 14px;font-size:12px;border-radius:8px}.pwa-install-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#64748b;cursor:pointer;border-radius:6px;transition:all .15s}.pwa-install-close:hover{color:#f1f5f9;background:#ffffff1a}@media(max-width:480px){.pwa-install-content{flex-wrap:wrap;gap:10px}.pwa-install-text span{display:none}}.pwa-sidebar-install{display:flex;align-items:center;gap:8px;width:calc(100% - 24px);margin:4px 12px 8px;padding:10px 12px;border-radius:8px;border:1px dashed rgba(56,189,248,.35);background:#38bdf80f;color:#38bdf8;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.pwa-sidebar-install:hover{background:#38bdf81f;border-color:#38bdf880;transform:translateY(-1px)}.pwa-sidebar-install svg{flex-shrink:0}@media print{.sidebar,.topbar,.page-content,.toast-container,#global-progress,.pwa-install-banner,.modal-close,.btn,button{display:none!important}.modal-overlay{position:static!important;background:none!important;padding:0!important}.modal{box-shadow:none!important;border:none!important;border-radius:0!important;max-width:100%!important;width:100%!important;margin:0!important;padding:20mm!important;background:#fff!important;color:#000!important}.modal-header{border-bottom:2px solid #333!important;padding-bottom:12px!important;margin-bottom:16px!important;color:#000!important;background:none!important}.modal-body{padding:0!important;color:#000!important}.detail-grid{color:#000!important}.detail-field-label{color:#666!important}.detail-field-value{color:#000!important}table{border-collapse:collapse!important;width:100%!important}th,td{border:1px solid #ccc!important;padding:6px 8px!important;color:#000!important;background:#fff!important}th{background:#f0f0f0!important;font-weight:600!important}.stat-card{background:#f8f8f8!important;border:1px solid #ddd!important;color:#000!important}.stat-label{color:#666!important}.stat-value{color:#000!important}.badge{border:1px solid #999!important;background:#eee!important;color:#333!important}@page{size:A4;margin:10mm}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
