/* ════════════════════════════════════════════════════════════
   DATUMETRY UI KIT — components (Part 1)
   ════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────
   1 · BUTTONS & ACTIONS
   variants: primary / secondary / ghost / destructive
   sizes: sm / md / lg · icon-only · leading/trailing icon
   hover-action candidates: h-sweep / h-lift / h-draw / h-invert
   ────────────────────────────────────────────── */
.btn{
  --h:44px;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:var(--h);padding:0 24px;border-radius:var(--r-pill);
  font-size:15px;font-weight:650;letter-spacing:.005em;line-height:1;
  border:1.5px solid transparent;cursor:pointer;user-select:none;white-space:nowrap;
  text-decoration:none;isolation:isolate;overflow:hidden;
  transition:background var(--t2) var(--ease),color var(--t2) var(--ease),
    border-color var(--t2) var(--ease),box-shadow var(--t2) var(--ease),
    transform var(--t1) var(--ease);
}
.btn:focus-visible{outline:none;box-shadow:var(--ring);}
.btn:active{transform:translateY(0) scale(.97);box-shadow:none !important;}
/* CANONICAL hover (chosen: "Lift") — rises 2px w/ soft shadow, presses down on click */
.btn.primary:hover,.btn.secondary:hover,.btn.destructive:hover{transform:translateY(-2px);}
.btn.primary:hover{box-shadow:0 8px 20px -6px rgba(52,21,238,.45);}
.btn.secondary:hover{box-shadow:0 8px 20px -8px rgba(11,14,22,.3);}
.btn.destructive:hover{box-shadow:0 8px 20px -8px rgba(210,41,75,.45);}
[data-theme="dark"] .btn.primary:hover{box-shadow:0 8px 22px -6px rgba(122,140,255,.4);}
.btn[disabled],.btn.is-disabled{opacity:.38;pointer-events:none;}
.btn .ic{width:17px;height:17px;flex:none;display:inline-flex;transition:transform var(--t2) var(--ease);}

.btn.sm{--h:34px;font-size:13.5px;padding:0 17px;gap:6px;}
.btn.sm .ic{width:14px;height:14px;}
.btn.lg{--h:54px;font-size:16.5px;padding:0 32px;}
.btn.icon-only{width:var(--h);padding:0;}

.btn.primary{background:var(--accent);color:#fff;}
[data-theme="dark"] .btn.primary{color:var(--ink);}
.btn.primary:hover{background:var(--accent-hover);}
.btn.secondary{background:transparent;color:var(--text);border-color:var(--line-strong);}
.btn.secondary:hover{border-color:var(--text);background:var(--bg-card);}
.btn.ghost{background:transparent;color:var(--text-2);}
.btn.ghost:hover{color:var(--text);background:var(--bg-hover);}
.btn.destructive{background:var(--danger);color:#fff;}
.btn.destructive:hover{filter:brightness(.92);}
.btn.destructive.quiet{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-bd);}

/* loading */
.btn.is-loading{color:transparent !important;pointer-events:none;}
.btn.is-loading::after{content:"";position:absolute;left:50%;top:50%;margin:-8px 0 0 -8px;width:16px;height:16px;
  border-radius:50%;border:2px solid rgba(255,255,255,.95);border-top-color:transparent;animation:btnspin .7s linear infinite;}
.btn.secondary.is-loading::after,.btn.ghost.is-loading::after{border-color:var(--text);border-top-color:transparent;}
[data-theme="dark"] .btn.primary.is-loading::after{border-color:var(--ink);border-top-color:transparent;}
@keyframes btnspin{to{transform:rotate(360deg);}}

/* —— retired hover candidates removed; "Lift" (B) is canonical above —— */

/* text link */
.tlink{display:inline-flex;align-items:center;gap:6px;font-weight:650;font-size:15px;color:var(--accent);
  text-decoration:none;position:relative;cursor:pointer;}
.tlink::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:100%;background:currentColor;
  transform:scaleX(0);transform-origin:left;transition:transform var(--t2) var(--ease);}
