:root{--bg: #eef2f1;--surface: #ffffff;--surface-2: #f6f9f8;--surface-3: #eef3f1;--border: #e7ecea;--border-strong: #dbe2df;--text: #141b18;--muted: #6a766f;--faint: #9aa6a0;--brand: #129a45;--brand-dark: #0c7a36;--brand-darker: #0a5f2b;--brand-light: #e7f6ed;--accent: #1379bd;--accent-dark: #0d5f96;--accent-light: #e8f2fa;--navy: #19294a;--navy-2: #122038;--navy-deep: #0d1829;--gold: #f3b62a;--gold-dark: #b9810b;--gold-light: #fdf3d6;--warn-bg: #fff8ec;--warn-border: #f5d79a;--warn-text: #8a5708;--danger: #e0413b;--danger-light: #fdeaea;--radius: 18px;--radius-md: 13px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(16, 26, 22, .05);--shadow: 0 1px 2px rgba(16, 26, 22, .04), 0 10px 28px -14px rgba(16, 26, 22, .18);--shadow-lg: 0 20px 48px -18px rgba(16, 26, 22, .28);--ring: 0 0 0 3.5px rgba(18, 154, 69, .16)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body,#root{height:100%;margin:0}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{scrollbar-width:thin;scrollbar-color:#c4cdc8 transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#cdd6d1;border-radius:99px;border:3px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:#b3bdb7;background-clip:content-box}.app{display:flex;min-height:100vh;position:relative}.app:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(820px 460px at 100% -8%,rgba(18,154,69,.07),transparent 60%),radial-gradient(680px 460px at -6% 4%,rgba(19,121,189,.06),transparent 55%)}.sidebar{width:252px;flex-shrink:0;z-index:2;background:var(--surface);border-right:1px solid var(--border);color:var(--muted);display:flex;flex-direction:column;padding:20px 16px;position:sticky;top:0;height:100vh}.brand{display:grid;place-items:center;padding:12px 8px 2px}.brand-logo{width:100%;max-width:124px;height:auto;display:block}.brand-sub{text-align:center;font-size:10.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--brand);margin:12px 0 22px}.nav-label{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:0 12px 10px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;color:var(--muted);text-decoration:none;font-weight:500;font-size:14px;transition:background .18s,color .18s,transform .05s}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item:active{transform:scale(.99)}.nav-item.active{background:linear-gradient(100deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;font-weight:600;box-shadow:0 8px 18px -8px #129a4580}.nav-icon{width:19px;height:19px;flex-shrink:0}.sidebar-foot{margin-top:auto;padding:16px 8px 4px;display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--faint);border-top:1px solid var(--border)}.foot-ver{color:var(--faint)}.main-wrap{flex:1;display:flex;flex-direction:column;min-width:0;position:relative;z-index:1}.topbar{height:64px;flex-shrink:0;background:#f7faf9cc;-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 34px;position:sticky;top:0;z-index:20}.topbar-title{font-size:16px;font-weight:700;letter-spacing:-.015em}.topbar-right{display:flex;align-items:center;gap:16px}.date-pill{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--muted);background:var(--surface);border:1px solid var(--border);padding:7px 13px;border-radius:999px;box-shadow:var(--shadow-sm)}.date-pill svg{width:15px;height:15px}.user-menu{position:relative;padding-left:16px;border-left:1px solid var(--border)}.user-chip{display:flex;align-items:center;gap:10px;background:transparent;border:none;padding:4px 6px;border-radius:10px;cursor:pointer}.user-chip:hover{background:var(--surface-2)}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 130%);color:#fff;font-weight:700;font-size:13px;box-shadow:var(--shadow-sm)}.user-meta{display:flex;flex-direction:column;line-height:1.2;align-items:flex-start}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--muted)}.chevron{width:16px;height:16px;color:var(--muted)}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);z-index:40;width:210px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;animation:modalIn .14s ease}.dropdown-item{display:block;width:100%;text-align:left;background:transparent;border:none;padding:9px 12px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text);text-decoration:none;cursor:pointer}.dropdown-item:hover{background:var(--surface-2)}.dropdown-item.active{color:var(--brand-dark);font-weight:700;background:var(--brand-light)}.dropdown-item.logout{color:var(--danger)}.dropdown-item.logout:hover{background:var(--danger-light)}.dropdown-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);padding:10px 12px 4px}.dropdown-divider{height:1px;background:var(--border);margin:6px 4px}.dropdown-header{padding:8px 12px 6px;display:flex;flex-direction:column;gap:2px}.dropdown-name{font-size:13px;font-weight:700;color:var(--text)}.dropdown-email{font-size:11px;color:var(--muted);word-break:break-all}.dropdown-readonly{padding:4px 12px 8px;font-size:13px;font-weight:600;color:var(--text)}.signin{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:24px;background:var(--bg)}.signin-logo{width:120px;height:auto;margin-bottom:8px}.signin h1{margin:0;font-size:22px;font-weight:800}.signin-btn{margin-top:18px;text-decoration:none;font-weight:600;font-size:14px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;padding:12px 22px;border-radius:10px;box-shadow:0 6px 16px -8px #0a733299}.signin-btn:hover{background:linear-gradient(180deg,var(--brand-dark),var(--brand-darker))}.content{flex:1;padding:32px 34px 64px;max-width:1340px;width:100%}.loading{padding:90px;text-align:center;color:var(--muted)}.page-head{margin-bottom:26px}.page-head h1{margin:0 0 6px;font-size:25px;font-weight:800;letter-spacing:-.025em}.page-head p{margin:0;color:var(--muted);font-size:14.5px;max-width:780px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 26px;margin-bottom:22px;animation:cardIn .4s cubic-bezier(.16,.84,.44,1) both}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.card h2{margin:0 0 18px;font-size:15.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:11px}.card h2:before{content:"";width:4px;height:17px;border-radius:3px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);flex-shrink:0}.card h3{margin:18px 0 10px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:stretch;margin-bottom:22px}.grid-2>.card{margin-bottom:0;display:flex;flex-direction:column}.card-fill{flex:1;display:flex;flex-direction:column}.info-note{margin-top:auto;display:flex;gap:13px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:15px 16px}.info-note .info-icon{width:36px;height:36px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(140deg,var(--brand-light),#d6f0e0);color:var(--brand-dark)}.info-note .info-icon svg{width:19px;height:19px}.info-note strong{display:block;font-size:13px;margin-bottom:4px;color:var(--text)}.info-note p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.55}.info-note b{color:var(--brand-dark);font-weight:700}.row{display:flex;gap:16px;flex-wrap:wrap}.row>*{flex:1;min-width:150px}label{display:block;font-weight:600;margin-bottom:7px;font-size:13px;color:var(--text)}.field{margin-bottom:18px}.field:last-child{margin-bottom:0}.hint{font-size:12.5px;color:var(--muted);font-weight:400;margin-top:6px;line-height:1.45}input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--border-strong);background:var(--surface-2);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);transition:border-color .16s,box-shadow .16s,background .16s}input:hover,select:hover,textarea:hover{border-color:var(--faint)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:var(--ring)}input[type=checkbox]{width:auto;accent-color:var(--brand)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236a766f' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}table input,table select{padding:8px 10px;border:1px solid var(--border);background:#fff;border-radius:8px}table input:hover,table select:hover{border-color:var(--border-strong)}table input:focus,table select:focus{background:#fff}table input::placeholder{color:var(--faint)}table td{vertical-align:middle}td.num input{width:86px;text-align:right;display:inline-block}td input[type=date],td input[type=month]{width:160px}table td:has(>button){width:1%;white-space:nowrap;text-align:right}table th:empty{width:1%}button{font:inherit;font-weight:600;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:10px 17px;border-radius:var(--radius-sm);transition:background .16s,border-color .16s,box-shadow .16s,transform .06s}button:hover{background:var(--surface-2);border-color:var(--faint)}button:active{transform:translateY(1px)}button.primary{background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%);border-color:var(--brand-dark);color:#fff;box-shadow:0 1px 2px #0a7a3659,0 8px 18px -10px #0a7a36b3}button.primary:hover{background:linear-gradient(180deg,var(--brand-dark) 0%,var(--brand-darker) 100%)}button.ghost{border-color:transparent;background:transparent;color:var(--accent);padding:6px 9px}button.ghost:hover{background:var(--accent-light)}button.danger{color:var(--danger);border-color:#f2cccb;background:var(--surface)}button.danger:hover{background:var(--danger-light);border-color:var(--danger)}button.sm{padding:7px 12px;font-size:12.5px;border-radius:8px}.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.segmented{display:inline-flex;border:1px solid var(--border-strong);border-radius:10px;overflow:hidden;background:var(--surface-2);padding:3px;gap:3px}.segmented button{border:none;border-radius:7px;background:transparent;color:var(--muted);padding:6px 15px;font-size:13px;box-shadow:none}.segmented button:hover{background:#0000000a}.segmented button.active{background:var(--surface);color:var(--brand-dark);box-shadow:var(--shadow-sm)}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;align-items:stretch}.kpi{display:flex;align-items:center;gap:15px;height:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:17px 19px;box-shadow:var(--shadow-sm)}.kpi-icon{width:48px;height:48px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(140deg,var(--brand-light),#d6f0e0);color:var(--brand-dark)}.kpi-icon svg{width:24px;height:24px}.kpi .v{font-size:27px;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--brand-darker)}.kpi .l{font-size:12px;color:var(--muted);margin-top:6px;font-weight:500}.kpi.alt .kpi-icon{background:linear-gradient(140deg,var(--accent-light),#d3e8f7);color:var(--accent-dark)}.kpi.alt .v{color:var(--accent-dark)}.summary-list{list-style:none;padding:0;margin:0}.summary-list li{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--border)}.summary-list li:last-child{border-bottom:none}.summary-list li span:first-child{color:var(--muted)}.summary-list li span:last-child{font-weight:600;text-align:right}table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:11px 13px;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--surface-2);font-weight:600;color:var(--faint);font-size:11px;text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0}tbody tr{transition:background .12s}tbody tr:hover{background:var(--surface-2)}tbody tr:last-child td{border-bottom:none}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}.table-scroll{overflow:auto;max-height:70vh;border:1px solid var(--border);border-radius:var(--radius-md)}.table-scroll table th{background:#eef3f1;box-shadow:inset 0 -1px 0 var(--border)}.cell-ship{background:var(--brand-light);font-weight:600;color:var(--brand-darker)}.cell-empty{color:#ccd5d0}.matrix td,.matrix th{white-space:nowrap}.matrix thead th.num{min-width:86px}.matrix th.rowhead{position:sticky;left:0;z-index:1;text-align:left;font-weight:600;color:var(--text);background:var(--surface-2);text-transform:none;letter-spacing:0;box-shadow:inset -1px 0 0 var(--border)}.matrix thead th.rowhead{z-index:2;background:#eef3f1}.matrix tbody tr:hover{background:transparent}.matrix tr.ship-row th.rowhead{color:var(--brand-darker)}.warn{background:var(--warn-bg);border:1px solid var(--warn-border);color:var(--warn-text);padding:12px 15px;border-radius:var(--radius-sm);margin-bottom:12px;font-size:13px}.badge{display:inline-block;padding:3px 11px;border-radius:999px;font-size:11px;font-weight:600}.badge.released{background:var(--brand-light);color:var(--brand-dark)}.badge.planned{background:var(--gold-light);color:var(--gold-dark)}.tag{display:inline-block;padding:3px 10px;border-radius:7px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:600}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar h2{margin-bottom:0}.muted{color:var(--muted)}.right{text-align:right}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;padding:24px;background:#101a1673;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;animation:overlayIn .15s ease}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:450px;padding:26px;animation:modalIn .22s cubic-bezier(.16,.84,.44,1)}.modal-icon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(140deg,var(--accent-light),#d3e8f7);color:var(--accent-dark)}.modal-icon.danger{background:var(--danger-light);color:var(--danger)}.modal-icon svg{width:23px;height:23px}.modal h3{margin:0 0 9px;font-size:18px;font-weight:700;letter-spacing:-.01em}.modal-body{margin:0 0 22px;color:var(--muted);font-size:14px;line-height:1.55}.modal-actions{display:flex;justify-content:flex-end;gap:10px}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.md-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:22px}.tab{border:none;background:transparent;color:var(--muted);font-weight:600;font-size:14px;padding:10px 16px;border-radius:0;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{background:transparent;color:var(--text)}.tab.active{color:var(--brand-dark);border-bottom-color:var(--brand)}.md-subnav{position:sticky;top:78px;z-index:15;display:flex;flex-wrap:wrap;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:5px;margin-bottom:20px;box-shadow:var(--shadow-sm);width:fit-content}.md-subnav a{text-decoration:none;color:var(--muted);font-size:13px;font-weight:600;padding:7px 15px;border-radius:999px;transition:background .15s,color .15s}.md-subnav a:hover{background:var(--surface-2);color:var(--text)}[id^=md-]{scroll-margin-top:140px}.updated-pill{font-size:11px;color:var(--muted);font-weight:500;background:var(--surface-2);border:1px solid var(--border);padding:3px 10px;border-radius:999px;white-space:nowrap}.cap-chart-wrap{margin:4px 0 18px}.cap-chart{display:flex;align-items:flex-end;gap:3px;height:64px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md)}.cap-bar{flex:1;min-width:4px;border-radius:4px 4px 2px 2px;background:linear-gradient(180deg,var(--brand) 0%,var(--brand-dark) 100%)}.cap-bar:hover{background:linear-gradient(180deg,var(--brand-dark),var(--brand-darker))}.cap-chart-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);padding:6px 2px 0}.cap-scroll{max-height:296px}.md-fieldset{border:0;margin:0;padding:0;min-width:0}.md-fieldset:disabled input,.md-fieldset:disabled select,.md-fieldset:disabled textarea{background:var(--surface-2);color:var(--text);-webkit-text-fill-color:var(--text);opacity:1;cursor:default;border-color:var(--border)}.md-fieldset:disabled input:hover,.md-fieldset:disabled select:hover{border-color:var(--border)}.md-fieldset:disabled table input,.md-fieldset:disabled table select{background:transparent;border-color:transparent}.readonly-banner{display:flex;align-items:center;gap:9px;background:var(--accent-light);border:1px solid #cbe1f1;color:var(--accent-dark);padding:11px 15px;border-radius:var(--radius-sm);margin-bottom:22px;font-size:13px;font-weight:500}.readonly-banner svg{width:17px;height:17px;flex-shrink:0}.readonly-banner b{font-weight:700}.empty-state{text-align:center;padding:52px 24px;color:var(--muted)}.empty-state svg{width:42px;height:42px;color:var(--faint);margin-bottom:12px}.empty-state h3{margin:0 0 4px;font-size:15px;color:var(--text);text-transform:none;letter-spacing:0}.ship-layout{display:grid;grid-template-columns:330px 1fr;gap:22px;align-items:start}.section-lock{border:0;margin:0;padding:0;min-width:0}.section-lock:disabled input,.section-lock:disabled select,.section-lock:disabled textarea{background:var(--surface-2);color:var(--text);-webkit-text-fill-color:var(--text);opacity:1;cursor:default;border-color:var(--border)}.section-subhead{display:flex;justify-content:space-between;align-items:center;margin:18px 0 10px}.section-subhead h3{margin:0}.line-items{display:flex;flex-direction:column;gap:14px}.line-item{border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;background:var(--surface-2)}.line-item-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.line-item-title{font-weight:700;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.line-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px 16px}.line-grid .field{margin-bottom:0}.line-grid .line-desc{grid-column:1 / -1}.line-grid input{background:#fff}.ship-search{margin-bottom:10px}.ship-filters{display:flex;flex-direction:column;gap:8px}.ship-filters select{width:100%}.filter-check{display:flex;align-items:center;gap:8px;font-weight:500;font-size:13px;color:var(--text);margin:0}.filter-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted);margin:12px 0}.ship-list{display:flex;flex-direction:column;gap:9px}.ship-item{cursor:pointer;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-md);padding:13px 15px;transition:border-color .15s,background .15s,box-shadow .15s,transform .05s}.ship-item:hover{border-color:var(--brand);background:var(--surface-2)}.ship-item:active{transform:scale(.995)}.ship-item.active{border-color:var(--brand);background:var(--brand-light);box-shadow:var(--shadow-sm)}.ship-item-ref{font-weight:700;font-size:14px;letter-spacing:-.01em}.ship-item-meta{color:var(--muted);font-size:12px;margin-top:4px;display:flex;align-items:center;gap:8px}.ship-progress{height:5px;border-radius:99px;background:var(--surface-3);margin-top:11px;overflow:hidden}.ship-progress>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--brand),var(--brand-dark));transition:width .3s ease}.stage-chip{display:inline-block;padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:600;background:var(--surface-3);color:var(--muted);border:1px solid var(--border)}@media (max-width: 980px){.ship-layout{grid-template-columns:1fr}}.stepper{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 4px}.step{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:6px 12px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted)}.step.done{background:var(--brand-light);border-color:#cfead9;color:var(--brand-dark)}.step.current{background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dark) 150%);border-color:var(--gold-dark);color:#fff;box-shadow:0 5px 12px -5px #f3b62abf}@media print{.no-print{display:none!important}.content{padding:0;max-width:none}.card{box-shadow:none;border:1px solid #ddd;page-break-inside:avoid;animation:none}body{background:#fff}.app:before{display:none}}@media (max-width: 880px){.grid-2{grid-template-columns:1fr}.sidebar{width:78px}.brand{padding:10px}.brand-sub,.nav-label,.nav-item span,.sidebar-foot{display:none}.nav-item{justify-content:center}.content{padding:22px 18px 48px}.topbar{padding:0 18px}.user-meta{display:none}}
