/* ============================================================
   Pexo Hub — "Luminous Lab" admin design system
   Fresh, liquid, light — built for a cleaning-products ops team.
   All legacy class names preserved; restyled + brought to life.
   ============================================================ */
:root{
  --ink:#0B2330; --ink-soft:#5C7686; --line:#E4EDF2; --card:#FFFFFF; --bg:#EEF5F9;
  --azure:#1A7AE0; --aqua:#13B7A4; --lime:#7FCB1B; --coral:#F0653E; --amber:#E8A12B;
  --marine:#072A3A;
  --grad-brand:linear-gradient(135deg,#1F86EE 0%,#13B7A4 100%);
  --grad-fresh:linear-gradient(135deg,#13B7A4 0%,#8FD414 100%);
  --grad-side:linear-gradient(176deg,#0C3A4F 0%,#072734 55%,#05202C 100%);
  --r:16px; --r-sm:11px;
  --shadow:0 1px 2px rgba(11,35,48,.05),0 6px 18px rgba(11,35,48,.05);
  --shadow-lg:0 2px 6px rgba(11,35,48,.06),0 18px 44px rgba(11,35,48,.12);
  --glow:0 8px 24px rgba(26,122,224,.32);
  --glow-aqua:0 8px 24px rgba(19,183,164,.30);
  --ease:cubic-bezier(.4,0,.2,1); --spring:cubic-bezier(.34,1.4,.5,1);
}
[data-theme=dark]{
  --ink:#EAF4F8; --ink-soft:#8DA9B8; --line:#173747; --card:#0E2632; --bg:#071A23; --marine:#EAF4F8;
  --shadow:0 1px 3px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.35);
  --shadow-lg:0 2px 6px rgba(0,0,0,.4),0 20px 50px rgba(0,0,0,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:Inter,system-ui,sans-serif;color:var(--ink);font-size:14px;line-height:1.5;
  background:radial-gradient(1100px 540px at 88% -8%,color-mix(in srgb,var(--aqua) 12%,var(--bg)),transparent 60%),
             radial-gradient(900px 500px at -5% 4%,color-mix(in srgb,var(--azure) 9%,var(--bg)),transparent 55%),
             var(--bg);
  background-attachment:fixed}
a{color:inherit;text-decoration:none}
.mono{font-family:"Spline Sans Mono",ui-monospace,monospace}

/* ---------- motion keyframes ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes popIn{0%{opacity:0;transform:scale(.85)}100%{opacity:1;transform:scale(1)}}
@keyframes sheen{0%{transform:translateX(-120%) skewX(-18deg)}100%{transform:translateX(220%) skewX(-18deg)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}
@keyframes meshDrift{0%{transform:translate(0,0) scale(1)}33%{transform:translate(3%,-4%) scale(1.08)}66%{transform:translate(-3%,3%) scale(1.04)}100%{transform:translate(0,0) scale(1)}}
@keyframes spinSheen{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}

/* ---------- shell ---------- */
.shell{display:flex;min-height:100vh}
.sidebar{width:240px;background:var(--grad-side);color:#DCEAF1;flex-shrink:0;position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;padding:16px 13px;gap:3px;overflow-y:auto;overflow-x:hidden;
  border-right:1px solid rgba(255,255,255,.04)}
.sidebar::before{content:"";position:absolute;top:-60px;left:-40px;width:240px;height:240px;pointer-events:none;
  background:radial-gradient(circle,rgba(19,183,164,.30),transparent 70%);filter:blur(14px)}
.sidebar::-webkit-scrollbar{width:7px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}
.brand{position:relative;display:flex;align-items:center;gap:11px;padding:8px 10px 16px;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:19px;color:#fff;letter-spacing:-.01em}
.brand .mk{position:relative;width:36px;height:36px;border-radius:11px;background:var(--grad-brand);
  display:grid;place-items:center;color:#fff;box-shadow:0 6px 16px rgba(19,183,164,.45);overflow:hidden}
.brand .mk::after{content:"";position:absolute;inset:-40%;background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.55),transparent 30%);
  animation:spinSheen 5s linear infinite;mix-blend-mode:screen}
.nav{display:flex;flex-direction:column;gap:2px}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.09em;color:#5E7C8C;margin:15px 12px 5px;font-weight:700}
.nav a{position:relative;display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:#AFC6D3;
  font-weight:500;font-size:13.5px;transition:transform .16s var(--ease),background .16s,color .16s}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff;transform:translateX(3px)}
.nav a.on{background:var(--grad-brand);color:#fff;box-shadow:var(--glow);font-weight:600}
.nav a.on::before{content:"";position:absolute;left:-13px;top:50%;transform:translateY(-50%);width:4px;height:21px;
  border-radius:0 4px 4px 0;background:linear-gradient(var(--aqua),var(--lime))}
.nav a .ic{width:20px;text-align:center;font-size:15px;filter:grayscale(.15)}
.nav a.on .ic{filter:none}
.side-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.09);padding-top:10px;font-size:12.5px;color:#83A0B0}
.side-foot a{display:block;padding:7px 11px;border-radius:9px;transition:.15s}
.side-foot a:hover{background:rgba(255,255,255,.07);color:#fff;transform:translateX(3px)}

/* ---------- main + topbar ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:64px;background:color-mix(in srgb,var(--card) 82%,transparent);backdrop-filter:saturate(1.4) blur(12px);
  -webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:16px;padding:0 26px;position:sticky;top:0;z-index:30}
.topbar h1{font-size:20px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.015em}
.topbar .sub{color:var(--ink-soft);font-size:13px}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.iconbtn{width:40px;height:40px;border:1px solid var(--line);border-radius:11px;background:var(--card);color:var(--ink);
  display:grid;place-items:center;cursor:pointer;font-size:16px;transition:.18s var(--ease)}
.iconbtn:hover{border-color:transparent;color:#fff;background:var(--grad-brand);transform:translateY(-2px);box-shadow:var(--glow)}
.who{display:flex;align-items:center;gap:9px;font-size:13px}
.who .av{width:37px;height:37px;border-radius:50%;background:var(--grad-brand);color:#fff;display:grid;place-items:center;
  font-weight:700;box-shadow:0 0 0 3px color-mix(in srgb,var(--aqua) 22%,transparent)}
.content{padding:26px;max-width:1240px;width:100%}

/* entrance choreography */
.content>*{animation:fadeUp .5s var(--ease) both}
.content>*:nth-child(1){animation-delay:.02s}.content>*:nth-child(2){animation-delay:.08s}
.content>*:nth-child(3){animation-delay:.14s}.content>*:nth-child(4){animation-delay:.20s}
.content>*:nth-child(5){animation-delay:.26s}.content>*:nth-child(6){animation-delay:.32s}
.cards{animation:none!important}
.cards .stat{animation:fadeUp .55s var(--ease) both}
.cards .stat:nth-child(1){animation-delay:.05s}.cards .stat:nth-child(2){animation-delay:.12s}
.cards .stat:nth-child(3){animation-delay:.19s}.cards .stat:nth-child(4){animation-delay:.26s}
.cards .stat:nth-child(5){animation-delay:.33s}

/* ---------- stat cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:22px}
.stat{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:18px 20px;box-shadow:var(--shadow);transition:transform .22s var(--spring),box-shadow .22s var(--ease),border-color .22s}
.stat::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-brand);opacity:.85;transition:.22s}
.stat::after{content:"";position:absolute;top:0;bottom:0;width:40%;left:0;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);opacity:0}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--azure) 30%,var(--line))}
.stat:hover::before{height:4px;opacity:1}
.stat:hover::after{opacity:.9;animation:sheen .9s var(--ease)}
.stat .lbl{font-size:12px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding-right:46px}
.stat .val{font-size:28px;font-weight:800;font-family:"Bricolage Grotesque",sans-serif;margin-top:7px;letter-spacing:-.02em;line-height:1.1}
.stat .val small{font-size:14px;color:var(--ink-soft);font-weight:600}
.stat .delta{font-size:12.5px;margin-top:5px;font-weight:600;color:var(--ink-soft)}
.stat .delta.up{color:var(--lime)} .stat .delta.down{color:var(--coral)}
.stat .ic{position:absolute;top:15px;right:15px;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  font-size:20px;float:none;background:color-mix(in srgb,var(--aqua) 12%,var(--card));box-shadow:inset 0 0 0 1px var(--line)}

/* ---------- panels ---------- */
.panel{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);margin-bottom:20px;min-width:0;transition:box-shadow .25s var(--ease)}
.panel:hover{box-shadow:var(--shadow-lg)}
.panel-h{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line)}
.panel-h h2{font-size:15.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.panel-h h2::before{content:"";width:8px;height:8px;border-radius:3px;background:var(--grad-fresh);box-shadow:0 0 8px rgba(19,183,164,.5)}
.panel-h .grow{flex:1}
.panel-b{padding:18px 20px}
.panel-b.flush{padding:0}

/* ---------- table ---------- */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);
  padding:11px 18px;border-bottom:1px solid var(--line);font-weight:700;white-space:nowrap}