.tlink:hover::after{transform:scaleX(1);}
.tlink .ic{width:15px;height:15px;transition:transform var(--t2) var(--ease);}
.tlink:hover .ic{transform:translateX(3px);}

/* ──────────────────────────────────────────────
   2 · FORM CONTROLS
   ────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:7px;width:100%;}
.field > label{font-size:14px;font-weight:650;color:var(--text);}
.field .req{color:var(--danger);margin-left:2px;}
.field .help{font-size:13px;color:var(--text-3);}
.field .errtext{display:none;font-size:13px;font-weight:550;color:var(--danger);}
.field.err .errtext{display:block;}
.field.err .help{display:none;}

.input,.textarea,.selectbox{
  font-family:inherit;font-size:15px;color:var(--text);width:100%;
  background:var(--bg-card);border:1.5px solid var(--line-strong);border-radius:var(--r-md);
  height:46px;padding:0 15px;outline:none;
  transition:border-color var(--t2) var(--ease),box-shadow var(--t2) var(--ease),transform var(--t1) var(--ease);
}
.textarea{height:auto;min-height:104px;padding:12px 15px;resize:vertical;line-height:1.5;}
.input::placeholder,.textarea::placeholder{color:var(--text-3);}
.input:hover,.textarea:hover,.selectbox:hover{border-color:var(--text-3);}
.input:focus,.textarea:focus,.selectbox:focus-visible,.selectbox.open{border-color:var(--accent);box-shadow:var(--ring);}
.field.err .input,.field.err .textarea,.field.err .selectbox{border-color:var(--danger);box-shadow:0 0 0 3px rgba(210,41,75,.12);}
.input[disabled]{background:var(--bg-sunken);color:var(--text-3);cursor:not-allowed;}

/* custom select (single) */
.selectbox{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;position:relative;}
.selectbox .val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.selectbox .val.ph{color:var(--text-3);}
.selectbox .chev{flex:none;width:16px;height:16px;color:var(--text-3);transition:transform var(--t2) var(--ease);}
.selectbox.open .chev{transform:rotate(180deg);}
.selectbox .menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:20;
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-3);
  padding:6px;max-height:240px;overflow:auto;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;
  transition:opacity var(--t2) var(--ease),transform var(--t2) var(--ease);}
.selectbox.open .menu{opacity:1;transform:none;pointer-events:auto;}
.selectbox .opt{padding:9px 11px;border-radius:var(--r-sm);font-size:14.5px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;}
.selectbox .opt:hover,.selectbox .opt.hl{background:var(--bg-hover);}
.selectbox .opt.hl{box-shadow:inset 0 0 0 1.5px var(--line-strong);}
.selectbox .opt.sel{color:var(--accent);font-weight:650;background:var(--accent-soft);}

/* multi-select = same menu + chips inside the box */
.selectbox.multi{height:auto;min-height:46px;padding:6px 15px 6px 6px;flex-wrap:wrap;justify-content:flex-start;}
.selectbox.multi .chev{margin-left:auto;}
.mchip{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);color:var(--accent);
  border:1px solid transparent;font-size:13px;font-weight:650;border-radius:var(--r-pill);padding:5px 7px 5px 11px;
  animation:chipIn var(--t2) var(--ease);}
[data-theme="dark"] .mchip{color:var(--accent);}
.mchip .x{width:15px;height:15px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12px;line-height:1;transition:background var(--t1);}
.mchip .x:hover{background:rgba(52,21,238,.15);}
@keyframes chipIn{from{opacity:0;transform:scale(.85);}to{opacity:1;transform:none;}}

/* radio + checkbox */
.choice{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:15px;color:var(--text);}
.choice input{appearance:none;margin:0;width:20px;height:20px;flex:none;cursor:pointer;position:relative;
  border:1.5px solid var(--line-strong);background:var(--bg-card);
  transition:border-color var(--t2) var(--ease),background var(--t2) var(--ease),transform var(--t1) var(--ease);}
