/* Eustralis Sample Request Platform — design system ported from the National Sales
   Manager Platform (navy + gold). Mobile-first; breakpoints 390 / 768 / 1400. */
:root{
  color-scheme:light;
  --bg:#eef1f6; --card:#fff; --card2:#f6f8fc; --line:#dfe5f0; --line2:#c6d0e2;
  --navy:#161e33; --navy2:#222d49; --navy3:#33406a;
  --txt:#16213a; --mut:#5d6a87; --dim:#92a0bc; --inv:#cfd8ec;
  --gold:#c98a1b; --gold2:#e0a33a; --goldbg:#fbf2dd;
  --ok:#1c9b6a; --warn:#dd8a06; --bad:#cf4040;
  --okbg:#e2f6ec; --warnbg:#fbf0d8; --badbg:#fbe6e6;
  --r:14px; --shadow:0 2px 14px rgba(22,33,58,.07); --sidew:236px;
  --font:'Segoe UI',system-ui,-apple-system,Inter,Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--bg);color:var(--txt);font-family:var(--font);-webkit-text-size-adjust:100%}
h1,h2,h3,h4{font-weight:800;letter-spacing:-.2px}
a{color:var(--gold)}
.hidden{display:none!important}

/* layout: navy sidebar + main */
.app{display:flex;min-height:100vh}
#side{width:var(--sidew);flex-shrink:0;background:var(--navy);color:var(--inv);position:fixed;
  top:0;left:0;bottom:0;overflow-y:auto;z-index:40;display:flex;flex-direction:column;transition:transform .2s}
.brandbox{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.07)}
.brandbox .lg{font-size:17px;font-weight:800;letter-spacing:.5px;color:#fff}
.brandbox .lg b{color:var(--gold2)}
.brandbox .sub{font-size:11.5px;color:var(--dim);margin-top:3px}
nav{padding:10px 0;flex:1}
.gl{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--dim);padding:14px 20px 6px}
.navbtn{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--inv);
  padding:10px 20px;cursor:pointer;font-size:13.5px;font-weight:600;border-left:3px solid transparent;transition:.13s;text-align:left}
