:root{--navy:#071f45;--navy2:#0d3672;--blue:#2463eb;--blue2:#0ea5e9;--green:#16a34a;--red:#dc2626;--orange:#f97316;--yellow:#f59e0b;--bg:#eef3fa;--card:#fff;--muted:#64748b;--text:#0f172a;--line:#d8e2f0;--soft:#f8fafc;--shadow:0 16px 45px rgba(15,31,58,.10)}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(135deg,#eef4fb,#f7faff);color:var(--text)}
button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.muted{color:var(--muted)}.small{font-size:12px}.danger{color:var(--red)}.success{color:var(--green)}.mono{font-family:Consolas,monospace}.nowrap{white-space:nowrap}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 20% 20%,#dbeafe,transparent 25%),linear-gradient(135deg,#0b254c,#123a78)}
.login-card{width:440px;background:#fff;border-radius:28px;padding:30px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.login-logo{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#38bdf8,#1d4ed8);display:flex;align-items:center;justify-content:center;color:white;font-weight:900;margin-bottom:12px}.login-card h1{margin:0 0 6px}.login-card p{margin:0 0 22px;color:#64748b}.login-card label{font-weight:800;font-size:13px}.login-card input{width:100%;margin:6px 0 14px;padding:13px;border:1px solid var(--line);border-radius:14px}.primary{background:linear-gradient(135deg,#1d4ed8,#0ea5e9);color:white;border:none;border-radius:14px;padding:12px 18px;font-weight:900;box-shadow:0 10px 22px rgba(37,99,235,.22)}.secondary{background:#eaf2ff;color:#123a78;border:none;border-radius:14px;padding:12px 18px;font-weight:900}.ghost{background:white;border:1px solid var(--line);border-radius:14px;padding:10px 14px;font-weight:800}.green{background:linear-gradient(135deg,#16a34a,#22c55e)}.red{background:linear-gradient(135deg,#dc2626,#ef4444)}.orange{background:linear-gradient(135deg,#ea580c,#fb923c)}
.app-shell{display:grid;grid-template-columns:300px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#071f45,#0d3672);color:white;padding:20px 16px;display:flex;flex-direction:column;gap:18px}.brand{display:flex;gap:12px;align-items:center}.brand-badge{width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#38bdf8,#2563eb);display:flex;align-items:center;justify-content:center;font-weight:900}.brand h2{margin:0;font-size:20px}.brand p{margin:2px 0 0;color:#bfdbfe;font-size:13px}.cycle-card{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:16px}.cycle-card .label{font-size:11px;font-weight:900;color:#bfdbfe;letter-spacing:.08em}.cycle-card .value{font-size:20px;font-weight:900;margin-top:6px}.nav{display:flex;flex-direction:column;gap:8px}.nav button{display:flex;align-items:center;gap:12px;width:100%;background:transparent;color:white;border:0;border-radius:14px;padding:13px 14px;text-align:left;font-weight:850}.nav button.active,.nav button:hover{background:rgba(255,255,255,.14)}.nav .ico{width:30px;height:30px;border-radius:11px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}.userbox{margin-top:auto;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:13px}.userrow{display:flex;gap:10px;align-items:center}.avatar{width:40px;height:40px;border-radius:50%;background:#dbeafe;color:#123a78;font-weight:900;display:flex;align-items:center;justify-content:center}.signout{width:100%;margin-top:10px}
.main{padding:24px;overflow:auto}.hero{background:linear-gradient(135deg,#fff,#f8fbff);border-radius:28px;padding:26px;margin-bottom:22px;box-shadow:var(--shadow);display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.eyebrow{color:#64748b;font-weight:900;font-size:12px;letter-spacing:.1em;text-transform:uppercase}.hero h1{margin:6px 0 8px;font-size:32px}.hero p{margin:0;color:#64748b}.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:#eaf2ff;color:#123a78;font-weight:900}.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:white;border:1px solid #dbe5f3;border-radius:22px;padding:18px;box-shadow:0 10px 30px rgba(15,31,58,.07)}.card h3{margin:0 0 12px}.stat{background:white;border:1px solid #dbe5f3;border-radius:22px;padding:18px;box-shadow:0 10px 30px rgba(15,31,58,.06)}.stat .k{font-size:12px;font-weight:900;color:#64748b;text-transform:uppercase;letter-spacing:.08em}.stat .v{font-size:30px;font-weight:950;margin-top:8px}.stat .s{color:#64748b;margin-top:6px;font-size:13px}.toolbar{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin:14px 0 18px}.field{display:flex;flex-direction:column;gap:6px;min-width:190px}.field label{font-size:13px;font-weight:900;color:#243b5a}.field input,.field select,.field textarea{padding:12px 13px;border:1px solid #c9d8ea;border-radius:13px;background:white;min-height:44px}.field textarea{min-height:78px}.wide{min-width:320px;flex:1}.alert{padding:14px 16px;border-radius:16px;margin:14px 0;font-weight:800}.alert.warn{background:#fff7d6;color:#92400e;border:1px solid #fde68a}.alert.info{background:#eaf5ff;color:#123a78;border:1px solid #bfdbfe}.alert.good{background:#eafaf0;color:#166534;border:1px solid #bbf7d0}
.table-wrap{overflow:auto;border:1px solid #dbe5f3;border-radius:18px;background:white}.table{border-collapse:collapse;width:100%;min-width:1100px}.table th{background:#f4f8fd;text-align:left;color:#243b5a;font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:12px;border-bottom:1px solid #dbe5f3;position:sticky;top:0;z-index:1}.table td{padding:10px 12px;border-bottom:1px solid #e6edf7;vertical-align:middle}.table tr:hover{background:#f8fbff}.table input,.table select{width:110px;padding:9px;border:1px solid #c9d8ea;border-radius:10px}.table .comment{width:230px}.badge{display:inline-flex;padding:6px 9px;border-radius:999px;font-size:12px;font-weight:900}.badge.draft{background:#fff3c4;color:#92400e}.badge.submitted{background:#dcfce7;color:#166534}.badge.locked{background:#fee2e2;color:#991b1b}.badge.open{background:#dcfce7;color:#166534}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.tabs button{border:0;background:#eaf2ff;color:#123a78;border-radius:14px;padding:12px 16px;font-weight:900}.tabs button.active{background:#123a78;color:white}.section-title{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}.actions{display:flex;gap:8px;flex-wrap:wrap}.mini{padding:8px 10px;border-radius:10px;font-size:12px}.bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#0ea5e9)}.driver{background:#f8fbff}.linkbtn{background:none;border:0;color:#1d4ed8;font-weight:900;padding:0}.modal{position:fixed;inset:0;background:rgba(2,6,23,.54);display:flex;align-items:center;justify-content:center;padding:22px;z-index:20}.modal-card{background:white;border-radius:24px;width:min(760px,95vw);max-height:90vh;overflow:auto;padding:22px;box-shadow:0 35px 90px rgba(0,0,0,.25)}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-head h2{margin:0}.footer-note{font-size:12px;color:#64748b;margin-top:14px}.empty{padding:24px;text-align:center;color:#64748b}.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.right{text-align:right}.fileinput{padding:14px;background:#f8fbff;border:1px dashed #aac0da;border-radius:18px}
@media(max-width:1050px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.grid-2,.grid-3,.grid-4,.two-col,.three-col{grid-template-columns:1fr}.hero{flex-direction:column}.main{padding:14px}.table{min-width:900px}}
/* v7 fixes */
.userbox .usertext{min-width:0;overflow:hidden}.userbox .usertext b{display:block;max-width:175px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.forecast-grid{max-height:calc(100vh - 330px);overflow:auto}.forecast-table{min-width:1480px}.forecast-table th:first-child,.forecast-table td:first-child{position:sticky;left:0;background:#fff;z-index:2}.forecast-table th:first-child{background:#f4f8fd;z-index:3}.forecast-table th:nth-child(2),.forecast-table td:nth-child(2){position:sticky;left:68px;background:#fff;z-index:2}.forecast-table th:nth-child(2){background:#f4f8fd;z-index:3}.forecast-table input{width:96px}.forecast-table .comment{width:200px}.wide-modal{width:min(1100px,96vw)}.driver-block{margin:14px 0}.modal .table-wrap{max-height:320px;overflow:auto}.negative{color:#dc2626}.positive{color:#16a34a}
/* v8 performance + impersonation */
.loading-card{background:white;border:1px solid #dbe5f3;border-radius:24px;padding:26px;box-shadow:var(--shadow);max-width:620px}.loading-card h2{margin:0 0 8px}.loading-card p{margin:0;color:var(--muted)}
.impersonate-banner{margin-bottom:14px;background:#fff7d6;border:1px solid #fde68a;color:#92400e;border-radius:16px;padding:12px 14px;font-weight:800}.impersonate-banner button{float:right;border:0;border-radius:10px;background:#92400e;color:#fff;padding:6px 10px;font-weight:900}
.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-3 .stat{min-width:0}
@media(max-width:1200px){.three-col{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.three-col{grid-template-columns:1fr}.impersonate-banner button{float:none;margin-left:8px}}
/* v9 layout, performance, responsive improvements */
:root{--sidebar:260px}.app-shell{grid-template-columns:var(--sidebar) 1fr}.sidebar{padding:14px 12px;gap:12px}.brand-badge{width:44px;height:44px;border-radius:15px}.brand h2{font-size:18px}.brand p{font-size:12px}.cycle-card{padding:13px;border-radius:18px}.cycle-card .value{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav{gap:5px}.nav button{padding:10px 11px;border-radius:12px}.nav .ico{width:26px;height:26px}.userbox{padding:10px;border-radius:16px}.userbox .usertext b{max-width:150px}.main{padding:18px}.hero{padding:20px;border-radius:24px;margin-bottom:16px}.hero h1{font-size:27px}.grid{gap:14px}.card,.stat{border-radius:18px;padding:14px}.stat .v{font-size:25px}.dashboard-grid{grid-template-columns:minmax(260px,.75fr) minmax(420px,1.35fr) minmax(300px,.9fr)}
.forecast-grid{max-height:calc(100vh - 275px);overflow:auto;scrollbar-gutter:stable both-edges}.forecast-table{min-width:1180px;table-layout:fixed}.forecast-table th,.forecast-table td{padding:7px 8px}.forecast-table th:nth-child(1),.forecast-table td:nth-child(1){width:46px}.forecast-table th:nth-child(2),.forecast-table td:nth-child(2){width:52px}.forecast-table th:nth-child(3),.forecast-table td:nth-child(3){width:64px}.forecast-table th:nth-child(4),.forecast-table td:nth-child(4){width:76px}.forecast-table th:nth-child(n+5):nth-child(-n+12),.forecast-table td:nth-child(n+5):nth-child(-n+12){width:76px}.forecast-table th:nth-child(13),.forecast-table td:nth-child(13){width:88px}.forecast-table th:nth-child(14),.forecast-table td:nth-child(14){width:170px}.forecast-table input{width:64px;padding:7px 8px}.forecast-table .comment{width:145px}.table input,.table select{padding:7px 8px}.toolbar.compact-toolbar{margin-top:6px}.loading-card{padding:20px}.loading-card h2{font-size:22px}.modal-card.wide-modal{width:min(1180px,96vw)}
@media(max-width:1300px){:root{--sidebar:235px}.dashboard-grid{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.userbox .usertext b{max-width:125px}}
@media(max-width:900px){.app-shell{display:block}.sidebar{position:relative;height:auto;min-height:0}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.main{padding:12px}.hero{display:block}.actions{margin-top:12px}.grid-2,.grid-3,.grid-4,.dashboard-grid{grid-template-columns:1fr}.toolbar{align-items:stretch}.field{min-width:100%;width:100%}.forecast-grid{max-height:60vh}.table{min-width:900px}}
@media(max-width:560px){body{font-size:14px}.brand h2{font-size:17px}.nav{grid-template-columns:1fr}.hero h1{font-size:23px}.stat .v{font-size:22px}.forecast-table{min-width:1080px}.forecast-table input{width:58px}.forecast-table .comment{width:120px}.primary,.secondary,.ghost{width:100%;margin-top:6px}.actions .pill{font-size:12px}}
/* v10 submission lock + actuals tab layout */
.compact-tabs{margin-top:4px;margin-bottom:10px}.compact-tabs button{padding:9px 13px}.forecast-table.compact{min-width:1040px}.forecast-table.compact th,.forecast-table.compact td{padding:6px 7px}.compact-comment{width:145px!important}.table input:disabled{background:#f1f5f9;color:#64748b}.badge.submitted{background:#e0f2fe;color:#075985}.badge.locked{background:#fee2e2;color:#991b1b}.table td:nth-child(10),.table td:nth-child(11){font-weight:800}.field.wide select{min-width:280px}
@media(max-width:1100px){.forecast-table.compact{min-width:980px}.forecast-grid{max-height:58vh}.main{padding:12px}.sidebar{font-size:14px}.nav button{font-size:14px}}
@media(max-width:700px){.forecast-table.compact{min-width:930px}.tabs.compact-tabs{display:grid;grid-template-columns:1fr}.tabs.compact-tabs button{width:100%}.hero .actions{display:grid}.toolbar{gap:8px}.card,.stat{padding:12px}}