.choice input:hover{border-color:var(--accent);}
.choice input:active{transform:scale(.88);}
.choice input:focus-visible{outline:none;box-shadow:var(--ring);}
.choice.cb input{border-radius:6px;}
.choice.rd input{border-radius:50%;}
.choice input:checked{background:var(--accent);border-color:var(--accent);}
.choice.cb input:checked::after{content:"";position:absolute;left:6px;top:2.5px;width:5px;height:10px;
  border:2px solid #fff;border-top:0;border-left:0;transform:rotate(42deg);}
[data-theme="dark"] .choice.cb input:checked::after{border-color:var(--ink);}
.choice.rd input:checked{background:var(--bg-card);}
.choice.rd input:checked::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--accent);
  animation:chipIn var(--t2) var(--ease);}
.choice-group{display:flex;flex-direction:column;gap:12px;}
.choice-group.row{flex-direction:row;flex-wrap:wrap;gap:18px;}

/* toggle */
.switch{position:relative;width:48px;height:28px;flex:none;display:inline-block;cursor:pointer;}
.switch input{position:absolute;opacity:0;inset:0;margin:0;cursor:pointer;}
.switch .tr{position:absolute;inset:0;border-radius:999px;background:var(--bg-sunken);
  border:1.5px solid var(--line-strong);transition:background var(--t3) var(--ease),border-color var(--t3);}
.switch .th{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;background:var(--bg-card);
  box-shadow:var(--sh-1);transition:transform var(--t3) var(--ease),width var(--t1);}
.switch input:active ~ .th{width:24px;}
.switch input:checked + .tr{background:var(--accent);border-color:var(--accent);}
.switch input:checked ~ .th{transform:translateX(20px);}
.switch input:checked:active ~ .th{transform:translateX(16px);}
.switch input:focus-visible + .tr{box-shadow:var(--ring);}

/* date picker (styled native) */
.input.date{cursor:pointer;}
.input.date::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.55;}

/* file upload */
.upload{border:1.5px dashed var(--line-strong);border-radius:var(--r-md);background:var(--bg-card);
  padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;cursor:pointer;
  transition:border-color var(--t2) var(--ease),background var(--t2) var(--ease);}
.upload:hover,.upload.drag{border-color:var(--accent);background:var(--accent-soft);}
.upload .uic{width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;}
.upload b{font-size:14.5px;}
.upload span{font-size:13px;color:var(--text-3);}

/* ──────────────────────────────────────────────
   3 · CONTAINERS & LAYOUT
   ────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--sh-1);
  transition:transform var(--t3) var(--ease),box-shadow var(--t3) var(--ease),border-color var(--t3);}
.card.lift:hover{transform:translateY(-4px);box-shadow:var(--sh-2);}
.card h4{font-size:18px;}
.card .ctext{font-size:14.5px;color:var(--text-2);}

/* feature card — the three pillars */
.pillar{padding:30px 28px;gap:14px;position:relative;overflow:hidden;}
.pillar .pnum{font-size:13px;font-weight:700;letter-spacing:.1em;color:var(--text-3);}
.pillar .pico{width:46px;height:46px;border-radius:var(--r-md);background:var(--accent-soft);color:var(--accent);
  display:flex;align-items:center;justify-content:center;transition:transform var(--t3) var(--ease);}
.pillar:hover .pico{transform:translateY(-3px);}
.pillar h4{font-size:21px;}
.pillar::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform var(--t4) var(--ease);}
.pillar:hover::after{transform:scaleX(1);}

/* frosted pill / badge */
.fpill{display:inline-flex;align-items:center;gap:8px;height:32px;padding:0 15px;border-radius:var(--r-pill);
  font-size:13px;font-weight:650;letter-spacing:.02em;
  background:color-mix(in srgb,var(--bg-card) 55%,transparent);backdrop-filter:blur(10px);
  border:1px solid var(--line-strong);color:var(--text);}
