/* ============================================================
   织布 ERP — Redesign Design System
   "Loom" — 工业精密 × Stripe 级清晰
   单一可移植 stylesheet:tokens + base + components
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&family=Noto+Sans+SC:wght@400;500;700&display=swap');

/* ============================================================
   1. TOKENS
   ============================================================ */
:root{
  /* type families */
  --font-sans:'IBM Plex Sans','Noto Sans SC',-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',Consolas,monospace;

  /* neutral canvas — cool, crisp */
  --bg-app:#F4F5F8;
  --bg-sunken:#ECEEF2;
  --surface:#FFFFFF;
  --surface-2:#FAFBFC;
  --surface-3:#F4F6F9;

  /* ink */
  --ink-1:#10131A;
  --ink-2:#535B6A;
  --ink-3:#878F9C;
  --ink-4:#AAB1BC;
  --on-accent:#FFFFFF;

  /* lines */
  --line:#E7EAEF;
  --line-2:#D9DDE4;
  --line-strong:#C3C9D2;

  /* accent — anchored on #2563EB */
  --accent:#2563EB;
  --accent-hover:#1D4ED8;
  --accent-press:#1B40B5;
  --accent-soft:#ECF1FE;
  --accent-soft-2:#DCE7FD;
  --accent-ink:#1E40AF;
  --ring:0 0 0 3px rgba(37,99,235,.15);

  /* status — one of each, unified */
  --ok:#15803D;     --ok-soft:#E6F4EB;   --ok-ink:#15723A;
  --warn:#B45309;   --warn-soft:#FBF0DF; --warn-ink:#92510B;
  --danger:#DC2626; --danger-soft:#FBEAEA; --danger-ink:#B5201F;
  --info:#2563EB;   --info-soft:#ECF1FE; --info-ink:#1E40AF;

  /* categorical (产品/颜色/类型 tag) */
  --cat-purple:#6D44C9; --cat-purple-soft:#EEE9FB;
  --cat-teal:#0E7490;   --cat-teal-soft:#E0F2F4;
  --cat-slate:#475569;  --cat-slate-soft:#EDF0F4;
  --cat-rose:#BE185D;   --cat-rose-soft:#FBE7F0;

  /* radii */
  --r-xs:4px; --r-sm:6px; --r-md:8px; --r-lg:12px; --r-pill:999px;

  /* shadow — restrained, overlays only */
  --shadow-sm:0 1px 2px rgba(16,19,26,.05),0 1px 1px rgba(16,19,26,.03);
  --shadow-md:0 6px 18px rgba(16,19,26,.09),0 2px 5px rgba(16,19,26,.05);
  --shadow-pop:0 18px 44px rgba(16,19,26,.16),0 4px 12px rgba(16,19,26,.08);

  /* spacing scale */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px; --s7:32px; --s8:40px;

  /* type scale */
  --fs-display:26px; --lh-display:32px;
  --fs-h1:19px; --lh-h1:26px;
  --fs-h2:15px; --lh-h2:22px;
  --fs-base:13px; --lh-base:20px;
  --fs-sm:12px;  --lh-sm:18px;
  --fs-xs:11px;  --lh-xs:16px;
  --fs-2xs:10px; --lh-2xs:14px;

  /* density-driven row height (toggled via [data-density]) */
  --row-h:36px;
  --cell-px:12px;
}
:root[data-density="compact"]{ --row-h:30px; --cell-px:10px; }
:root[data-density="cozy"]{ --row-h:42px; --cell-px:14px; }

/* ============================================================
   2. BASE
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-sans);
  font-size:var(--fs-base);
  line-height:var(--lh-base);
  color:var(--ink-1);
  background:var(--bg-app);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv05" 1,"ss01" 1;
}
.num,.tnum,td.num,.kpi-value,.mono{font-variant-numeric:tabular-nums}
.mono,code,kbd{font-family:var(--font-mono)}
::selection{background:var(--accent-soft-2);color:var(--accent-ink)}
:focus-visible{outline:none;box-shadow:var(--ring)}
a{color:var(--accent);text-decoration:none}

/* scrollbars */
*{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}

