/* =========================================================
   Supplysy — design tokens + base
   ========================================================= */

:root{
  /* Palette: Páramo (default) */
  --bg:        #F5F1EA;
  --bg-elev:   #FBF8F2;
  --bg-card:   #FFFFFF;
  --ink:       #1A1714;
  --ink-2:     #4A4742;
  --ink-3:     #8A857C;
  --line:      #E7E1D5;
  --line-2:    #D8D1C0;
  --accent:    #2D4438;       /* evergreen */
  --accent-ink:#FFFFFF;
  --blush:     #E8C5BD;       /* rose */
  --blush-2:   #C48A82;
  --amber:     #C68A3A;       /* cold-chain warning */
  --danger:    #A33A2A;
  --success:   #2D7A4F;

  /* Type */
  --f-display: "Newsreader", "Times New Roman", serif;
  --f-ui:      "Albert Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --f-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Density */
  --pad-1:  6px;
  --pad-2:  10px;
  --pad-3:  14px;
  --pad-4:  20px;
  --pad-5:  28px;
  --pad-6:  40px;
  --pad-7:  64px;
  --radius: 14px;
  --radius-sm: 8px;

  --row-h:  44px;

  --shadow-card: 0 1px 0 rgba(0,0,0,.02), 0 12px 28px -16px rgba(26,23,20,.18);
  --shadow-lg:   0 24px 60px -28px rgba(26,23,20,.35);
}

/* ---- palette: Mercado ---- */
:root[data-palette="mercado"]{
  --bg:        #F7F6F2;
  --bg-elev:   #FFFFFF;
  --bg-card:   #FFFFFF;
  --ink:       #0F1011;
  --ink-2:     #3D4148;
  --ink-3:     #8A8F96;
  --line:      #E5E5E0;
  --line-2:    #D2D2CC;
  --accent:    #C84B31;
  --accent-ink:#FFFFFF;
  --blush:     #F2D6D0;
  --blush-2:   #C84B31;
}

/* ---- palette: Volcán ---- */
:root[data-palette="volcan"]{
  --bg:        #F4EDE0;
  --bg-elev:   #FBF6EA;
  --bg-card:   #FFFFFF;
  --ink:       #1F1410;
  --ink-2:     #56433A;
  --ink-3:     #8E7A6B;
  --line:      #E6D8C4;
  --line-2:    #D3C0A2;
  --accent:    #1F4B3A;
  --accent-ink:#FBF6EA;
  --blush:     #E6B5A2;
  --blush-2:   #BF4F2B;
}

/* ---- palette: Manglar (coastal) — for shrimp/banana origins ---- */
:root[data-palette="manglar"]{
  --bg:        #EEF2EE;
  --bg-elev:   #F7F9F6;
  --bg-card:   #FFFFFF;
  --ink:       #142322;
  --ink-2:     #3F5755;
  --ink-3:     #7E938F;
  --line:      #DDE4DD;
  --line-2:    #C2CFCB;
  --accent:    #2A6F6A;   /* mangrove teal */
  --accent-ink:#F4F8F6;
  --blush:     #F6C1A8;   /* coral */
  --blush-2:   #E07A5F;
}

/* ---- palette: Tueste (coffee roast) — for cafe + cacao ---- */
:root[data-palette="tueste"]{
  --bg:        #F0EAE0;
  --bg-elev:   #F8F4EC;
  --bg-card:   #FFFFFF;
  --ink:       #1F1410;
  --ink-2:     #4C342A;
  --ink-3:     #8C7464;
  --line:      #E3D7C2;
  --line-2:    #CFBE9F;
  --accent:    #6B3F25;   /* medium roast */
  --accent-ink:#F8F4EC;
  --blush:     #E8C9A0;   /* cream foam */
  --blush-2:   #C68A3A;   /* caramel */
}