.ink-band .fpill{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#fff;}
.badge{display:inline-flex;align-items:center;gap:6px;height:24px;padding:0 11px;border-radius:var(--r-pill);
  font-size:12px;font-weight:700;letter-spacing:.04em;border:1px solid var(--line);background:var(--bg-sunken);color:var(--text-2);}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}
.badge.success{color:var(--success);background:var(--success-bg);border-color:var(--success-bd);}
.badge.warn{color:var(--warn);background:var(--warn-bg);border-color:var(--warn-bd);}
.badge.danger{color:var(--danger);background:var(--danger-bg);border-color:var(--danger-bd);}
.badge.info{color:var(--info);background:var(--info-bg);border-color:var(--info-bd);}

/* divider */
.divider{border:none;height:1px;background:var(--line);margin:0;}
.divider.labeled{display:flex;align-items:center;gap:14px;background:none;height:auto;}
.divider.labeled::before,.divider.labeled::after{content:"";flex:1;height:1px;background:var(--line);}
.divider.labeled span{font-size:12px;font-weight:650;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);}

/* modal */
.modal-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-3);padding:26px;max-width:420px;width:100%;display:flex;flex-direction:column;gap:12px;position:relative;}
.modal-card .mx{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;border:none;
  background:transparent;color:var(--text-3);font-size:17px;cursor:pointer;transition:background var(--t1),color var(--t1);}
.modal-card .mx:hover{background:var(--bg-hover);color:var(--text);}
.modal-card h4{font-size:19px;}
.modal-card .mact{display:flex;gap:10px;justify-content:flex-end;margin-top:8px;}
.modal-overlay{position:fixed;inset:0;z-index:90;background:rgba(11,14,22,.45);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity var(--t3) var(--ease-io);}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal-overlay .modal-card{transform:translateY(14px) scale(.97);transition:transform var(--t3) var(--ease);}
.modal-overlay.open .modal-card{transform:none;}

/* accordion */
.acc{border:1px solid var(--line);border-radius:var(--r-md);background:var(--bg-card);overflow:hidden;}
.acc + .acc{margin-top:10px;}
.acc .acc-h{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;
  padding:18px 20px;background:none;border:none;cursor:pointer;font-size:15.5px;font-weight:650;color:var(--text);text-align:left;
  transition:background var(--t1);}
.acc .acc-h:hover{background:var(--bg-hover);}
.acc .acc-h .pm{flex:none;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line-strong);
  display:inline-flex;align-items:center;justify-content:center;position:relative;transition:transform var(--t3) var(--ease),border-color var(--t2),background var(--t2);}
.acc .acc-h .pm::before,.acc .acc-h .pm::after{content:"";position:absolute;background:var(--text-2);transition:background var(--t2);}
.acc .acc-h .pm::before{width:9px;height:1.5px;}
.acc .acc-h .pm::after{width:1.5px;height:9px;}
.acc.open .acc-h .pm{transform:rotate(135deg);background:var(--accent);border-color:var(--accent);}
.acc.open .acc-h .pm::before,.acc.open .acc-h .pm::after{background:#fff;}
.acc .acc-b{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--t3) var(--ease);}
.acc.open .acc-b{grid-template-rows:1fr;}
.acc .acc-b > div{overflow:hidden;}
.acc .acc-b p{padding:0 20px 18px;font-size:14.5px;color:var(--text-2);max-width:70ch;}

/* tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);position:relative;}
.tab{font-size:14.5px;font-weight:600;color:var(--text-2);background:none;border:none;
  padding:12px 18px;cursor:pointer;position:relative;transition:color var(--t2);}
.tab:hover{color:var(--text);}
.tab.active{color:var(--text);}
.tab::after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--grad);
  border-radius:2px;transform:scaleX(0);transition:transform var(--t3) var(--ease);}
.tab.active::after{transform:scaleX(1);}

/* ──────────────────────────────────────────────
   4 · FEEDBACK & STATUS
   ────────────────────────────────────────────── */
.alert{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);
  border:1px solid var(--line);background:var(--bg-card);font-size:14.5px;}