/* ============================================================
   3. TYPOGRAPHY HELPERS
   ============================================================ */
.t-display{font-size:var(--fs-display);line-height:var(--lh-display);font-weight:600;letter-spacing:-.01em}
.t-h1{font-size:var(--fs-h1);line-height:var(--lh-h1);font-weight:600;letter-spacing:-.005em}
.t-h2{font-size:var(--fs-h2);line-height:var(--lh-h2);font-weight:600}
.t-h3{font-size:var(--fs-base);line-height:var(--lh-base);font-weight:600}
.t-sm{font-size:var(--fs-sm);line-height:var(--lh-sm)}
.t-xs{font-size:var(--fs-xs);line-height:var(--lh-xs)}
.t-label{font-size:var(--fs-2xs);line-height:var(--lh-2xs);font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap}
.t-muted{color:var(--ink-2)}
.t-faint{color:var(--ink-3)}
.t-strong{font-weight:600}
.t-tabular{font-variant-numeric:tabular-nums}

/* ============================================================
   4. BUTTONS
   ============================================================ */
.btn{
  --bh:32px;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  height:var(--bh);padding:0 13px;
  font-family:inherit;font-size:var(--fs-sm);font-weight:500;line-height:1;
  color:var(--ink-1);background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r-sm);
  cursor:pointer;white-space:nowrap;
  transition:background .13s,border-color .13s,box-shadow .13s,color .13s;
}
.btn:hover{background:var(--surface-3);border-color:var(--line-strong)}
.btn:active{background:var(--bg-sunken)}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent);box-shadow:0 1px 1.5px rgba(16,19,26,.10)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-primary:active{background:var(--accent-press)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--surface-3);color:var(--ink-1)}
.btn-subtle{background:var(--accent-soft);border-color:transparent;color:var(--accent-ink)}
.btn-subtle:hover{background:var(--accent-soft-2)}
.btn-danger{background:var(--surface);border-color:var(--line-2);color:var(--danger)}
.btn-danger:hover{background:var(--danger-soft);border-color:var(--danger-soft)}
.btn-sm{--bh:27px;padding:0 9px;font-size:var(--fs-xs)}
.btn-lg{--bh:38px;padding:0 18px;font-size:var(--fs-base)}
.btn-icon{width:var(--bh);padding:0}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ============================================================
   5. BADGES / TAGS / CHIPS
   ============================================================ */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  height:20px;padding:0 8px;
  font-size:var(--fs-xs);font-weight:500;line-height:1;
  border-radius:var(--r-pill);white-space:nowrap;
}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.85;flex-shrink:0}
.badge-plain::before{display:none}
.badge-ok{background:var(--ok-soft);color:var(--ok-ink)}
.badge-warn{background:var(--warn-soft);color:var(--warn-ink)}
.badge-danger{background:var(--danger-soft);color:var(--danger-ink)}
.badge-info{background:var(--info-soft);color:var(--info-ink)}
.badge-neutral{background:var(--surface-3);color:var(--ink-2)}
.badge-purple{background:var(--cat-purple-soft);color:var(--cat-purple)}
.badge-teal{background:var(--cat-teal-soft);color:var(--cat-teal)}
.badge-slate{background:var(--cat-slate-soft);color:var(--cat-slate)}
.badge-rose{background:var(--cat-rose-soft);color:var(--cat-rose)}

/* code chip — roll codes / 库位 / 批次 (industrial signature) */
.code-chip{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:var(--fs-xs);font-weight:500;
  color:var(--ink-1);background:var(--surface-3);
  border:1px solid var(--line);border-radius:var(--r-xs);
  padding:2px 6px;letter-spacing:-.01em;white-space:nowrap;
}
.code-chip.accent{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-ink)}

/* color dot */
.swatch{width:13px;height:13px;border-radius:var(--r-xs);border:1px solid rgba(16,19,26,.14);flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.4)}