td{padding:13px 18px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:middle}
/* bounded scroll box with sticky headers (long tables / reports) */
.tbl-scroll{max-height:65vh;overflow:auto}
.tbl-scroll thead th{position:sticky;top:0;z-index:3;background:var(--card);box-shadow:inset 0 -1px 0 var(--line)}
tbody tr{transition:background .14s,box-shadow .14s}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:color-mix(in srgb,var(--aqua) 6%,var(--card));box-shadow:inset 3px 0 0 var(--aqua)}
.t-r{text-align:right}.t-c{text-align:center}

/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;
  white-space:nowrap;animation:popIn .3s var(--spring) both}
.badge.gray{background:color-mix(in srgb,var(--ink-soft) 14%,var(--card));color:var(--ink-soft)}
.badge.blue{background:color-mix(in srgb,var(--azure) 14%,var(--card));color:var(--azure)}
.badge.green{background:color-mix(in srgb,var(--aqua) 16%,var(--card));color:#0d8a7c}
.badge.amber{background:color-mix(in srgb,var(--amber) 18%,var(--card));color:#b87b10}
.badge.red{background:color-mix(in srgb,var(--coral) 16%,var(--card));color:#cc4324}
.badge .d{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:7px;height:42px;padding:0 18px;
  border-radius:var(--r-sm);border:1px solid var(--line);background:var(--card);color:var(--ink);font-weight:600;
  font-size:13.5px;cursor:pointer;transition:transform .16s var(--ease),box-shadow .16s,border-color .16s,background .16s;
  font-family:inherit;overflow:hidden;white-space:nowrap}
.btn:hover{border-color:color-mix(in srgb,var(--azure) 55%,var(--line));transform:translateY(-2px);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0) scale(.98)}
.btn.primary{background:var(--grad-brand);border-color:transparent;color:#fff}
.btn.primary:hover{box-shadow:var(--glow);transform:translateY(-2px)}
.btn.primary::after{content:"";position:absolute;top:0;bottom:0;width:45%;left:0;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);opacity:0}
.btn.primary:hover::after{opacity:1;animation:sheen .85s var(--ease)}
.btn.dark{background:var(--marine);border-color:var(--marine);color:#fff}
[data-theme=dark] .btn.dark{color:var(--bg)}
.btn.sm{height:34px;padding:0 13px;font-size:12.5px;border-radius:9px}
.btn.danger{color:var(--coral);border-color:color-mix(in srgb,var(--coral) 35%,var(--line))}
.btn.danger:hover{background:color-mix(in srgb,var(--coral) 10%,var(--card));border-color:var(--coral)}
.btn.ghost{background:transparent}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}

/* ---------- forms ---------- */
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink-soft)}
.field input,.field select,.field textarea{width:100%;height:44px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--card);padding:0 13px;font-size:14px;color:var(--ink);font-family:inherit;transition:.18s var(--ease)}
.field textarea{height:auto;min-height:84px;padding:11px 13px}
.field input:hover,.field select:hover,.field textarea:hover{border-color:color-mix(in srgb,var(--azure) 35%,var(--line))}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--azure);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--azure) 16%,transparent)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ---------- flash ---------- */
.flash{position:relative;padding:13px 16px 13px 18px;border-radius:12px;margin-bottom:16px;font-size:13.5px;font-weight:500;
  border:1px solid transparent;overflow:hidden;animation:fadeUp .4s var(--ease) both}