.alert .aic{flex:none;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;margin-top:1px;}
.alert b{display:block;font-size:14.5px;}
.alert p{font-size:13.5px;color:var(--text-2);}
.alert.success{background:var(--success-bg);border-color:var(--success-bd);}
.alert.success .aic{background:var(--success);}
.alert.warn{background:var(--warn-bg);border-color:var(--warn-bd);}
.alert.warn .aic{background:var(--warn);}
.alert.danger{background:var(--danger-bg);border-color:var(--danger-bd);}
.alert.danger .aic{background:var(--danger);}
.alert.info{background:var(--info-bg);border-color:var(--info-bd);}
.alert.info .aic{background:var(--info);}

/* toast */
.toast-zone{position:fixed;bottom:22px;right:22px;z-index:99;display:flex;flex-direction:column;gap:10px;align-items:flex-end;}
.toast{display:flex;align-items:center;gap:12px;background:var(--ink);color:#F6F6F2;
  border:1px solid rgba(255,255,255,.14);border-radius:var(--r-md);padding:13px 18px;font-size:14.5px;font-weight:550;
  box-shadow:var(--sh-3);animation:toastIn var(--t3) var(--ease);}
.toast .tdot{width:8px;height:8px;border-radius:50%;background:#3DDCA8;flex:none;}
.toast.out{animation:toastOut var(--t3) var(--ease-io) forwards;}
@keyframes toastIn{from{opacity:0;transform:translateY(12px) scale(.97);}to{opacity:1;transform:none;}}
@keyframes toastOut{to{opacity:0;transform:translateY(8px);}}

/* tooltip */
.tip{position:relative;display:inline-flex;}
.tip .bubble{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(3px);
  background:var(--ink);color:#F6F6F2;font-size:12.5px;font-weight:550;padding:7px 12px;border-radius:var(--r-sm);
  white-space:nowrap;box-shadow:var(--sh-2);opacity:0;pointer-events:none;
  transition:opacity var(--t2) var(--ease),transform var(--t2) var(--ease);}
.tip .bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--ink);}
.tip:hover .bubble,.tip:focus-within .bubble{opacity:1;transform:translateX(-50%);}

/* progress bar */
.progress{height:8px;border-radius:999px;background:var(--bg-sunken);overflow:hidden;width:100%;}
.progress .fill{height:100%;border-radius:999px;background:var(--accent);width:0;
  transition:width var(--t4) var(--ease);}

/* spinner */
.spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--bg-sunken);
  border-top-color:var(--accent);animation:btnspin .8s linear infinite;}

/* skeleton */
.skel{border-radius:var(--r-sm);background:linear-gradient(90deg,var(--bg-sunken) 25%,var(--bg-hover) 50%,var(--bg-sunken) 75%);
  background-size:200% 100%;animation:skel 1.5s linear infinite;}
@keyframes skel{from{background-position:200% 0;}to{background-position:-200% 0;}}

/* empty state */
.empty{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:36px 24px;}
.empty .eic{width:52px;height:52px;border-radius:var(--r-md);background:var(--bg-sunken);color:var(--text-3);
  display:flex;align-items:center;justify-content:center;}
.empty b{font-size:16px;}
.empty p{font-size:14px;color:var(--text-2);max-width:34ch;}

/* ──────────────────────────────────────────────
   5 · NAVIGATION
   ────────────────────────────────────────────── */
.topnav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 22px;
  border-radius:var(--r-pill);transition:background var(--t3) var(--ease-io),box-shadow var(--t3),border-color var(--t3);
  border:1px solid transparent;}