/* ---- palette: Pacífico (ocean) — for seafood and cool light ---- */
:root[data-palette="pacifico"]{
  --bg:        #F0F2F5;
  --bg-elev:   #F9FAFB;
  --bg-card:   #FFFFFF;
  --ink:       #0F1B2A;
  --ink-2:     #3D4F65;
  --ink-3:     #7C8DA3;
  --line:      #DDE3EB;
  --line-2:    #BFC9D6;
  --accent:    #1F4F73;   /* deep ocean */
  --accent-ink:#F9FAFB;
  --blush:     #C9DDEB;   /* sky */
  --blush-2:   #3C82BC;   /* azure */
}

/* ---- palette: Andes (premium minimal) — universal ---- */
:root[data-palette="andes"]{
  --bg:        #F4F4F2;
  --bg-elev:   #FAFAF8;
  --bg-card:   #FFFFFF;
  --ink:       #1A1A1B;
  --ink-2:     #4A4946;
  --ink-3:     #8A8884;
  --line:      #E5E3DE;
  --line-2:    #CFCCC4;
  --accent:    #5C5854;   /* warm stone */
  --accent-ink:#FAFAF8;
  --blush:     #D9C9B5;   /* warm sand */
  --blush-2:   #A8856B;   /* stone tan */
}

/* ---- dark mode ---- */
:root[data-theme="dark"]{
  --bg:        #14120F;
  --bg-elev:   #1B1916;
  --bg-card:   #1F1D1A;
  --ink:       #F2EDE3;
  --ink-2:     #B7B1A4;
  --ink-3:     #7C766A;
  --line:      #2C2924;
  --line-2:    #3A362F;
  --accent:    #B8C9B0;
  --accent-ink:#14120F;
  --blush:     #D9A89F;
  --blush-2:   #C48A82;
  --shadow-card: 0 1px 0 rgba(255,255,255,.02), 0 18px 40px -24px rgba(0,0,0,.6);
}
:root[data-theme="dark"][data-palette="mercado"]{
  --bg:#0F0F0E;--bg-elev:#181816;--bg-card:#1C1C1A;--ink:#F3F2EE;--ink-2:#B0AEA8;--ink-3:#75736D;
  --line:#2A2A28;--line-2:#3A3A36;--accent:#E66A4F;--blush:#E66A4F;
}
:root[data-theme="dark"][data-palette="volcan"]{
  --bg:#1A120D;--bg-elev:#221812;--bg-card:#271C15;--ink:#F4EAD8;--ink-2:#BFAA94;--ink-3:#897665;
  --line:#352719;--line-2:#473322;--accent:#E6B5A2;--blush:#D88565;
}
:root[data-theme="dark"][data-palette="manglar"]{
  --bg:#0E1716;--bg-elev:#13201E;--bg-card:#172624;--ink:#E8F0EE;--ink-2:#A5BAB6;--ink-3:#6E837F;
  --line:#1E2E2C;--line-2:#2B403D;--accent:#5FB5AD;--blush:#E07A5F;--blush-2:#E07A5F;
}
:root[data-theme="dark"][data-palette="tueste"]{
  --bg:#15100B;--bg-elev:#1D1611;--bg-card:#241C15;--ink:#F1E6D4;--ink-2:#BFAB8E;--ink-3:#8A7660;
  --line:#322519;--line-2:#453322;--accent:#D89A56;--blush:#C68A3A;--blush-2:#C68A3A;
}
:root[data-theme="dark"][data-palette="pacifico"]{
  --bg:#0A111A;--bg-elev:#101A26;--bg-card:#14202F;--ink:#E6ECF3;--ink-2:#A8B5C4;--ink-3:#6E7E92;
  --line:#1D2A3A;--line-2:#2A3B50;--accent:#7BB0E0;--blush:#3C82BC;--blush-2:#3C82BC;
}
:root[data-theme="dark"][data-palette="andes"]{
  --bg:#111110;--bg-elev:#191917;--bg-card:#1E1E1C;--ink:#EDECE8;--ink-2:#AFADA7;--ink-3:#76746E;
  --line:#2A2925;--line-2:#3B3933;--accent:#D9C9B5;--blush:#A8856B;--blush-2:#A8856B;
}