.flash::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.flash.ok{background:color-mix(in srgb,var(--aqua) 12%,var(--card));color:#0a7d70;border-color:color-mix(in srgb,var(--aqua) 28%,var(--line))}
.flash.ok::before{background:var(--aqua)}
.flash.err{background:color-mix(in srgb,var(--coral) 12%,var(--card));color:#cc4324;border-color:color-mix(in srgb,var(--coral) 28%,var(--line))}
.flash.err::before{background:var(--coral)}

/* ---------- misc ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.filters input,.filters select{height:40px;border:1px solid var(--line);border-radius:10px;background:var(--card);
  color:var(--ink);padding:0 12px;font-size:13.5px;font-family:inherit;transition:.16s}
.filters input:focus,.filters select:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px color-mix(in srgb,var(--azure) 14%,transparent)}
.muted{color:var(--ink-soft)} .b{font-weight:700} .sp{height:1px;background:var(--line);margin:14px 0}
.pill-row{display:flex;gap:7px;flex-wrap:wrap}
.empty{text-align:center;padding:48px;color:var(--ink-soft)}
.empty .big{font-size:46px;display:inline-block;animation:floatY 4s ease-in-out infinite}
.linkish{color:var(--azure);font-weight:600;cursor:pointer;transition:.14s}
.linkish:hover{color:var(--aqua);text-decoration:underline;text-underline-offset:3px}
.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;align-items:start}
.two-col>*{min-width:0}

/* ---------- responsive ---------- */
@media(max-width:1000px){.two-col{grid-template-columns:1fr!important}}
@media(max-width:860px){
  .sidebar{position:fixed;left:-264px;z-index:60;transition:left .24s var(--ease);box-shadow:0 0 50px rgba(0,0,0,.5)}
  .sidebar.open{left:0}.menu-toggle{display:grid!important}
  .scrim2{position:fixed;inset:0;background:rgba(4,18,25,.55);backdrop-filter:blur(2px);z-index:55;opacity:0;visibility:hidden;transition:.24s}
  .scrim2.open{opacity:1;visibility:visible}
}
.menu-toggle{display:none}
@media(max-width:760px){
  .content{padding:16px}
  .panel-b{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .panel-b table{width:auto;min-width:100%}
  .panel-b th,.panel-b td{white-space:nowrap}
  .row-3{grid-template-columns:1fr 1fr}
  .grid-cards{grid-template-columns:1fr 1fr!important}
}
@media(max-width:560px){
  .content{padding:13px}
  .topbar{height:56px;padding:0 12px}
  .topbar h1{font-size:17px} .topbar .sub{display:none}
  .who>div:not(.av){display:none}
  .top-actions{gap:8px}
  .cards{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
  .stat{padding:14px} .stat .val{font-size:21px} .stat .ic{width:32px;height:32px;font-size:16px}
  .stat .lbl{padding-right:38px}
  .row,.row-3{grid-template-columns:1fr}
  .two-col{gap:14px}
  .panel-h{flex-wrap:wrap;row-gap:8px}
  .grid-cards{grid-template-columns:1fr!important}
}

/* ---------- login (the hero moment) ---------- */
.login-wrap{position:relative;min-height:100vh;display:grid;place-items:center;overflow:hidden;
  background:linear-gradient(140deg,#072734 0%,#0C4256 38%,#11806F 72%,#1A7AE0 120%)}
.login-mesh{position:absolute;inset:-20%;z-index:0;pointer-events:none;
  background:radial-gradient(40% 40% at 20% 25%,rgba(19,183,164,.55),transparent 60%),
             radial-gradient(45% 45% at 80% 20%,rgba(26,122,224,.5),transparent 60%),
             radial-gradient(50% 50% at 65% 85%,rgba(143,212,20,.32),transparent 60%);
  filter:blur(20px);animation:meshDrift 18s ease-in-out infinite}
.orb{position:absolute;border-radius:50%;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 32% 30%,rgba(255,255,255,.55),rgba(255,255,255,.06) 60%,transparent 70%);
  box-shadow:inset 0 0 30px rgba(255,255,255,.3);animation:floatY 9s ease-in-out infinite}
.orb.o1{width:120px;height:120px;left:12%;top:60%;animation-duration:11s}
.orb.o2{width:70px;height:70px;left:78%;top:30%;animation-duration:8s;animation-delay:-2s}
.orb.o3{width:46px;height:46px;left:62%;top:70%;animation-duration:7s;animation-delay:-4s}
.orb.o4{width:200px;height:200px;left:70%;top:-6%;animation-duration:14s;opacity:.5}
.login-card{position:relative;z-index:2;width:404px;max-width:92vw;padding:36px 34px;border-radius:24px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.6);box-shadow:0 30px 70px rgba(3,18,26,.45),inset 0 1px 0 rgba(255,255,255,.6);
  animation:popIn .6s var(--spring) both,fadeUp .6s var(--ease) both}
[data-theme=dark] .login-card{background:rgba(14,38,50,.9);border-color:rgba(255,255,255,.1)}
.login-card .brand{color:var(--ink);justify-content:center;padding-bottom:4px;font-size:22px}
.login-card .brand .mk{width:42px;height:42px;border-radius:13px;font-size:20px}

/* ---------- global search (topbar) ---------- */
.topsearch{position:relative;flex:1;max-width:420px;margin-left:8px}
.topsearch .ts-ic{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.6;pointer-events:none}
.topsearch input{width:100%;height:42px;border-radius:12px;border:1px solid var(--line);background:var(--card);
  padding:0 14px 0 38px;font-size:13.5px;color:var(--ink);font-family:inherit;transition:.18s var(--ease)}
.topsearch input:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 4px color-mix(in srgb,var(--azure) 15%,transparent)}
.ts-kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:"Spline Sans Mono",monospace;font-size:12px;
  color:var(--ink-soft);background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:1px 7px;pointer-events:none}
.topsearch input:focus ~ .ts-kbd{display:none}
.ts-panel{position:absolute;top:50px;left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-lg);max-height:64vh;overflow-y:auto;z-index:60;padding:6px;animation:fadeUp .18s var(--ease) both}
.ts-group-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-weight:700;padding:9px 12px 5px}
.ts-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:inherit;cursor:pointer}
.ts-item:hover,.ts-item.sel{background:color-mix(in srgb,var(--azure) 9%,var(--card))}
.ts-item .ic{font-size:16px;width:22px;text-align:center}
.ts-item .tx{flex:1;min-width:0}
.ts-item .tx b{font-size:13.5px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ts-item .tx span{font-size:12px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.ts-empty{padding:16px;text-align:center;color:var(--ink-soft);font-size:13px}
@media(max-width:680px){.topsearch{max-width:none}}
@media(max-width:520px){.topsearch{display:none}}

/* ---------- activity feed (dashboard) ---------- */
.feed-item{display:flex;gap:12px;padding:11px 18px;border-bottom:1px solid var(--line);align-items:flex-start;color:inherit;transition:background .12s var(--ease)}
a.feed-item:hover{background:color-mix(in srgb,var(--azure) 6%,transparent)}
a.feed-item:hover .feed-tx > :first-child{color:var(--azure)}

/* breadcrumbs */
.crumbs{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:12.5px;margin-bottom:3px}
.crumbs a{color:var(--ink-soft);font-weight:600;text-decoration:none}
.crumbs a:hover{color:var(--azure)}
.crumbs .sep{color:var(--ink-soft);opacity:.6}
.crumbs .cur{color:var(--ink-soft)}

/* sortable table headers (table.sortable) */
th.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
th.th-sort:hover{color:var(--azure)}
th.th-sort::after{content:"⇅";font-size:10px;opacity:.35;margin-left:5px}
th.sort-asc::after{content:"▲";font-size:9px;opacity:.9;margin-left:5px}
th.sort-desc::after{content:"▼";font-size:9px;opacity:.9;margin-left:5px}
.feed-item:last-child{border-bottom:none}
.feed-ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;font-size:15px;flex-shrink:0;
  background:color-mix(in srgb,var(--aqua) 12%,var(--card));box-shadow:inset 0 0 0 1px var(--line)}
.feed-item.ev-order .feed-ic{background:color-mix(in srgb,var(--azure) 14%,var(--card))}
.feed-item.ev-pay .feed-ic{background:color-mix(in srgb,var(--aqua) 16%,var(--card))}
.feed-item.ev-new .feed-ic{background:color-mix(in srgb,var(--lime) 18%,var(--card))}
.feed-tx{flex:1;min-width:0;font-size:13.5px}
.feed-tx .when{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.day-sep{padding:11px 18px 7px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--ink-soft);background:color-mix(in srgb,var(--aqua) 5%,var(--card));border-bottom:1px solid var(--line);position:sticky;top:64px;z-index:1}

/* ---------- clickable table rows ---------- */
tr.rowlink{cursor:pointer;transition:background .12s var(--ease)}
tr.rowlink:hover{background:color-mix(in srgb,var(--azure) 6%,transparent)}
tr.rowlink:hover td:first-child{box-shadow:inset 3px 0 0 var(--azure)}
tr.rowlink:active{background:color-mix(in srgb,var(--azure) 11%,transparent)}

/* ---------- order journey stepper ---------- */
.journey{display:flex;align-items:flex-start;gap:0;padding:10px 4px 4px;overflow-x:auto;scrollbar-width:none}
.journey::-webkit-scrollbar{display:none}
.jstep{flex:1;min-width:92px;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}
.jstep::before{content:"";position:absolute;top:23px;left:-50%;width:100%;height:3px;background:var(--line);z-index:1;border-radius:2px}
.jstep:first-child::before{display:none}
.jstep.done::before,.jstep.current::before{background:var(--grad-brand)}
.jnode{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-size:20px;z-index:2;position:relative;
  background:var(--card);border:2px solid var(--line);color:var(--ink-soft);transition:.35s var(--ease)}
.jstep.done .jnode{background:var(--grad-brand);border-color:transparent;color:#fff;box-shadow:0 8px 18px -8px var(--aqua)}
.jstep.current .jnode{background:var(--grad-fresh);border-color:transparent;color:#fff;animation:jpulse 1.9s ease-in-out infinite}
.jlbl{font-size:11.5px;font-weight:600;margin-top:9px;max-width:96px;line-height:1.25}
.jstep.current .jlbl{color:var(--aqua)}
.jtime{font-size:10.5px;color:var(--ink-soft);margin-top:3px}
@keyframes jpulse{0%,100%{box-shadow:0 0 0 5px color-mix(in srgb,var(--aqua) 26%,transparent)}50%{box-shadow:0 0 0 13px color-mix(in srgb,var(--aqua) 5%,transparent)}}
.jterminal{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:13px;background:color-mix(in srgb,var(--coral) 9%,var(--card))}
.jterminal .ji{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:20px;background:var(--coral);color:#fff;flex-shrink:0}
.jterminal.returned{background:color-mix(in srgb,var(--amber) 12%,var(--card))}.jterminal.returned .ji{background:var(--amber)}
.paybar-wrap{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.paybar-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;margin-bottom:8px}
.paybar{height:10px;border-radius:6px;background:var(--bg);overflow:hidden}
.paybar-fill{height:100%;border-radius:6px;background:var(--grad-fresh);transition:width .8s var(--ease);
  background:linear-gradient(90deg,var(--amber),color-mix(in srgb,var(--amber) 60%,var(--aqua)))}
.paybar-fill.full{background:var(--grad-fresh)}

/* ---------- in-system report bar charts ---------- */
.rchart{display:flex;flex-direction:column;gap:11px}
.rbar-row{display:flex;align-items:center;gap:12px}
.rbar-lbl{width:180px;flex-shrink:0;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rbar-track{flex:1;min-width:60px;height:18px;border-radius:9px;background:var(--bg);overflow:hidden}
.rbar-fill{height:100%;border-radius:9px;background:var(--grad-brand);box-shadow:0 2px 8px -2px var(--azure);animation:rgrow .7s var(--ease) both}
.rbar-val{width:120px;flex-shrink:0;text-align:right;font-family:"Spline Sans Mono",monospace;font-size:12.5px;font-weight:600}
@keyframes rgrow{from{width:0 !important;opacity:.4}}
@media(max-width:620px){.rbar-lbl{width:108px}.rbar-val{width:88px;font-size:11.5px}}

/* ---------- profile header band (detail pages) ---------- */
.profile-band{display:flex;align-items:center;gap:18px;padding:22px 24px;
  background:linear-gradient(120deg,color-mix(in srgb,var(--azure) 9%,var(--card)),color-mix(in srgb,var(--aqua) 9%,var(--card)))}
.profile-av{width:64px;height:64px;border-radius:18px;flex-shrink:0;background:var(--grad-brand);color:#fff;
  display:grid;place-items:center;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:24px;
  box-shadow:0 10px 24px rgba(19,183,164,.4)}
@media(max-width:560px){.profile-band{padding:16px;gap:13px}.profile-av{width:52px;height:52px;font-size:20px;border-radius:14px}}

/* ---------- keyboard focus visibility (a11y) ---------- */
:focus-visible{outline:2px solid var(--azure);outline-offset:2px;border-radius:6px}
.nav a:focus-visible,.side-foot a:focus-visible{outline-color:#fff;outline-offset:-2px}
.btn:focus-visible,.iconbtn:focus-visible{outline-offset:3px}

/* ---------- accessibility: respect reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
}