.topnav.transparent{background:transparent;color:#fff;}
.topnav.solid{background:color-mix(in srgb,var(--bg-card) 88%,transparent);backdrop-filter:blur(12px);
  border-color:var(--line);box-shadow:var(--sh-2);color:var(--text);}
.topnav .links{display:flex;align-items:center;gap:2px;}
.navlink{font-size:14.5px;font-weight:550;padding:8px 14px;border-radius:var(--r-pill);cursor:pointer;
  text-decoration:none;color:inherit;opacity:.72;transition:opacity var(--t1),background var(--t1);}
.navlink:hover{opacity:1;background:rgba(127,127,127,.1);}
.navlink.active{opacity:1;font-weight:700;}
.brandbit{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;}
.brandbit .markbox{height:23px;width:auto;display:inline-flex;}
.brandbit .name{font-family:'Chakra Petch',sans-serif;font-weight:600;letter-spacing:.13em;font-size:14px;text-transform:uppercase;}

/* breadcrumb */
.crumbs{display:flex;align-items:center;gap:8px;font-size:13.5px;flex-wrap:wrap;}
.crumbs a{color:var(--text-3);text-decoration:none;transition:color var(--t1);}
.crumbs a:hover{color:var(--text);}
.crumbs .sep{color:var(--line-strong);}
.crumbs .cur{color:var(--text);font-weight:650;}

/* pagination */
.pager{display:flex;align-items:center;gap:6px;}
.pager button{min-width:38px;height:38px;border-radius:var(--r-sm);border:1px solid transparent;background:none;
  font-size:14px;font-weight:600;color:var(--text-2);cursor:pointer;
  transition:background var(--t1),color var(--t1),border-color var(--t1),transform var(--t1);}
.pager button:hover{background:var(--bg-hover);color:var(--text);}
.pager button:active{transform:scale(.92);}
.pager button.cur{background:var(--accent);color:#fff;}
[data-theme="dark"] .pager button.cur{color:var(--ink);}
.pager button[disabled]{opacity:.35;pointer-events:none;}

/* mobile menu */
.mobile-shell{width:300px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--bg-card);
  box-shadow:var(--sh-2);overflow:hidden;}
.mobile-shell .mhead{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line);}
.burger{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--line-strong);background:none;cursor:pointer;
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;transition:border-color var(--t2);}
.burger:hover{border-color:var(--text);}
.burger i{display:block;width:16px;height:1.6px;background:var(--text);transition:transform var(--t3) var(--ease),opacity var(--t2);}
.mobile-shell.open .burger i:nth-child(1){transform:translateY(6.6px) rotate(45deg);}
.mobile-shell.open .burger i:nth-child(2){opacity:0;}
.mobile-shell.open .burger i:nth-child(3){transform:translateY(-6.6px) rotate(-45deg);}
.mobile-shell .mlinks{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--t3) var(--ease);}
.mobile-shell.open .mlinks{grid-template-rows:1fr;}
.mobile-shell .mlinks > div{overflow:hidden;display:flex;flex-direction:column;}
.mobile-shell .mlinks a{padding:14px 20px;font-size:15.5px;font-weight:600;text-decoration:none;color:var(--text);
  border-bottom:1px solid var(--line);transition:background var(--t1),padding-left var(--t2) var(--ease);}
.mobile-shell .mlinks a:hover{background:var(--bg-hover);padding-left:26px;}
.mobile-shell .mlinks .mcta{padding:16px 20px;border-bottom:none;}

/* footer */
.footer-demo{background:var(--ink);color:rgba(246,246,242,.7);border-radius:var(--r-lg);overflow:hidden;position:relative;}
.footer-demo .fin{position:relative;z-index:2;padding:42px 38px 28px;display:flex;flex-direction:column;gap:32px;}
.footer-demo .fcols{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.footer-demo .fbrand{display:flex;flex-direction:column;gap:14px;max-width:300px;}
.footer-demo .fbrand p{font-size:13.5px;line-height:1.6;}
.footer-demo .fnav{display:flex;gap:56px;flex-wrap:wrap;}
.footer-demo .fnav .col{display:flex;flex-direction:column;gap:10px;}
.footer-demo .fnav .col b{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;}
.footer-demo .fnav .col a{font-size:14px;text-decoration:none;color:rgba(246,246,242,.62);transition:color var(--t1);}
.footer-demo .fnav .col a:hover{color:#fff;}
.footer-demo .fbase{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:13px;color:rgba(246,246,242,.45);}
.socials{display:flex;gap:10px;}
.socials a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);color:rgba(246,246,242,.75);
  display:inline-flex;align-items:center;justify-content:center;transition:border-color var(--t2),color var(--t2),transform var(--t2) var(--ease);}