/* ---- density: compact ---- */
:root[data-density="compact"]{
  --pad-1: 4px; --pad-2: 7px; --pad-3: 10px; --pad-4: 14px;
  --pad-5: 18px; --pad-6: 26px; --pad-7: 40px;
  --row-h: 36px;
}

/* ---- editorial vs commercial tone (typography emphasis) ---- */
:root[data-tone="comercial"]{
  --f-display: "Albert Sans", ui-sans-serif, sans-serif;
}

/* =========================================================
   Reset
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: var(--f-ui);
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button{font-family:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}
input,select,textarea{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4,h5,h6,p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}

/* =========================================================
   Type utilities
   ========================================================= */
.serif{font-family:var(--f-display);font-weight:400;letter-spacing:-0.01em}
.mono{font-family:var(--f-mono);font-feature-settings:"tnum" 1,"ss01" 1}
.eyebrow{
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);
}
.h1{font-family:var(--f-display);font-size:54px;line-height:1.02;letter-spacing:-0.025em;font-weight:400}
.h2{font-family:var(--f-display);font-size:36px;line-height:1.08;letter-spacing:-0.02em;font-weight:400}
.h3{font-family:var(--f-display);font-size:24px;line-height:1.18;letter-spacing:-0.015em;font-weight:400}
.h4{font-size:15px;font-weight:600;letter-spacing:-.005em}
.t-body{font-size:14px;color:var(--ink-2);line-height:1.55}
.t-small{font-size:12px;color:var(--ink-3)}
.num{font-family:var(--f-mono);font-feature-settings:"tnum" 1}

/* =========================================================
   App shell
   ========================================================= */
.app{
  display:grid;
  grid-template-columns: 240px 1fr;
  min-height:100vh;
  background:var(--bg);
}
.app[data-density="compact"]{grid-template-columns:200px 1fr}

.sidebar{
  border-right:1px solid var(--line);
  background:var(--bg-elev);
  padding: var(--pad-4) var(--pad-3);
  display:flex; flex-direction:column; gap: var(--pad-4);
  position:sticky; top:0; height:100vh; overflow-y:auto;
}
.brand{display:flex;align-items:center;gap:10px;padding:0 4px}
.brand-mark{
  width:28px;height:28px;border-radius:50%;
  background: radial-gradient(circle at 35% 30%, var(--blush) 0%, var(--blush-2) 55%, var(--accent) 100%);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
}
.brand-name{font-family:var(--f-display);font-size:22px;letter-spacing:-.02em}
.brand-tld{color:var(--ink-3);font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;margin-left:2px}

.nav-group{display:flex;flex-direction:column;gap:1px}
.nav-group-label{
  font-family:var(--f-mono);font-size:9.5px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--ink-3);padding:6px 8px;
}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding: 8px 10px; border-radius: 9px;
  font-size:13px; color:var(--ink-2);
  transition: background .12s, color .12s;
  cursor:default;
}
.nav-item:hover{background:rgba(0,0,0,.04);color:var(--ink)}
.nav-item.active{background:var(--ink);color:var(--bg)}
:root[data-theme="dark"] .nav-item.active{background:var(--ink);color:var(--bg)}
.nav-item .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.5}
.nav-item .badge{
  margin-left:auto;font-family:var(--f-mono);font-size:10px;
  padding:1px 6px;border-radius:999px;background:rgba(0,0,0,.06);color:var(--ink-2);
}
.nav-item.active .badge{background:rgba(255,255,255,.18);color:var(--bg)}