/* avatar */
.avatar{border-radius:50%;display:grid;place-items:center;font-weight:600;flex-shrink:0;font-family:var(--font-sans)}
.av-blue{background:var(--accent-soft);color:var(--accent-ink)}
.av-purple{background:var(--cat-purple-soft);color:var(--cat-purple)}
.av-teal{background:var(--cat-teal-soft);color:var(--cat-teal)}
.av-amber{background:var(--warn-soft);color:var(--warn-ink)}
.av-rose{background:var(--cat-rose-soft);color:var(--cat-rose)}
.av-slate{background:var(--cat-slate-soft);color:var(--cat-slate)}

/* ============================================================
   6. SURFACES / CARDS
   ============================================================ */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card-pad{padding:var(--s5)}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);padding:14px var(--s5);border-bottom:1px solid var(--line)}
.card-head > :first-child{min-width:0}
.card-title{font-size:var(--fs-h2);font-weight:600;letter-spacing:-.003em;white-space:nowrap}
.card-sub{font-size:var(--fs-sm);color:var(--ink-3);margin-top:2px}
.card-body{padding:var(--s5)}

/* ============================================================
   7. KPI / STAT
   ============================================================ */
.kpi-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.kpi{background:var(--surface);padding:14px var(--s5) var(--s4)}
.kpi-label{font-size:var(--fs-2xs);font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:6px}
.kpi-value{font-size:24px;line-height:30px;font-weight:600;letter-spacing:-.01em;color:var(--ink-1);margin-top:7px;display:flex;align-items:baseline;gap:5px}
.kpi-value .unit{font-size:var(--fs-sm);font-weight:500;color:var(--ink-3)}
.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:var(--fs-xs);font-weight:500;margin-top:6px;white-space:nowrap}
.kpi-value{white-space:nowrap}
.kpi-delta.up{color:var(--ok-ink)}
.kpi-delta.down{color:var(--danger-ink)}
.kpi-delta.flat{color:var(--ink-3)}

/* ============================================================
   8. DATA TABLE — elastic columns, sticky header + sticky right action col
   ============================================================ */
.table-wrap{position:relative;overflow:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg)}
table.dt{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--fs-sm);min-width:max-content}
table.dt th,table.dt td{
  padding:0 var(--cell-px);height:var(--row-h);
  text-align:left;vertical-align:middle;white-space:nowrap;
  border-bottom:1px solid var(--line);
}
table.dt thead th{
  position:sticky;top:0;z-index:3;
  background:var(--surface-2);
  font-size:var(--fs-xs);font-weight:600;color:var(--ink-2);
  letter-spacing:.01em;border-bottom:1px solid var(--line-2);
  user-select:none;
}
table.dt tbody tr{transition:background .1s}
table.dt tbody tr:hover td{background:var(--surface-3)}
table.dt tbody tr.is-selected td{background:var(--accent-soft)}
table.dt tbody tr:last-child td{border-bottom:none}
table.dt td.num,table.dt th.num{text-align:right;font-variant-numeric:tabular-nums}
table.dt td.col-strong{font-weight:600;color:var(--ink-1)}
table.dt td.col-muted{color:var(--ink-2)}
.cell-clip{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* sticky right action column */
table.dt th.col-actions,table.dt td.col-actions{
  position:sticky;right:0;z-index:2;
  text-align:right;
  background:var(--surface);
  box-shadow:-1px 0 0 var(--line),-10px 0 14px -10px rgba(16,19,26,.18);
}
table.dt thead th.col-actions{z-index:4;background:var(--surface-2)}
table.dt tbody tr:hover td.col-actions{background:var(--surface-3)}
table.dt tbody tr.is-selected td.col-actions{background:var(--accent-soft)}
.row-actions{display:inline-flex;align-items:center;gap:4px;justify-content:flex-end}

/* sticky left (checkbox / primary key) — optional */
table.dt th.col-pin,table.dt td.col-pin{position:sticky;left:0;z-index:2;background:var(--surface);box-shadow:1px 0 0 var(--line)}
table.dt thead th.col-pin{z-index:4;background:var(--surface-2)}
table.dt tbody tr:hover td.col-pin{background:var(--surface-3)}

/* table footer / total row */
.dt-foot{display:flex;align-items:center;gap:var(--s6);padding:9px var(--s4);background:var(--surface-2);border-top:1px solid var(--line-2);font-size:var(--fs-sm)}
.dt-foot .tot{display:flex;align-items:baseline;gap:6px}
.dt-foot .tot b{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink-1)}

