.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-4)}.kpi-card{background:var(--surface-elevated);border:1px solid var(--line);border-radius:11px;box-shadow:0 1px 3px #1b17140a;padding:var(--sp-4);border-left:4px solid var(--ink-faint);position:relative;transition:transform .12s ease,box-shadow .12s ease}.kpi-card:hover{box-shadow:0 2px 6px #1b171414}.kpi-card.success{border-left-color:var(--success)}.kpi-card.warning{border-left-color:var(--warn)}.kpi-card.info{border-left-color:var(--accent)}.kpi-card.danger{border-left-color:var(--danger)}.kpi-label{font-family:var(--font-mono);font-size:var(--fs-caption);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);font-weight:600}.kpi-value{font-family:var(--font-display);font-variation-settings:"opsz" 72,"SOFT" 30;font-size:clamp(22px,2.4vw,var(--fs-display));font-weight:500;color:var(--ink);margin-top:var(--sp-1);letter-spacing:-.022em;font-feature-settings:"tnum" 1;line-height:1.05}.kpi-meta{font-size:var(--fs-caption);color:var(--ink-faint);margin-top:var(--sp-1)}@media(max-width:640px){.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--sp-2)}.kpi-card{padding:var(--sp-3)}.kpi-value{font-size:18.5px}}.modal-overlay{position:fixed;inset:0;background:#1b17146b;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:var(--sp-4);animation:modalFadeIn .32s cubic-bezier(.16,1,.3,1)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface-elevated);border:1px solid var(--line);width:100%;max-width:560px;max-height:calc(100vh - 2rem);overflow-y:auto;box-shadow:0 25px 50px -12px #1b171438,0 4px 12px #1b171414;animation:modalSlideUp .32s cubic-bezier(.16,1,.3,1);position:relative}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent 8%,rgba(96,165,250,.55) 50%,transparent 92%);pointer-events:none;z-index:2;border-radius:11px 11px 0 0}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-sm{max-width:420px}.modal-sm .modal-body{min-height:146px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-lg .modal-body{min-height:331px}.modal-xl{max-width:960px}.modal-xl .modal-body{min-height:479px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid rgba(96,165,250,.18);background:#1e2a44;position:sticky;top:0;z-index:1;overflow:hidden;--ink: #E2E8F0;--ink-2: #CBD5E1;--ink-muted: #94A3B8;--line: rgba(96, 165, 250, .2)}.modal-header:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(to right,rgba(96,165,250,.07) 1px,transparent 1px),linear-gradient(to bottom,rgba(96,165,250,.07) 1px,transparent 1px);background-size:24px 24px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);opacity:.85}.modal-header>*{position:relative;z-index:1}.modal-title-group{display:flex;flex-direction:column;align-items:flex-start;gap:var(--sp-1);min-width:0}.modal-eyebrow{font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);line-height:1}.modal-header h3{font-family:var(--font-display);font-variation-settings:"opsz" 36,"SOFT" 50;font-size:var(--fs-subhead);font-weight:500;letter-spacing:-.015em;color:var(--ink);margin:0;display:flex;align-items:center;gap:var(--sp-2);line-height:1.15}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink-muted);line-height:1;padding:.25rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}.close-btn:hover{background:#ffffff14;color:var(--ink);box-shadow:0 0 0 2px #ffffff1f}.close-btn:focus-visible{outline:none;background:#ffffff14;color:var(--ink);box-shadow:0 0 0 2px #60a5fa8c}.modal-overlay .modal-header .modal-header-actions{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.modal-overlay .modal-header .btn-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;border-radius:50%;cursor:pointer;color:var(--ink-muted);transition:background .15s,color .15s,box-shadow .15s;padding:0}.modal-overlay .modal-header .btn-icon svg{width:18px;height:18px}.modal-overlay .modal-header .btn-icon:hover{background:#ffffff14;color:var(--ink);box-shadow:0 0 0 2px #ffffff1f}.modal-overlay .modal-header .btn-icon:focus-visible{outline:none;background:#ffffff14;color:var(--ink);box-shadow:0 0 0 2px #60a5fa8c}.modal-overlay .modal-header .btn-icon:disabled{opacity:.45;cursor:not-allowed}.modal-overlay .modal-header .btn,.modal-overlay .modal-header .btn.btn-sm,.modal-overlay .modal-header .btn.btn-outline,.modal-overlay .modal-header .btn.btn-secondary{display:inline-flex;align-items:center;gap:var(--sp-2);padding:.45rem .9rem;font-family:var(--font-body);font-size:.8125rem;font-weight:500;letter-spacing:.01em;background:#ffffff0f;border:1px solid rgba(96,165,250,.32);color:var(--ink-2);border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}.modal-overlay .modal-header .btn svg{width:14px;height:14px;flex-shrink:0}.modal-overlay .modal-header .btn:hover{background:#ffffff1f;border-color:#60a5fa8c;color:var(--ink)}.modal-overlay .modal-header .btn:focus-visible{outline:none;box-shadow:0 0 0 2px #60a5fa8c}.modal-overlay .modal-header .btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay .modal-header label{color:var(--ink-2);font-size:.8125rem}.modal-overlay .modal-header input[type=checkbox],.modal-overlay .modal-header input[type=radio]{accent-color:var(--accent);cursor:pointer}.modal-overlay .modal-header h3 .rev-badge,.modal-overlay .modal-header h3 .badge,.modal-overlay .modal-header h3 .source-pill{box-shadow:inset 0 0 0 1px #ffffff26}.modal-body{padding:var(--sp-4) var(--sp-5);min-height:240px}.modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);background:var(--surface-sunken);border-radius:0 0 11px 11px;position:sticky;bottom:0;flex-wrap:wrap;box-shadow:inset 0 1px 0 var(--line)}.modal-footer .btn-primary{padding-inline:var(--sp-5);min-width:128px;font-weight:500;letter-spacing:.01em}.modal-footer .btn-secondary{min-width:84px}@media(max-width:767px){.modal-overlay{align-items:stretch;padding:0;overflow:hidden}.modal-content{max-width:100%!important;max-height:100vh!important;height:100vh;margin:0;border-radius:0;display:flex;flex-direction:column;overflow:hidden}.modal-sm,.modal-md,.modal-lg,.modal-xl{max-width:100%!important}.modal-header{flex-shrink:0;border-radius:0;padding:var(--sp-3) var(--sp-4)}.modal-header h3{font-size:15.5px}.modal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--sp-4)}.modal-footer{flex-shrink:0;border-radius:0;padding:var(--sp-3) var(--sp-4)}.modal-content input,.modal-content select,.modal-content textarea{font-size:16px!important}}.modal-overlay .modal-content .section-hint,.modal-overlay .modal-content .modal-section-hint{font-size:.8125rem;color:var(--ink-muted);margin:0 0 var(--sp-4);line-height:1.45}.modal-overlay .modal-content .section-hint strong,.modal-overlay .modal-content .modal-section-hint strong{color:var(--ink)}.modal-overlay .modal-content .form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-bottom:var(--sp-3)}.modal-overlay .modal-content .form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3);margin-bottom:var(--sp-3)}@media(max-width:639px){.modal-overlay .form-grid-2,.modal-overlay .form-grid-3{grid-template-columns:1fr}}.modal-overlay .modal-content .form-group{display:flex;flex-direction:column;margin-bottom:var(--sp-3)}.modal-overlay .modal-content .form-group>label,.modal-overlay .modal-content .form-group>.form-label{font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:600;color:var(--ink-muted);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.08em}.modal-overlay .modal-content .form-group input,.modal-overlay .modal-content .form-group select,.modal-overlay .modal-content .form-group textarea{padding:.5rem .625rem;border:1px solid var(--line);border-radius:6px;font-size:var(--fs-body);background:var(--surface-elevated);color:var(--ink);font-family:var(--font-body);width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.modal-overlay .modal-content .form-group input:focus,.modal-overlay .modal-content .form-group select:focus,.modal-overlay .modal-content .form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.modal-overlay .modal-content .form-group input:disabled,.modal-overlay .modal-content .form-group select:disabled,.modal-overlay .modal-content .form-group textarea:disabled{background:var(--surface-base);color:var(--ink-muted);cursor:not-allowed}.modal-overlay .modal-content .form-group input::placeholder,.modal-overlay .modal-content .form-group textarea::placeholder{color:var(--ink-faint)}.modal-overlay .modal-content .form-hint{font-size:var(--fs-caption);color:var(--ink-faint);margin-top:var(--sp-1);line-height:1.4}.modal-overlay .modal-content .req,.modal-overlay .modal-content .field-required,.modal-overlay .modal-content .required{color:var(--danger);margin-left:2px}.modal-overlay .modal-content .attrs-fieldset,.modal-overlay .modal-content .modal-fieldset,.modal-overlay .modal-content fieldset{border:1px solid var(--line);border-radius:6px;padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-3);background:var(--surface-base)}.modal-overlay .modal-content .attrs-fieldset legend,.modal-overlay .modal-content .modal-fieldset legend,.modal-overlay .modal-content fieldset legend{padding:0 var(--sp-2);font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em}.modal-overlay .modal-content .modal-body label.inline-label,.modal-overlay .modal-content .modal-body .check-label{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-body);color:var(--ink-2)}*{margin:0;padding:0;box-sizing:border-box}:root{--font-display: "Fraunces", Georgia, serif;--font-body: "Geist", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--surface-base: #FFFFFF;--surface-raised: #FBF8F1;--surface-elevated: #FFFFFF;--surface-sunken: #ffffff;--surface-hover: rgba(27, 23, 20, .045);--ink: #1B1714;--ink-2: #3A2F27;--ink-muted: #7A6A5A;--ink-faint: #B0A294;--line: #ececec;--line-strong: #b8b7b5;--line-soft: rgba(27, 23, 20, .06);--accent: #2563eb;--accent-deep: #1d4ed8;--accent-soft: #DCE6FA;--success: #0F7A5A;--success-soft: #D4E8DD;--warn: #B57500;--warn-soft: #F0E0BD;--danger: #B14C28;--danger-soft: #F3D9CB;--info: #235E8C;--info-soft: #DAE8F2;--sidebar-w-expanded: 264px;--sidebar-w-collapsed: 72px;--sidebar-w: var(--sidebar-w-expanded);--header-height: 60px;--shadow-card: 0 1px 3px rgba(27, 23, 20, .05);--shadow-modal: 0 20px 60px rgba(27, 23, 20, .18);--shadow-focus: 0 0 0 3px rgba(37, 99, 235, .18);--radius-sm: 4px;--radius: 6px;--radius-lg: 10px;--radius-pill: 9999px;--fs-display: 30px;--fs-subhead: 18.5px;--fs-body: 13.5px;--fs-caption: 11px;--fs-micro: 7px;--sp-1: 4px;--sp-2: 7px;--sp-3: 11px;--sp-4: 18px;--sp-5: 29px;--sp-6: 47px;--primary: var(--accent);--primary-dark: var(--accent-deep);--primary-light: var(--accent-soft);--primary-text: var(--accent-deep);--success-light: var(--success-soft);--success-text: var(--success);--warning: var(--warn);--warning-light: var(--warn-soft);--warning-text: var(--warn);--danger-light: var(--danger-soft);--danger-text: var(--danger);--orange: var(--danger);--orange-light: var(--danger-soft);--orange-text: var(--danger);--gray-50: var(--surface-base);--gray-100: var(--surface-sunken);--gray-200: var(--line);--gray-300: var(--line-strong);--gray-400: var(--ink-faint);--gray-500: var(--ink-muted);--gray-700: var(--ink-2);--gray-900: var(--ink);--bg-page: var(--surface-base);--bg-card: var(--surface-raised);--bg-card-hover: var(--surface-base);--bg-input: var(--surface-elevated);--bg-table-header: var(--surface-base);--bg-modal-overlay: rgba(27, 23, 20, .45);--border-color: var(--line);--border-light: var(--line-soft);--border-input: var(--line);--border-radius: var(--radius);--border-radius-sm: var(--radius-sm);--border-radius-lg: var(--radius-lg);--border-radius-pill: var(--radius-pill);--text-primary: var(--ink);--text-secondary: var(--ink-muted);--text-muted: var(--ink-faint);--text-label: var(--ink-muted);--sidebar-width: var(--sidebar-w);--input-padding: .625rem .75rem;--input-font-size: .875rem;--btn-padding: .5rem 1rem;--btn-font-size: .875rem;--table-font-size: .875rem;--label-font-size: .75rem}html{font-size:16px;overflow-x:hidden;color-scheme:light}body{font-family:var(--font-body);background:var(--surface-base);color:var(--ink);line-height:1.5;min-height:100vh;overflow-x:hidden;width:100%;max-width:100vw;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.container{max-width:1280px;margin:0 auto;padding:0 1rem}.page,.dashboard{max-width:100%;overflow-x:hidden}.card{background:var(--surface-elevated);border:1px solid var(--line);border-radius:11px;box-shadow:0 1px 3px #1b17140a;padding:var(--sp-5);margin-bottom:var(--sp-4)}@media(max-width:639px){.card{padding:var(--sp-4);border-radius:7px}}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--line);flex-wrap:wrap;gap:var(--sp-3)}.card-title-group{display:flex;flex-direction:column;align-items:flex-start;gap:var(--sp-1);min-width:0}.card-eyebrow{font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);line-height:1}.card-title{font-family:var(--font-display);font-variation-settings:"opsz" 36,"SOFT" 50;font-size:var(--fs-subhead);font-weight:500;letter-spacing:-.015em;line-height:1.15;color:var(--ink);margin:0}@media(max-width:479px){.card-title{font-size:16px}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:6px;border:none;cursor:pointer;transition:all .15s;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media(max-width:767px){.btn{padding:.625rem 1.125rem;min-height:44px}}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface-raised);color:var(--ink-2);border:1px solid var(--line)}.btn-secondary:hover{background:var(--surface-base);border-color:var(--line-strong)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:.375rem}.form-input,.form-select{width:100%;padding:.5rem .75rem;font-size:1rem;border:1px solid var(--line);border-radius:6px;transition:border-color .15s,box-shadow .15s;background:var(--surface-elevated);color:var(--ink);font-family:var(--font-body);-webkit-appearance:none;appearance:none}@media(max-width:767px){.form-input,.form-select{padding:.75rem;min-height:48px}}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%237A6A5A' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;color:var(--ink);color-scheme:light}select,.form-select{color:var(--ink)!important;color-scheme:light!important;-webkit-appearance:none}select option,.form-select option{color:var(--ink)!important;background-color:var(--surface-elevated)!important;-webkit-text-fill-color:var(--ink)!important}.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;position:relative}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid var(--gray-200);white-space:nowrap}table td,table th{text-align:left!important}@media(max-width:767px){.table th,.table td{padding:.5rem .375rem;font-size:.75rem}.table th:first-child,.table td:first-child{position:sticky;left:0;z-index:2;background:var(--surface-elevated)}.table thead th:first-child{background:var(--surface-base);z-index:3}.table tbody tr:hover td:first-child{background:var(--surface-base)}.table-wrapper:after{content:"";position:absolute;top:0;right:0;bottom:0;width:18px;background:linear-gradient(to right,transparent,rgba(15,23,42,.08));pointer-events:none;z-index:4}}.table th{font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);background:var(--surface-base);border-bottom:1px solid var(--line-strong);position:sticky;top:0;z-index:1;font-family:var(--font-mono)}.th-unit{font-size:.55rem;font-weight:400;color:var(--ink-muted);text-transform:lowercase;letter-spacing:normal}.table tbody tr:hover{background:var(--surface-base)}.table td{color:var(--ink)}@media(max-width:639px){.table-responsive-cards{min-width:auto}.table-responsive-cards thead{display:none}.table-responsive-cards tbody tr{display:block;margin-bottom:1rem;padding:1rem;background:var(--surface-elevated);border:1px solid var(--line);border-radius:8px;box-shadow:0 1px 2px #1b17140a}.table-responsive-cards tbody td{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--gray-100)}.table-responsive-cards tbody td:last-child{border-bottom:none}.table-responsive-cards tbody td:before{content:attr(data-label);font-weight:600;color:var(--gray-500);font-size:.75rem;text-transform:uppercase}}.badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px;white-space:nowrap}.badge-success{background:var(--success-soft);color:var(--success)}.badge-warning{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-info{background:var(--info-soft);color:var(--info)}.badge-secondary{background:var(--surface-base);color:var(--ink-2);border:1px solid var(--line)}.grid{display:grid;gap:1rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}@media(min-width:480px){.grid-2,.grid-4{grid-template-columns:repeat(2,1fr)}}@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3,.grid-4{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a}@media(max-width:479px){.stat-card{padding:1rem}}.stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-900)}@media(max-width:479px){.stat-value{font-size:1.25rem}}.stat-label{font-size:.875rem;color:var(--gray-500);margin-top:.25rem}@media(max-width:479px){.stat-label{font-size:.75rem}}.text-center{text-align:center}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-gray{color:var(--gray-500)}.text-muted{color:var(--gray-500);font-size:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.flex-wrap{flex-wrap:wrap}.hide-mobile{display:block}.show-mobile{display:none}@media(max-width:767px){.hide-mobile{display:none!important}.show-mobile{display:block!important}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#1e293b;z-index:1001;padding:0 1rem;align-items:center;justify-content:space-between}@media(max-width:767px){.mobile-header{display:flex}}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:.5rem;gap:5px;-webkit-tap-highlight-color:transparent}.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;transition:opacity .3s ease}.sidebar-overlay.active{display:block;opacity:1}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.75rem}.page-header h1{font-size:1.5rem;font-weight:700;margin:0;flex:1;min-width:0}.page-header .btn{flex-shrink:0}@media(max-width:767px){.page-header h1{font-size:1.25rem}.page-header .btn{padding:.5rem .75rem;min-height:40px;font-size:.8125rem}}@media(max-width:479px){.page-header h1{font-size:1.125rem}}.empty-state{padding:2rem;text-align:center;color:var(--gray-500)}.filter-section{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-section .form-group{margin-bottom:0;min-width:150px;flex:1}@media(max-width:639px){.filter-section{flex-direction:column;align-items:stretch}.filter-section .form-group{width:100%}}.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.scroll-x::-webkit-scrollbar{height:6px}.scroll-x::-webkit-scrollbar-track{background:var(--gray-100);border-radius:3px}.scroll-x::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}.action-btn{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:.5rem;border-radius:6px;border:none;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@supports (padding: max(0px)){.safe-area-bottom{padding-bottom:max(1rem,env(safe-area-inset-bottom))}.safe-area-top{padding-top:max(1rem,env(safe-area-inset-top))}}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-text.sm{height:.75rem}.skeleton-text.lg{height:1.5rem}.skeleton-text:last-child{margin-bottom:0}.skeleton-circle{border-radius:50%}.skeleton-table-row{display:flex;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--gray-100)}.skeleton-table-row>*{flex:1}.skeleton-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 1px 3px #0000001a}.skeleton-stat-card{background:#fff;border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px #0000001a}.skeleton-stat-card .skeleton-value{height:1.5rem;width:60%;margin-bottom:.5rem}.skeleton-stat-card .skeleton-label{height:.875rem;width:80%}.skeleton-row{display:table-row}.skeleton-row td{padding:.75rem 1rem;border-bottom:1px solid var(--gray-100)}.skeleton-row .skeleton-cell{height:1rem;min-width:60px}@media print{html,body,app-root,.app-layout,.main-content{margin:0!important;padding:0!important;min-height:0!important;height:auto!important;overflow:visible!important;background:#fff!important}.sidebar,.mobile-header,.hamburger,.btn,app-mobile-header,app-toast,app-confirm-dialog{display:none!important}.app-layout>nav{display:none!important}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.page-header h1{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-primary)}.header-left{display:flex;align-items:baseline;gap:.75rem}.total-count{font-size:var(--input-font-size);color:var(--text-secondary);font-weight:500}.stat-pills{display:flex;gap:.5rem;flex-wrap:wrap}.pill{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:var(--border-radius-pill);background:var(--gray-100);color:var(--gray-500)}.pill-blue{background:var(--primary-light);color:var(--primary-text)}.pill-green{background:var(--success-light);color:var(--success-text)}.pill-orange{background:var(--orange-light);color:var(--orange-text)}.tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:2px solid var(--border-color);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.5rem 1rem;font-size:var(--input-font-size);font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;white-space:nowrap}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.filters-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.filter-select{min-width:150px;max-width:200px;padding:var(--input-padding);border:1px solid var(--border-input);border-radius:var(--border-radius);font-size:var(--input-font-size);background:var(--bg-input);color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.search-box{flex:1;min-width:200px;max-width:300px;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:var(--input-padding);padding-left:2.5rem;border:1px solid var(--border-input);border-radius:var(--border-radius);font-size:var(--input-font-size);background:var(--bg-input);color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.clear-btn{position:absolute;right:.5rem;background:none;border:none;font-size:1.125rem;color:var(--text-muted);cursor:pointer;padding:.25rem;line-height:1}.clear-btn:hover{color:var(--text-primary)}.badge-draft{background:var(--gray-100);color:var(--gray-500)}.badge-received,.badge-delivered{background:var(--success-light);color:var(--success-text)}.badge-cancelled{background:var(--danger-light);color:var(--danger-text)}.badge-info{background:var(--primary-light);color:var(--primary-text)}.badge-production,.badge-dispatched{background:var(--orange-light);color:var(--orange-text)}.badge-partial{background:var(--warning-light);color:var(--warning-text)}.font-mono{font-family:Monaco,Menlo,monospace;font-size:.75rem}.font-bold{font-weight:600}.text-right{text-align:right}.text-muted{color:var(--text-muted);font-size:.75rem}.actions-cell{display:flex;gap:4px;flex-wrap:wrap;align-items:center;justify-content:flex-start}table th:has(+th+th):last-child,.table th.actions-col,.data-table th.actions-col{text-align:left}.btn-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;border-radius:4px;cursor:pointer;color:#6b7280;transition:all .15s ease}.btn-icon:hover{background:#f3f4f6;color:#111827}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon svg{width:16px;height:16px;display:block}.btn-icon-danger{color:#dc2626}.btn-icon-danger:hover{background:#fee2e2;color:#991b1b}.modal-header-actions{display:flex;align-items:center;gap:.25rem}.row-menu-wrap{position:relative;display:inline-block}.row-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 16px #0000001f;z-index:50;padding:.25rem;display:flex;flex-direction:column}.row-menu-item{background:none;border:none;text-align:left;padding:.5rem .75rem;font-size:.8125rem;color:#374151;cursor:pointer;border-radius:6px;white-space:nowrap}.row-menu-item:hover{background:#f3f4f6}.row-menu-item.row-menu-danger{color:#b91c1c}.row-menu-item.row-menu-danger:hover{background:#fef2f2}.row-menu-divider{height:1px;background:#e5e7eb;margin:.25rem}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.btn-danger-outline{background:none;border:1px solid var(--danger);color:var(--danger);padding:.25rem .5rem;font-size:.75rem;border-radius:var(--border-radius-sm);cursor:pointer}.btn-danger-outline:hover{background:var(--danger-light)}.section-title{font-size:.8rem;font-weight:600;color:var(--gray-700);margin:0 0 .5rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state h3{font-size:1rem;color:var(--text-secondary);margin:0 0 .5rem}.empty-state p{font-size:var(--input-font-size);margin:0}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.skeleton-text{height:1rem;width:100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.attr-tag{font-size:.65rem;font-weight:500;background:var(--gray-100);color:var(--gray-500);padding:1px 6px;border-radius:3px;border:1px solid var(--border-color)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;font-size:var(--input-font-size);background:var(--gray-50);padding:.75rem;border-radius:var(--border-radius-sm)}.total-row{display:flex;justify-content:space-between;font-size:var(--input-font-size);padding:.25rem 0}.total-row.discount{color:var(--danger)}.total-row.grand-total{font-size:1rem;font-weight:700;padding-top:.5rem;border-top:2px solid var(--text-primary);margin-top:.25rem}.form-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.form-grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}@media(max-width:768px){.form-grid-4{grid-template-columns:repeat(2,1fr)}}.field-error,input.field-error,select.field-error,textarea.field-error{border:2px solid #ef4444!important;box-shadow:0 0 0 3px #ef444433!important;background-color:#fef2f2!important}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--line)}.page-header>.header-content,.header-title-block{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.page-title{font-family:var(--font-display);font-weight:500;font-size:clamp(22px,2.6vw,var(--fs-display));line-height:1.05;letter-spacing:-.022em;color:var(--ink);margin:0;font-variation-settings:"opsz" 48,"SOFT" 40}.page-subtitle{font-family:var(--font-body);font-size:var(--fs-body);color:var(--ink-muted);margin:var(--sp-2) 0 0;letter-spacing:-.005em}.eyebrow{font-family:var(--font-mono);font-size:var(--fs-caption);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-muted)}.section-title{font-family:var(--font-body);font-weight:600;font-size:var(--fs-subhead);color:var(--ink);margin:0 0 var(--sp-3);letter-spacing:-.012em;line-height:1.15}.filters-bar{display:flex;gap:var(--sp-3);align-items:center;flex-wrap:wrap;padding:var(--sp-3) var(--sp-4);background:var(--surface-elevated);border:1px solid var(--line);border-radius:11px;margin-bottom:var(--sp-4)}.page-spec-eyebrow{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:var(--sp-2);line-height:1}.page-spec-eyebrow:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px #2563eb29;flex-shrink:0}.page-spec-eyebrow .seq{color:var(--accent);font-weight:600}.empty-state-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-6) var(--sp-5);min-height:320px;background:var(--surface-elevated);border:1px solid var(--line);border-radius:11px;position:relative;overflow:hidden;margin-bottom:var(--sp-4)}.empty-state-card:before{content:"";position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,var(--line) 1px,transparent 1px),linear-gradient(to bottom,var(--line) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse at center,black 18%,transparent 72%);-webkit-mask-image:radial-gradient(ellipse at center,black 18%,transparent 72%);opacity:.5}.empty-state-card>*{position:relative;z-index:1}.empty-state-icon{width:56px;height:56px;border-radius:50%;background:var(--surface-base);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:var(--sp-4);box-shadow:0 0 0 4px #2563eb14}.empty-state-icon svg{width:26px;height:26px;stroke-width:1.7}.empty-state-eyebrow{font-family:var(--font-mono);font-size:var(--fs-caption);font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:var(--sp-3);display:inline-flex;align-items:center;gap:var(--sp-2)}.empty-state-eyebrow .seq{color:var(--accent);font-weight:600}.empty-state-title{font-family:var(--font-display);font-variation-settings:"opsz" 36,"SOFT" 50;font-size:var(--fs-subhead);font-weight:500;letter-spacing:-.015em;color:var(--ink);margin:0 0 var(--sp-2);line-height:1.15}.empty-state-sub{font-size:var(--fs-body);color:var(--ink-muted);margin:0 0 var(--sp-5);max-width:400px;line-height:1.5}.empty-state-actions{display:flex;flex-wrap:wrap;gap:var(--sp-3);justify-content:center}.empty-state-actions .btn-primary{padding-inline:var(--sp-5);min-width:144px;font-weight:500}@media(max-width:639px){.empty-state-card{padding:var(--sp-5) var(--sp-4);min-height:260px}.empty-state-icon{width:48px;height:48px}.empty-state-icon svg{width:22px;height:22px}}.kpi-grid.kpi-hero-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.kpi-card.hero{background:linear-gradient(135deg,rgba(37,99,235,.08) 0%,transparent 60%),var(--surface-elevated);border-left-width:0;border-top:3px solid var(--accent);padding-top:calc(var(--sp-4) - 3px)}.kpi-card.hero .kpi-label{color:var(--accent-deep);font-weight:700}.kpi-card.hero .kpi-value{font-size:clamp(28px,3.2vw,36px);color:var(--ink);background:linear-gradient(180deg,var(--ink),var(--ink-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.kpi-card.hero .kpi-meta{color:var(--ink-muted);font-family:var(--font-mono);letter-spacing:.04em}.mono,.font-mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1}.display{font-family:var(--font-display);font-variation-settings:"opsz" 96,"SOFT" 40;letter-spacing:-.025em}.text-accent{color:var(--accent)}.text-muted{color:var(--ink-muted)}.text-success{color:var(--success)}.text-warn{color:var(--warn)}.text-danger{color:var(--danger)}.divider{height:1px;background:var(--line);margin:1rem 0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}a:not([class]){color:var(--accent);text-decoration:none}a:not([class]):hover{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}@media(max-width:1023px){.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.625rem}.filters-bar{gap:.5rem}.page-header{align-items:flex-start}}@media(max-width:767px){.page-header{flex-direction:column;align-items:stretch;gap:.625rem}.page-header h1{font-size:clamp(20px,6vw,24px)!important}.page-header .header-left,.page-header .header-content,.page-header .header-actions{width:100%}.page-header .header-actions{display:flex;flex-wrap:wrap;gap:.5rem}.page-header .header-actions>.btn{flex:1 1 auto;min-width:0}.filters-bar,.filters-row{flex-direction:column;align-items:stretch;gap:.5rem}.filters-bar>*,.filters-row>*{width:100%;max-width:100%!important}.filter-select,.filter-input,.form-select.filter-select{min-width:0!important;max-width:100%!important;width:100%!important}.search-box{width:100%!important;max-width:100%!important;display:flex;gap:.375rem}.search-box .form-input{flex:1;min-width:0}.stat-pills{flex-wrap:wrap;gap:.375rem}.pill{font-size:.66rem;padding:.18rem .45rem}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.kpi-card{padding:.75rem}.kpi-value{font-size:1.25rem}.kpi-label{font-size:.62rem}@media(max-width:419px){.kpi-grid{grid-template-columns:1fr}}.card{padding:1rem .875rem;border-radius:8px}.card-header{padding-bottom:.75rem;margin-bottom:.75rem}.card>table,.card>*>table,.modal-body>table,.modal-body>*>table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.card>table>thead,.card>table>tbody,.card>table>tfoot,.card>*>table>thead,.card>*>table>tbody,.card>*>table>tfoot{display:table;width:100%;table-layout:auto}.card>table th,.card>*>table th,.table th{position:relative!important;top:auto!important}.card table th,.card table td{padding:.5rem;font-size:.78rem;white-space:nowrap}.form-grid,.form-grid-2,.form-grid-3,.form-row,.form-row-2,.form-row-3{grid-template-columns:1fr!important}.tabs,.tabs-bar{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;flex-wrap:nowrap}.tabs::-webkit-scrollbar,.tabs-bar::-webkit-scrollbar{display:none}.pagination{flex-wrap:wrap;gap:.5rem;font-size:.8125rem}.active-filter-row{width:100%;justify-content:flex-start}}@media(max-width:419px){.page-header h1{font-size:20px!important}.card{padding:.75rem .625rem}.btn{padding:.5rem .75rem;font-size:.8125rem}}