.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:var(--pad-2)}
.org-card{
  display:flex;align-items:center;gap:10px;padding:10px;
  border:1px solid var(--line);border-radius:10px;background:var(--bg-card);
}
.org-card .avatar{width:30px;height:30px;border-radius:50%;background:var(--blush);display:grid;place-items:center;font-weight:600;color:var(--accent)}
.org-card .name{font-size:12.5px;font-weight:600}
.org-card .role{font-size:10.5px;color:var(--ink-3);font-family:var(--f-mono);letter-spacing:.05em;text-transform:uppercase}

/* topbar */
.topbar{
  position:sticky;top:0;z-index:5;
  display:flex;align-items:center;gap: var(--pad-3);
  padding: var(--pad-3) var(--pad-6);
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}
.search{
  flex:1; display:flex;align-items:center;gap:10px;
  background:var(--bg-card);border:1px solid var(--line);
  border-radius:10px; padding: 8px 12px; max-width:520px;
}
.search input{flex:1;border:0;outline:0;background:transparent;font-size:13px}
.search .kbd{
  font-family:var(--f-mono);font-size:10px;padding:2px 6px;
  border-radius:5px;background:var(--bg);border:1px solid var(--line);color:var(--ink-3);
}
.icon-btn{
  width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  border:1px solid var(--line); background:var(--bg-card); color:var(--ink-2);
}
.icon-btn:hover{color:var(--ink)}

.lang-toggle{
  display:flex; padding:2px; background:var(--bg-card); border:1px solid var(--line);
  border-radius:8px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.08em;
}
.lang-toggle button{padding:4px 8px;border-radius:6px;color:var(--ink-3)}
.lang-toggle button.on{background:var(--ink);color:var(--bg)}

/* main */
.main{padding: var(--pad-6) var(--pad-6) var(--pad-7);max-width:1400px}

/* =========================================================
   Buttons / chips / pills
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding: 10px 16px; border-radius: 10px; font-size:13px; font-weight:500;
  border:1px solid var(--line); background:var(--bg-card); color:var(--ink);
  transition:transform .08s ease, background .12s ease, border-color .12s ease;
}
.btn:hover{border-color:var(--line-2)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-primary:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn-accent{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-ghost{background:transparent;border-color:transparent}
.btn-ghost:hover{background:rgba(0,0,0,.04)}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}
.btn-lg{padding:14px 22px;font-size:14px}
.btn-block{width:100%}

.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px; border-radius:999px; font-size:11.5px;
  background:var(--bg-card); border:1px solid var(--line); color:var(--ink-2);
}
.chip.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.6}

.tag{
  display:inline-flex;align-items:center;gap:5px;
  padding: 3px 8px; border-radius: 6px; font-family:var(--f-mono);
  font-size:10.5px;letter-spacing:.04em;
  background:var(--bg); border:1px solid var(--line); color:var(--ink-2);
}
.tag-cert{background:color-mix(in oklab, var(--success) 12%, transparent);
  border-color:color-mix(in oklab, var(--success) 30%, transparent);
  color: var(--success)}
.tag-fresh{background:color-mix(in oklab, var(--blush) 35%, transparent);
  border-color:color-mix(in oklab, var(--blush-2) 40%, transparent);
  color: var(--blush-2)}

/* =========================================================
   Cards
   ========================================================= */
.card{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
}
.card-pad{padding: var(--pad-4)}

/* =========================================================
   Photo placeholders (we use SVG striped placeholders w/ caption)
   ========================================================= */