/* ============================================================
   9. FILTER / TOOLBAR
   ============================================================ */
.toolbar{display:flex;align-items:center;gap:var(--s2);flex-wrap:wrap}
.toolbar .spacer{flex:1}
.seg{display:inline-flex;padding:2px;background:var(--surface-3);border:1px solid var(--line);border-radius:var(--r-sm)}
.seg button{height:24px;padding:0 11px;border:0;background:transparent;color:var(--ink-2);font-family:inherit;font-size:var(--fs-xs);font-weight:500;border-radius:var(--r-xs);cursor:pointer;transition:.12s;white-space:nowrap}
.seg button:hover{color:var(--ink-1)}
.seg button.active{background:var(--surface);color:var(--ink-1);box-shadow:var(--shadow-sm)}

.search{position:relative;display:inline-flex;align-items:center}
.search svg{position:absolute;left:9px;width:15px;height:15px;color:var(--ink-3);pointer-events:none}
.search input{height:32px;padding:0 11px 0 30px;min-width:220px}

.filterbar{display:flex;align-items:flex-end;gap:var(--s3);flex-wrap:wrap;padding:var(--s4);background:var(--surface-2);border-bottom:1px solid var(--line)}

/* ============================================================
   10. FORMS
   ============================================================ */
.field{display:flex;flex-direction:column;gap:5px;min-width:0}
.field > label{font-size:var(--fs-xs);font-weight:500;color:var(--ink-2)}
.field .req{color:var(--danger)}
.input,.field input:not([type=checkbox]):not([type=radio]),.field select,.field textarea{
  height:32px;padding:0 11px;width:100%;
  font-family:inherit;font-size:var(--fs-sm);color:var(--ink-1);
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-sm);
  transition:border-color .12s,box-shadow .12s;
}
.field textarea,textarea.input{height:auto;padding:8px 11px;line-height:1.6;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23878F9C' stroke-width='2.2'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 9px center;padding-right:28px}
.input:focus,.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-4)}
.field input:disabled,.field select:disabled{background:var(--surface-3);color:var(--ink-3);cursor:not-allowed}
.field-hint{font-size:var(--fs-xs);color:var(--ink-3)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4)}
.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
.form-full{grid-column:1/-1}
.input-affix{display:flex;align-items:center;gap:0}
.input-affix .suffix{display:inline-flex;align-items:center;height:32px;padding:0 10px;background:var(--surface-3);border:1px solid var(--line-2);border-left:0;border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:var(--fs-xs);color:var(--ink-3)}
.input-affix input{border-radius:var(--r-sm) 0 0 var(--r-sm)}

/* toggle */
.toggle{width:34px;height:20px;border-radius:99px;border:0;background:var(--line-strong);position:relative;cursor:pointer;transition:background .15s;flex-shrink:0;padding:0}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:left .15s}
.toggle.on{background:var(--accent)}
.toggle.on::after{left:16px}

/* checkbox */
.cbx{width:16px;height:16px;border:1px solid var(--line-strong);border-radius:var(--r-xs);background:var(--surface);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:.12s}
.cbx.on{background:var(--accent);border-color:var(--accent)}
.cbx.on::after{content:'';width:4px;height:8px;border:2px solid #fff;border-top:0;border-left:0;transform:rotate(42deg) translateY(-1px)}

/* ============================================================
   11. TABS
   ============================================================ */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line)}