.socials a:hover{border-color:#fff;color:#fff;transform:translateY(-2px);}
.socials svg{width:16px;height:16px;}

/* ──────────────────────────────────────────────
   6 · DATA DISPLAY
   ────────────────────────────────────────────── */
.tablewrap{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--bg-card);overflow:hidden;}
.dtbl{width:100%;border-collapse:collapse;font-size:14.5px;}
.dtbl th{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);
  text-align:left;padding:13px 18px;border-bottom:1px solid var(--line);cursor:pointer;user-select:none;white-space:nowrap;
  transition:color var(--t1);}
.dtbl th:hover{color:var(--text);}
.dtbl th .arr{display:inline-block;margin-left:5px;opacity:0;transition:opacity var(--t1),transform var(--t2) var(--ease);}
.dtbl th.sorted .arr{opacity:1;}
.dtbl th.desc .arr{transform:rotate(180deg);}
.dtbl td{padding:15px 18px;border-bottom:1px solid var(--line);color:var(--text-2);}
.dtbl td b{color:var(--text);font-weight:650;}
.dtbl tbody tr{transition:background var(--t1);}
.dtbl tbody tr:hover{background:var(--bg-hover);}
.dtbl tbody tr.sel{background:var(--accent-soft);}
.dtbl tbody tr:last-child td{border-bottom:none;}

/* stat card */
.stat{gap:6px;}
.stat .slabel{font-size:13.5px;font-weight:650;color:var(--text-2);}
.stat .snum{font-size:42px;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--text);
  font-variant-numeric:tabular-nums;}
.stat .strend{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;}
.stat .strend.up{color:var(--success);}
.stat .strend.down{color:var(--danger);}
.stat .strend .ta{display:inline-block;}
.stat .strend.down .ta{transform:rotate(180deg);}

/* chips & avatar */
.chip{display:inline-flex;align-items:center;gap:7px;height:30px;padding:0 14px;border-radius:var(--r-pill);
  font-size:13.5px;font-weight:600;border:1px solid var(--line-strong);background:var(--bg-card);color:var(--text);
  cursor:pointer;transition:border-color var(--t2),background var(--t2),transform var(--t1);}
.chip:hover{border-color:var(--text);}
.chip:active{transform:scale(.95);}
.chip.on{background:var(--ink);border-color:var(--ink);color:#F6F6F2;}
[data-theme="dark"] .chip.on{background:#F6F6F2;border-color:#F6F6F2;color:var(--ink);}
.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:750;flex:none;
  border:1.5px solid var(--line);}
.avatar.sm{width:30px;height:30px;font-size:11.5px;}
.avstack{display:flex;}
.avstack .avatar{margin-left:-10px;border:2px solid var(--bg-card);}
.avstack .avatar:first-child{margin-left:0;}

/* step progress indicator */
.steps{display:flex;align-items:center;gap:0;width:100%;}
.steps .st{display:flex;align-items:center;gap:9px;}
.steps .sdot{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);background:var(--bg-card);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-3);
  transition:background var(--t2),border-color var(--t2),color var(--t2);}
.steps .st.done .sdot,.steps .st.cur .sdot{background:var(--accent);border-color:var(--accent);color:#fff;}
[data-theme="dark"] .steps .st.done .sdot,[data-theme="dark"] .steps .st.cur .sdot{color:var(--ink);}
.steps .st.cur .sname{color:var(--text);}
.steps .sname{font-size:13.5px;font-weight:650;color:var(--text-3);white-space:nowrap;}
.steps .sline{flex:1;height:1.5px;background:var(--line-strong);margin:0 12px;min-width:24px;}
.steps .sline.done{background:var(--accent);}