.photo{
  position:relative; overflow:hidden; background:var(--bg);
  background-image:
    repeating-linear-gradient(135deg,
      color-mix(in oklab, var(--blush) 60%, transparent) 0 1px,
      transparent 1px 9px),
    radial-gradient(ellipse at 30% 25%, color-mix(in oklab, var(--blush) 80%, transparent), transparent 60%),
    linear-gradient(180deg, color-mix(in oklab, var(--blush) 35%, transparent), color-mix(in oklab, var(--accent) 22%, transparent));
}
.photo.green{
  background-image:
    repeating-linear-gradient(135deg,
      color-mix(in oklab, var(--accent) 22%, transparent) 0 1px,
      transparent 1px 9px),
    radial-gradient(ellipse at 30% 70%, color-mix(in oklab, var(--accent) 30%, transparent), transparent 65%),
    linear-gradient(180deg, color-mix(in oklab, var(--accent) 18%, transparent), color-mix(in oklab, var(--accent) 35%, transparent));
}
.photo.bone{
  background-image:
    repeating-linear-gradient(135deg, color-mix(in oklab,var(--ink) 6%, transparent) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, var(--bg-elev), var(--bg));
}
.photo.cafe{
  background-image:
    repeating-linear-gradient(135deg, oklch(0.42 0.06 50 / 0.30) 0 1px, transparent 1px 9px),
    radial-gradient(ellipse at 30% 30%, oklch(0.55 0.10 55 / 0.45), transparent 60%),
    linear-gradient(180deg, oklch(0.85 0.05 70 / 0.6), oklch(0.42 0.07 45 / 0.55));
}
.photo.cacao{
  background-image:
    repeating-linear-gradient(135deg, oklch(0.30 0.05 40 / 0.40) 0 1px, transparent 1px 9px),
    radial-gradient(ellipse at 60% 35%, oklch(0.42 0.07 40 / 0.55), transparent 65%),
    linear-gradient(180deg, oklch(0.55 0.07 45 / 0.50), oklch(0.28 0.05 35 / 0.65));
}
.photo.banano{
  background-image:
    repeating-linear-gradient(135deg, oklch(0.65 0.13 95 / 0.30) 0 1px, transparent 1px 9px),
    radial-gradient(ellipse at 30% 30%, oklch(0.88 0.15 100 / 0.55), transparent 65%),
    linear-gradient(180deg, oklch(0.92 0.10 105 / 0.6), oklch(0.65 0.13 95 / 0.45));
}
.photo.camaron{
  background-image:
    repeating-linear-gradient(135deg, oklch(0.62 0.16 25 / 0.30) 0 1px, transparent 1px 9px),
    radial-gradient(ellipse at 30% 30%, oklch(0.78 0.13 30 / 0.55), transparent 65%),
    linear-gradient(180deg, oklch(0.86 0.10 35 / 0.55), oklch(0.60 0.16 25 / 0.45));
}
.photo .ph-caption{
  position:absolute; left:10px; bottom:10px;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.1em;
  text-transform:uppercase; color: var(--ink);
  background: color-mix(in oklab, var(--bg-card) 80%, transparent);
  padding: 4px 8px; border-radius: 4px;
  border:1px solid var(--line);
}
.photo.green .ph-caption, .photo .ph-caption{color:var(--ink)}

/* =========================================================
   Tables
   ========================================================= */
.table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.table th{
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-3);
  text-align:left;padding: 10px 12px; border-bottom:1px solid var(--line);
  font-weight:500;
}
.table td{
  padding: 12px; border-bottom:1px solid var(--line); vertical-align:middle;
}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background: color-mix(in oklab, var(--bg-elev) 60%, transparent)}

/* =========================================================
   Form
   ========================================================= */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11.5px;color:var(--ink-3);font-weight:500;
  font-family:var(--f-mono);letter-spacing:.06em;text-transform:uppercase}
.input, .select{
  height:40px; border:1px solid var(--line); background:var(--bg-card);
  border-radius:10px; padding: 0 12px; font-size:13.5px; outline:0;
  transition: border-color .12s;
}
.input:focus, .select:focus{border-color:var(--ink-2)}
textarea.input{min-height:80px;padding:10px 12px}

/* =========================================================
   Misc
   ========================================================= */