.tab{position:relative;padding:9px 13px;font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);cursor:pointer;background:none;border:0;font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s}
.tab:hover{color:var(--ink-1)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab .count{margin-left:6px;font-size:var(--fs-xs);color:var(--ink-3);font-variant-numeric:tabular-nums}
.tab.active .count{color:var(--accent)}

/* ============================================================
   12. MODAL (lighter) + DRAWER
   ============================================================ */
.scrim{position:fixed;inset:0;background:rgba(16,19,26,.34);backdrop-filter:blur(1.5px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:7vh 20px 20px}
.modal{width:100%;max-width:640px;max-height:86vh;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-pop);display:flex;flex-direction:column;overflow:hidden}
@keyframes modalIn{from{transform:translateY(10px) scale(.985)}}
@media (prefers-reduced-motion:no-preference){
  .modal{animation:modalIn .2s cubic-bezier(.2,.8,.2,1)}
}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);padding:15px var(--s5);border-bottom:1px solid var(--line)}
.modal-head h3{font-size:var(--fs-h2);font-weight:600}
.modal-head .sub{font-size:var(--fs-sm);color:var(--ink-3);margin-top:2px;white-space:nowrap}
.modal-x{width:28px;height:28px;border:0;background:transparent;color:var(--ink-3);border-radius:var(--r-sm);cursor:pointer;display:grid;place-items:center;font-size:18px;line-height:1}
.modal-x:hover{background:var(--surface-3);color:var(--ink-1)}
.modal-body{padding:var(--s5);overflow:auto}
.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:var(--s2);padding:13px var(--s5);border-top:1px solid var(--line);background:var(--surface-2)}
.modal-foot .spacer{flex:1}

/* ============================================================
   13. MISC — breadcrumb, progress, divider, empty, skeleton, segbar
   ============================================================ */
.crumbs{display:flex;align-items:center;gap:7px;font-size:var(--fs-sm);color:var(--ink-3)}
.crumbs a,.crumbs button{color:var(--ink-2);background:none;border:0;font:inherit;cursor:pointer;padding:0}
.crumbs a:hover,.crumbs button:hover{color:var(--accent)}
.crumbs .sep{color:var(--ink-4)}
.crumbs .cur{color:var(--ink-1);font-weight:500}

.meter{height:6px;border-radius:99px;background:var(--bg-sunken);overflow:hidden}
.meter > i{display:block;height:100%;border-radius:99px;background:var(--accent)}

.divider{height:1px;background:var(--line);border:0}
.vdiv{width:1px;align-self:stretch;background:var(--line)}

.empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 20px;text-align:center;color:var(--ink-3)}
.empty svg{width:34px;height:34px;color:var(--ink-4)}

.skel{background:linear-gradient(90deg,var(--surface-3) 25%,var(--bg-sunken) 37%,var(--surface-3) 63%);background-size:400% 100%;animation:skel 1.3s ease infinite;border-radius:var(--r-xs)}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* drilldown progress strip (产品→颜色→匹) */
.drill{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:var(--surface)}
.drill .node{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--fs-xs);font-weight:500;color:var(--ink-2);cursor:pointer;background:none;border:0;font-family:inherit}
.drill .node:hover{background:var(--surface-3);color:var(--ink-1)}
.drill .node.active{color:var(--accent);background:var(--accent-soft)}
.drill .node .n{font-variant-numeric:tabular-nums;color:var(--ink-3)}
.drill .arrow{color:var(--ink-4);padding:0 2px}

/* toast */
.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:1200;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{display:flex;align-items:center;gap:9px;padding:10px 14px;background:var(--ink-1);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-pop);font-size:var(--fs-sm);animation:toastIn .22s cubic-bezier(.2,.8,.2,1)}
.toast svg{width:16px;height:16px}
.toast .ok{color:#6EE7A0}
@keyframes toastIn{from{transform:translateY(10px);opacity:0}}

/* util */
.row{display:flex;align-items:center;gap:var(--s2)}
.col{display:flex;flex-direction:column}
.gap1{gap:var(--s1)}.gap2{gap:var(--s2)}.gap3{gap:var(--s3)}.gap4{gap:var(--s4)}
.between{justify-content:space-between}
.center{align-items:center}
.wrap{flex-wrap:wrap}
.grow{flex:1}
.mt2{margin-top:var(--s2)}.mt3{margin-top:var(--s3)}.mt4{margin-top:var(--s4)}.mt5{margin-top:var(--s5)}
.hide{display:none!important}