.navbtn:hover{background:rgba(255,255,255,.05);color:#fff}
.navbtn.on{background:rgba(224,163,58,.13);color:#fff;border-left-color:var(--gold2)}
.navbtn .ic{width:18px;text-align:center}
.navbtn .badge{margin-left:auto;background:var(--gold2);color:#1a1300;border-radius:99px;font-size:11px;font-weight:800;padding:1px 8px}
.sidefoot{padding:14px 20px;border-top:1px solid rgba(255,255,255,.07);font-size:12px;color:var(--dim)}
.sidefoot b{color:#fff;display:block;font-size:13px}
.sidefoot button{margin-top:8px}

main{margin-left:var(--sidew);flex:1;padding:0 30px 90px;width:calc(100% - var(--sidew))}
.vhead{padding:26px 0 6px}
.vhead .kick{font-size:10.5px;font-weight:700;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase}
.vhead h2{font-size:27px;margin-top:4px}
.vhead p{font-size:13.5px;color:var(--mut);margin-top:4px}

.menubtn{display:none;position:fixed;top:12px;left:12px;width:42px;height:42px;border-radius:11px;
  background:var(--navy);color:#fff;border:none;font-size:18px;z-index:60;cursor:pointer}
.scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:35}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow)}
.card.tight{padding:16px 18px}
.sect{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin:20px 0 12px;display:flex;align-items:center;gap:10px;font-weight:700}
.sect::after{content:'';flex:1;height:1px;background:var(--line)}

/* KPI cards w/ coloured top border */
.kpirow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:4px 0 14px}
.kpi{background:var(--card2);border:1px solid var(--line);border-top:3px solid var(--gold2);border-radius:13px;padding:16px;position:relative}
.kpi label{font-size:10px;letter-spacing:1.3px;text-transform:uppercase;color:var(--mut);font-weight:700;display:block}
.kpi .big{font-size:26px;font-weight:800;color:var(--navy);line-height:1.1;margin-top:6px}
.kpi .big.calc{color:var(--gold)}
.kpi .sub{font-size:11px;color:var(--mut);margin-top:4px}
.kpi.ok{border-top-color:var(--ok)} .kpi.warn{border-top-color:var(--warn)} .kpi.bad{border-top-color:var(--bad)}

/* forms */
.fld{margin-bottom:14px}
.fld label,.label{display:block;font-size:11px;color:var(--mut);font-weight:700;letter-spacing:.4px;margin-bottom:6px}
input,select,textarea{width:100%;border:1px solid var(--line2);border-radius:10px;padding:11px 12px;font-size:14px;color:var(--txt);background:#fff;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--gold2);outline:none;box-shadow:0 0 0 3px rgba(224,163,58,.15)}
textarea{resize:vertical;min-height:72px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* buttons */
.btn{background:linear-gradient(120deg,var(--gold),var(--gold2));border:none;color:#fff;padding:11px 18px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;transition:.13s}
.btn:hover{filter:brightness(1.06)} .btn:disabled{opacity:.5;cursor:default;filter:none}
.btn.full{width:100%} .btn.sm{padding:7px 13px;font-size:12.5px;border-radius:9px}
.btn.ghost{background:#fff;border:1px solid var(--line2);color:var(--txt)}
.btn.navy{background:var(--navy)} .btn.ok{background:linear-gradient(120deg,#178a5e,var(--ok))}
.btn.bad{background:var(--bad)}

/* pills + badges */
.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px}
.pill.ok{background:var(--okbg);color:var(--ok)} .pill.warn{background:var(--warnbg);color:var(--warn)}
.pill.bad{background:var(--badbg);color:var(--bad)} .pill.mut{background:var(--bg);color:var(--mut);border:1px solid var(--line2)}

/* tables */
.twrap{border:1px solid var(--line);border-radius:12px;overflow:auto;background:#fff}
table{width:100%;border-collapse:collapse;font-size:13px}
th{background:var(--card2);color:var(--mut);font-size:10px;letter-spacing:1.1px;text-transform:uppercase;padding:10px 11px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:9px 11px;border-bottom:1px solid var(--line)}
tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr.clickable{cursor:pointer} tr.clickable:hover{background:var(--card2)}

/* product / cart grids */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}
.pcard{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:12px}
.pcard .sku{font-size:11px;font-weight:700;color:var(--gold)}
.pcard .nm{font-size:13.5px;font-weight:600;margin:3px 0}
.pcard .meta{font-size:11.5px;color:var(--mut)}
.pcard .add{display:flex;gap:8px;margin-top:8px}
.pcard .add input{width:64px;padding:7px}
.cartitem{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--card2);border:1px solid var(--line);border-left:3px solid var(--gold2);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.empty{text-align:center;padding:34px 16px;color:var(--dim)}

/* dropdown */
.dd{position:relative}
.ddlist{position:absolute;background:#fff;border:1px solid var(--line2);border-radius:10px;max-height:300px;overflow-y:auto;z-index:100;width:100%;margin-top:4px;box-shadow:var(--shadow)}
.ddlist div{padding:10px 12px;cursor:pointer;font-size:13.5px;border-bottom:1px solid var(--line)}
.ddlist div:hover{background:var(--card2)}
.ddlist .rep{color:var(--mut);font-size:11.5px}

/* toast + status bar */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:12px 18px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.25);opacity:0;pointer-events:none;transition:.22s;z-index:200}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.bad{background:var(--bad)} .toast.ok{background:var(--ok)}
.netbar{font-size:11.5px;font-weight:700;padding:6px 12px;border-radius:99px;display:inline-flex;align-items:center;gap:7px}
.netbar.online{background:var(--okbg);color:var(--ok)} .netbar.offline{background:var(--warnbg);color:var(--warn)}
.netbar .dot{width:8px;height:8px;border-radius:50%;background:currentColor}

/* skeleton loading */
.skel{background:linear-gradient(90deg,#eef1f6 25%,#e3e8f1 37%,#eef1f6 63%);background-size:400% 100%;animation:sh 1.2s infinite;border-radius:8px;height:14px;margin:8px 0}
@keyframes sh{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* login gate */
.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(125deg,var(--navy),var(--navy3));padding:20px}
.gatecard{background:#fff;border-radius:18px;padding:30px 28px;max-width:380px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.gatecard h1{font-size:22px} .gatecard .sub{color:var(--mut);font-size:13px;margin:4px 0 18px}

/* modal */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;align-items:center;justify-content:center;padding:16px}
.overlay.show{display:flex}
.modal{background:#fff;border-radius:16px;padding:24px;max-width:520px;width:100%;max-height:90vh;overflow:auto}
.modal h2{font-size:18px;margin-bottom:16px}
.mfield{margin-bottom:12px} .mfield label{font-size:11px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.5px}
.mval{background:var(--card2);padding:10px 12px;border-radius:8px;font-size:13.5px;white-space:pre-wrap;word-break:break-word;margin-top:4px}

@media(max-width:860px){
  #side{transform:translateX(-100%)} #side.open{transform:translateX(0)}
  main{margin-left:0;width:100%;padding:64px 16px 90px} .menubtn{display:block}
  #side.open ~ .scrim{display:block}
  .grid2{grid-template-columns:1fr}
}