.divider{height:1px;background:var(--line);width:100%;margin:var(--pad-4) 0}
.row{display:flex;align-items:center;gap:var(--pad-2)}
.col{display:flex;flex-direction:column;gap:var(--pad-2)}
.grow{flex:1}
.spacer-1{height:var(--pad-1)}
.spacer-2{height:var(--pad-2)}
.spacer-3{height:var(--pad-3)}
.spacer-4{height:var(--pad-4)}
.spacer-5{height:var(--pad-5)}
.spacer-6{height:var(--pad-6)}

.kv{display:flex;justify-content:space-between;gap:12px;font-size:13px;padding:6px 0}
.kv .k{color:var(--ink-3)}
.kv .v{font-family:var(--f-mono);font-feature-settings:"tnum" 1}

/* progress bar / shipment timeline */
.bar{
  height:6px;border-radius:999px;background:var(--line);overflow:hidden;
}
.bar > i{display:block;height:100%;background:var(--accent);border-radius:inherit;
  transition: width .3s ease;}

/* tooltip-ish badge for live updates */
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(45,122,79,.45)}70%{box-shadow:0 0 0 10px rgba(45,122,79,0)}100%{box-shadow:0 0 0 0 rgba(45,122,79,0)}}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}

/* tweaks panel transform-origin override so it doesn't get hidden */
.twk-panel{font-family:var(--f-ui) !important}

/* =========================================================
   MOBILE APP — native-feel UI for ≤720px
   ========================================================= */
.m-app{
  display:flex; flex-direction:column;
  height:100dvh; width:100%;
  background:var(--bg); color:var(--ink);
  font-family:var(--f-ui);
}

/* ── Top bar ── */
.m-topbar{
  display:flex; align-items:center; gap:8px;
  padding: 10px 14px;
  background:var(--bg-card);
  border-bottom:1px solid var(--line);
  position:relative; z-index:30;
}
.m-brand{display:flex; align-items:center; gap:8px}
.m-brand-name{font-family:var(--f-display); font-size:19px; font-weight:600; letter-spacing:-.01em}
.m-toggle{
  display:flex; padding:2px; background:var(--bg-elev); border:1px solid var(--line); border-radius:8px;
}
.m-toggle button{
  background:transparent; border:none; padding:5px 10px; font-size:11px;
  font-family:var(--f-mono); color:var(--ink-3); cursor:pointer; border-radius:6px;
  letter-spacing:.05em;
}
.m-toggle button.on{background:var(--ink); color:var(--bg-card)}
.m-icon-btn{
  width:36px; height:36px; border-radius:9px;
  background:transparent; border:none; cursor:pointer;
  display:grid; place-items:center; color:var(--ink);
}
.m-icon-btn:hover{background:var(--bg-elev)}

/* ── Scroll region ── */
.m-scroll{
  flex:1; overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding-bottom: 80px; /* bottom nav clearance */
}
.m-home{display:flex; flex-direction:column; gap:24px; padding-top:8px}
.m-section{padding: 12px 16px}
.m-section-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:14px}
.m-section-head h2{margin:0; font-size:22px; letter-spacing:-.01em}
.m-link{background:transparent; border:none; font-size:12px; font-family:var(--f-mono); color:var(--ink-3); cursor:pointer; letter-spacing:.04em}

/* ── Hero ── */
.m-hero{
  margin: 8px 16px 0;
  padding: 24px 22px 22px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 18px;
}
.m-hero-eyebrow{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-3);
  display:flex; align-items:center; gap:6px; margin-bottom:14px;
}
.m-hero-title{font-size:30px; line-height:1.05; letter-spacing:-.02em; text-wrap:pretty; margin:0}
.m-hero-sub{font-size:13.5px; color:var(--ink-2); margin-top:12px; line-height:1.45; text-wrap:pretty}
.m-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding: 12px 20px; margin-top:18px;
  background:var(--ink); color:var(--bg-card);
  border:none; border-radius:11px; font-size:14px; font-weight:600;
  cursor:pointer; font-family:var(--f-ui);
}
.m-cta-primary{background:var(--accent); color:var(--accent-ink)}

/* ── Category grid ── */
.m-cat-grid{display:grid; grid-template-columns: 1fr 1fr; gap: 12px}
.m-cat-tile{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:14px; padding:0; overflow:hidden;
  display:flex; flex-direction:column; cursor:pointer;
  text-align:left;
}
.m-cat-tile-info{padding: 10px 12px 12px; display:flex; flex-direction:column; gap:2px}
.m-cat-tile-count{font-size:11px; font-family:var(--f-mono); color:var(--ink-3)}

/* ── Horizontal scroll (auctions) ── */
.m-h-scroll{
  display:flex; gap:12px; overflow-x:auto; padding: 0 16px 4px;
  margin: 0 -16px; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling:touch;
}
.m-h-scroll::-webkit-scrollbar{display:none}
.m-auction-card{
  flex: 0 0 200px;
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:12px; overflow:hidden;
  scroll-snap-align: start;
}
.m-auction-card-info{padding: 10px 12px}

/* ── Product grid + card ── */
.m-prod-grid{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
.m-prod-card{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:12px; overflow:hidden;
  display:flex; flex-direction:column;
  cursor:pointer; padding:0; text-align:left;
}
.m-prod-card-info{padding: 8px 10px 10px; display:flex; flex-direction:column; gap:4px}
.m-prod-card-sub{font-size:11px; color:var(--ink-3)}
.m-prod-card-price-row{display:flex; justify-content:space-between; align-items:flex-end; margin-top:4px}
.m-prod-card-price-row .serif{font-size:17px; line-height:1}
.m-prod-card-unit{font-size:10px; font-family:var(--f-mono); color:var(--ink-3); margin-left:3px}
.m-add-btn{
  width:28px; height:28px; border-radius:8px;
  background:var(--ink); color:var(--bg-card);
  display:grid; place-items:center;
}

/* ── Catalog tab pills ── */
.m-cat-tabs{
  display:flex; gap:8px; overflow-x:auto;
  padding: 14px 16px;
  border-bottom:1px solid var(--line);
  background:var(--bg-card);
  scroll-snap-type: x mandatory;
}
.m-cat-tabs::-webkit-scrollbar{display:none}
.m-cat-pill{
  flex-shrink:0;
  display:flex; align-items:center; gap:7px;
  padding: 8px 14px; border-radius: 999px;
  background:var(--bg-elev); border:1px solid var(--line);
  font-size:13px; color:var(--ink-2);
  cursor:pointer; font-family:var(--f-ui); font-weight:500;
  scroll-snap-align: start;
  white-space:nowrap;
}
.m-cat-pill.on{background:var(--ink); color:var(--bg-card); border-color:var(--ink)}

/* ── Search ── */
.m-search{padding-top:8px}
.m-search-box{
  display:flex; align-items:center; gap:10px;
  margin: 0 16px;
  padding: 12px 14px;
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:12px;
}
.m-search-box input{
  flex:1; background:transparent; border:none; outline:none;
  font-size:15px; color:var(--ink); font-family:var(--f-ui);
}

/* ── Specs ── */
.m-spec{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:10px; padding: 10px 12px;
}
.m-spec-k{
  font-family:var(--f-mono); font-size:9.5px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:4px;
}
.m-spec-v{font-size:18px; letter-spacing:-.01em}

/* ── KV row ── */
.m-kv{display:flex; justify-content:space-between; align-items:center; padding:6px 0; font-size:13px}

/* ── Sticky bottom CTA (detail page) ── */
.m-sticky-cta{
  position:fixed; bottom: 64px; left:0; right:0; z-index:20;
  background: var(--bg-card); border-top:1px solid var(--line);
  padding: 14px 16px;
  display:flex; align-items:center; gap:12px;
  box-shadow: 0 -8px 20px -10px rgba(0,0,0,.08);
}

/* ── Overlay (detail / producer / category pages) ── */
.m-overlay{
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:var(--bg); z-index:40;
  overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  animation: slideUp .25s cubic-bezier(.2,.8,.2,1);
}
@keyframes slideUp{from{transform:translateY(20px); opacity:0} to{transform:translateY(0); opacity:1}}
.m-overlay-header{
  position:sticky; top:0; z-index:5;
  display:flex; align-items:center; gap:8px;
  padding: 10px 12px;
  background:var(--bg-card); border-bottom:1px solid var(--line);
}
.m-overlay-header.transparent{
  background:transparent; border:none;
}
.m-overlay-header.transparent .m-icon-btn{
  background:rgba(0,0,0,.4); color:white; backdrop-filter:blur(8px);
}
.m-overlay-header .m-icon-btn svg{transform:rotate(180deg)}
.m-scroll-inner{padding-bottom: 24px}

/* ── Category hero (inside category overlay) ── */
.m-cat-hero{margin-bottom:8px}

/* ── Bottom navigation ── */
.m-bottom-nav{
  position:fixed; bottom:0; left:0; right:0; z-index:50;
  display:flex; height: 64px;
  background:var(--bg-card); border-top:1px solid var(--line);
  padding-bottom: env(safe-area-inset-bottom);
}
.m-bottom-tab{
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
  background:transparent; border:none; cursor:pointer;
  color:var(--ink-3); font-family:var(--f-ui); font-size:10.5px;
  transition: color .15s;
  padding: 0;
}
.m-bottom-tab.on{color:var(--ink)}

/* ── Palette sheet (bottom sheet) ── */
.m-overlay-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:60;
}
.m-palette-sheet{
  position:fixed; bottom:0; left:0; right:0; z-index:70;
  background:var(--bg-card); border-top-left-radius:18px; border-top-right-radius:18px;
  padding: 12px 16px 24px;
  animation: slideUpSheet .25s cubic-bezier(.2,.8,.2,1);
  max-height: 80vh; overflow-y:auto;
}
@keyframes slideUpSheet{from{transform:translateY(100%)} to{transform:translateY(0)}}
.m-sheet-handle{
  width:36px; height:4px; border-radius:2px; background:var(--line-2);
  margin: 0 auto 14px;
}
.m-sheet-title{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:10px; padding: 0 4px;
}
.m-palette-list{display:flex; flex-direction:column; gap:2px}
.m-palette-item{
  display:flex; align-items:center; gap:14px;
  padding: 12px 12px; border-radius:10px;
  background:transparent; border:none; cursor:pointer;
}
.m-palette-item.on{background:var(--bg-elev)}
.m-palette-swatch{
  display:flex; width:48px; height:28px; border-radius:6px;
  overflow:hidden; border:1px solid var(--line);
}
.m-palette-swatch span{flex:1}

/* =========================================================
   Responsive — tablet & mobile (DESKTOP shell adaptations)
   ========================================================= */

/* Hide the hamburger on desktop */
.topbar-hamburger{display:none !important}

/* ── Tablet & below: collapse sidebar to overlay ── */
@media (max-width: 960px) and (min-width: 721px){
  .app{
    grid-template-columns: 1fr !important;
  }
  .sidebar{
    position: fixed; top:0; left:0; bottom:0;
    width: 280px; z-index: 90;
    transform: translateX(-100%);
    transition: transform .25s ease;
    box-shadow: 0 0 60px -20px rgba(0,0,0,.4);
  }
  .app.sidebar-open .sidebar{
    transform: translateX(0);
  }
  .app.sidebar-open::after{
    content:''; position:fixed; inset:0; background:rgba(0,0,0,.4);
    z-index: 80;
  }
  .topbar-hamburger{display:grid !important}
  .topbar .search{max-width: 200px}
}
