﻿/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/77ccc4b6-07c2-4a1e-9918-8be7f8623d6d.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/463a030f-f501-4517-a601-e4e87cb3fea4.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/b55d9327-a92f-45b0-846c-2dfb986da494.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/c55a4790-cdd3-43c0-8ab1-f2163a84f9e9.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/27b15efc-ba0c-4ea5-a64d-58c499bbddf5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/77ccc4b6-07c2-4a1e-9918-8be7f8623d6d.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/463a030f-f501-4517-a601-e4e87cb3fea4.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/b55d9327-a92f-45b0-846c-2dfb986da494.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/c55a4790-cdd3-43c0-8ab1-f2163a84f9e9.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/27b15efc-ba0c-4ea5-a64d-58c499bbddf5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/77ccc4b6-07c2-4a1e-9918-8be7f8623d6d.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/463a030f-f501-4517-a601-e4e87cb3fea4.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/b55d9327-a92f-45b0-846c-2dfb986da494.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/c55a4790-cdd3-43c0-8ab1-f2163a84f9e9.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/27b15efc-ba0c-4ea5-a64d-58c499bbddf5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/77ccc4b6-07c2-4a1e-9918-8be7f8623d6d.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/463a030f-f501-4517-a601-e4e87cb3fea4.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/b55d9327-a92f-45b0-846c-2dfb986da494.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/c55a4790-cdd3-43c0-8ab1-f2163a84f9e9.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/27b15efc-ba0c-4ea5-a64d-58c499bbddf5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/77ccc4b6-07c2-4a1e-9918-8be7f8623d6d.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/463a030f-f501-4517-a601-e4e87cb3fea4.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/b55d9327-a92f-45b0-846c-2dfb986da494.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/c55a4790-cdd3-43c0-8ab1-f2163a84f9e9.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/27b15efc-ba0c-4ea5-a64d-58c499bbddf5.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/86351a01-8aa2-40c0-8b4b-0bc52e18571a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/7652eec2-923c-4113-9484-ab307e7e519d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/883d6903-73e1-49da-9c55-347aec3f5545.woff2") format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/12d1ef54-515c-4bd3-bfa8-b04b799d0023.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/8f542c52-fe95-4ffa-93eb-c69f1ae9c723.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/a8e954e4-877f-4e15-9163-946b483dc52b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/86351a01-8aa2-40c0-8b4b-0bc52e18571a.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/7652eec2-923c-4113-9484-ab307e7e519d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* symbols2 */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/883d6903-73e1-49da-9c55-347aec3f5545.woff2") format('woff2');
  unicode-range: U+2000-2001, U+2004-2008, U+200A, U+23B8-23BD, U+2500-259F;
}
/* vietnamese */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/12d1ef54-515c-4bd3-bfa8-b04b799d0023.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/8f542c52-fe95-4ffa-93eb-c69f1ae9c723.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Geist Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/dealer-portal/prototype/a8e954e4-877f-4e15-9163-946b483dc52b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ============================================================================
   DataSales Portal — design system
   White-label dealer portal. Everything keys off --accent (one token).
   Theme: [data-theme=light|dark]  •  Style: [data-style=minimal|soft|contrast]
   Density: [data-density=compact|regular|comfy]
   Responsive: container queries on .ds-shell (container-name: app)
   ============================================================================ */

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Geist","Helvetica Neue",Helvetica,Arial,"Segoe UI",system-ui,sans-serif;
  background:#e9e9ef;color:#1b1a22;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.tnum{font-variant-numeric:tabular-nums}

/* ---- Tokens : light (default) -------------------------------------------- */
.portal{
  --accent:#6c4de0;
  --accent-ink:#ffffff;
  --accent-lite:color-mix(in srgb, var(--accent) 60%, #fff);
  --accent-grad:linear-gradient(135deg,#8a78f0,#6a4de0);

  --bg:#f3f3f8;
  --surface:#ffffff;
  --surface-2:#fafafb;
  --surface-3:#f2f2f7;
  --border:#e8e8ef;
  --border-2:#dcdce6;
  --text:#1b1a22;
  --text-2:#5c5a6b;
  --text-3:#908ea1;

  --ok:#1f9d57; --ok-soft:#e6f6ec;
  --warn:#c98a12; --warn-soft:#fbf2dd;
  --danger:#d8483f; --danger-soft:#fbe9e7;

  /* sidebar (light by default) */
  --side-bg:#ffffff;
  --side-text:#1b1a22;
  --side-text-2:#6a6878;
  --side-active-bg:color-mix(in srgb, var(--accent) 10%, transparent);
  --side-active-text:var(--accent);
  --side-border:var(--border);
  --side-logo: dark;

  /* derived accent */
  --accent-soft:color-mix(in srgb, var(--accent) 11%, var(--surface));
  --accent-soft-2:color-mix(in srgb, var(--accent) 6%, var(--surface));
  --accent-strong:color-mix(in srgb, var(--accent) 88%, #000);
  --accent-line:color-mix(in srgb, var(--accent) 28%, var(--border));
  --on-accent-soft:color-mix(in srgb, var(--accent) 78%, #000);

  /* radii */
  --r-xs:6px; --r-sm:8px; --r:11px; --r-lg:14px; --r-xl:20px; --r-pill:999px;
  /* shadows */
  --sh-1:0 1px 2px rgba(24,22,40,.06), 0 1px 3px rgba(24,22,40,.05);
  --sh-2:0 4px 16px rgba(24,22,40,.08), 0 2px 6px rgba(24,22,40,.05);
  --sh-pop:0 12px 40px rgba(24,22,40,.18);
  --ring:0 0 0 3px color-mix(in srgb, var(--accent) 28%, transparent);

  /* density */
  --ctl-h:40px; --fs:15px; --gutter:24px; --card-pad:20px;

  color:var(--text);
  background:var(--bg);
  font-size:var(--fs);
  line-height:1.45;
}

/* ---- Tokens : dark ------------------------------------------------------- */
.portal[data-theme="dark"]{
  --bg:#0f0e15;
  --surface:#1a1823;
  --surface-2:#201e2b;
  --surface-3:#272533;
  --border:#2b2937;
  --border-2:#393748;
  --text:#f2f1f8;
  --text-2:#a7a5b9;
  --text-3:#76748a;

  --ok-soft:color-mix(in srgb,#1f9d57 22%, var(--surface));
  --warn-soft:color-mix(in srgb,#c98a12 22%, var(--surface));
  --danger-soft:color-mix(in srgb,#d8483f 22%, var(--surface));

  --side-bg:#161420;
  --side-text:#f2f1f8;
  --side-text-2:#9b99ad;
  --side-active-bg:color-mix(in srgb, var(--accent) 22%, transparent);
  --side-active-text:#fff;
  --side-border:#252331;
  --side-logo: light;

  --accent-soft:color-mix(in srgb, var(--accent) 24%, var(--surface));
  --accent-soft-2:color-mix(in srgb, var(--accent) 14%, var(--surface));
  --accent-strong:color-mix(in srgb, var(--accent) 84%, #fff);
  --on-accent-soft:color-mix(in srgb, var(--accent) 30%, #fff);
  --sh-1:0 1px 2px rgba(0,0,0,.4);
  --sh-2:0 6px 22px rgba(0,0,0,.5);
  --sh-pop:0 16px 50px rgba(0,0,0,.6);
}

/* ---- Style variants ------------------------------------------------------ */
/* minimal : flat, hairline borders, near-zero shadow, tighter radii */
.portal[data-style="minimal"]{
  --r-xs:4px; --r-sm:5px; --r:7px; --r-lg:9px; --r-xl:12px;
  --sh-1:none; --sh-2:0 1px 0 rgba(24,22,40,.04);
}
.portal[data-style="minimal"] .card,
.portal[data-style="minimal"] .panel{border-color:var(--border-2)}
/* soft : airy, large radii, soft shadows, tinted surfaces */
.portal[data-style="soft"]{
  --r-xs:8px; --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:28px;
  --bg:#f1f0f8;
  --surface-2:color-mix(in srgb, var(--accent) 4%, #fff);
  --sh-1:0 2px 8px rgba(24,22,40,.06);
  --sh-2:0 10px 30px rgba(60,40,140,.10), 0 3px 10px rgba(24,22,40,.05);
  --card-pad:22px;
}
.portal[data-style="soft"][data-theme="dark"]{--bg:#0f0e15;--surface-2:#211f2e}
/* contrast : dark sidebar always, bolder accent presence */
.portal[data-style="contrast"]{
  --side-bg:#171522;
  --side-text:#f4f3fa;
  --side-text-2:#9d9bb0;
  --side-active-bg:var(--accent);
  --side-active-text:var(--accent-ink);
  --side-border:#262433;
  --side-logo: light;
}

/* ---- Density ------------------------------------------------------------- */
.portal[data-density="compact"]{--ctl-h:34px; --fs:14px; --gutter:18px; --card-pad:16px}
.portal[data-density="comfy"]{--ctl-h:46px; --fs:16px; --gutter:30px; --card-pad:26px}

/* ============================================================================
   Shell + responsive layout (container queries)
   ============================================================================ */
.ds-shell{
  container:app / inline-size;
  position:relative;
  width:100%; height:100%;
  background:var(--bg);
  overflow:hidden;
  display:flex; flex-direction:column;
}
.ds-app{
  display:grid;
  grid-template-columns:1fr;
  grid-template-rows:auto 1fr;
  height:100%;
  min-height:0;
}
.ds-side{display:none}
.ds-main{display:flex; flex-direction:column; min-width:0; min-height:0; overflow:hidden}
.ds-content{
  flex:1; min-height:0; overflow-y:auto; overflow-x:hidden;
  padding:var(--gutter);
  padding-bottom:calc(var(--gutter) + 76px); /* room for bottom nav on mobile */
  scrollbar-width:thin; scrollbar-color:var(--border-2) transparent;
}
.ds-content::-webkit-scrollbar{width:10px}
.ds-content::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:8px;border:3px solid transparent;background-clip:content-box}
.ds-page{max-width:1180px;margin:0 auto;width:100%}

/* TABLET ≥640: icon rail + no bottom nav */
@container app (min-width:640px){
  .ds-app{grid-template-columns:var(--rail,76px) 1fr; grid-template-rows:1fr}
  .ds-side{display:flex}
  .ds-content{padding-bottom:var(--gutter)}
  .ds-bottomnav{display:none !important}
}
/* DESKTOP ≥1024: full sidebar with labels */
@container app (min-width:1024px){
  .ds-app{grid-template-columns:var(--side-w,256px) 1fr}
}

/* ============================================================================
   Sidebar
   ============================================================================ */
.ds-side{
  grid-row:1 / -1;
  flex-direction:column;
  background:var(--side-bg);
  border-right:1px solid var(--side-border);
  min-height:0;
  z-index:30;
}
.ds-side-top{display:flex;align-items:center;gap:10px;height:64px;padding:0 16px;flex-shrink:0}
.ds-side-nav{flex:1;min-height:0;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:3px;scrollbar-width:none}
.ds-side-nav::-webkit-scrollbar{display:none}
.ds-side-foot{padding:10px;border-top:1px solid var(--side-border);flex-shrink:0}
.side-manager{padding:10px;border:1px solid var(--side-border);border-radius:var(--r);margin-bottom:8px}
.side-manager .sm-head{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.side-manager .sm-name{font-weight:600;font-size:12.5px;color:var(--side-text);line-height:1.2}
.side-manager .sm-role{font-size:11px;color:var(--side-text-2)}
.side-manager .sm-call{width:100%;justify-content:center;height:34px;font-size:12.5px;gap:7px}
.nav-item{
  display:flex;align-items:center;gap:12px;
  height:44px;padding:0 12px;border-radius:var(--r-sm);
  color:var(--side-text-2);font-weight:500;cursor:pointer;
  border:none;background:none;width:100%;text-align:left;font-size:inherit;
  font-family:inherit;position:relative;transition:background .12s,color .12s;
}
.nav-item:hover{background:color-mix(in srgb,var(--side-text) 7%,transparent);color:var(--side-text)}
.nav-item[data-active="true"]{background:var(--side-active-bg);color:var(--side-active-text);font-weight:600}
.nav-item .ico{flex-shrink:0;width:22px;height:22px}
.nav-item .nav-label{white-space:nowrap;overflow:hidden}
.nav-item .nav-badge{margin-left:auto;font-size:11px;font-weight:700;background:var(--accent);color:var(--accent-ink);
  min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 6px}
.nav-section{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--side-text-2);
  opacity:.65;padding:14px 12px 6px}

/* rail mode (tablet): hide labels, center icons */
@container app (max-width:1023px){
  .ds-side .nav-label,.ds-side .nav-badge-text,.ds-side .nav-section,.ds-side .side-wordmark{display:none}
  .ds-side-top{justify-content:center;padding:0}
  .ds-side .nav-item{justify-content:center;padding:0;width:44px;margin:0 auto}
  .ds-side .nav-item .nav-badge{position:absolute;top:5px;right:5px;margin:0;min-width:8px;height:8px;padding:0;font-size:0}
  .ds-side-foot .nav-item{margin:0 auto}
  .ds-side .side-manager{border:none;padding:0;margin-bottom:8px;display:flex;flex-direction:column;align-items:center;gap:6px}
  .ds-side .side-manager .sm-head{margin:0}
  .ds-side .side-manager .sm-call{width:44px;padding:0;margin:0 auto}
}

/* ============================================================================
   Topbar
   ============================================================================ */
.ds-topbar{
  display:flex;align-items:center;gap:14px;
  height:64px;padding:0 var(--gutter);flex-shrink:0;
  background:color-mix(in srgb,var(--surface) 88%, transparent);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);z-index:20;
}
.ds-topbar .tb-mark{display:flex;align-items:center;gap:9px}
.ds-search{
  flex:1;max-width:520px;display:flex;align-items:center;gap:10px;height:var(--ctl-h);
  padding:0 14px;background:var(--surface-3);border:1px solid transparent;border-radius:var(--r-pill);
  color:var(--text-3);cursor:text;transition:border-color .12s,background .12s;
}
.ds-search:focus-within{background:var(--surface);border-color:var(--accent-line);box-shadow:var(--ring)}
.ds-search input{flex:1;border:none;background:none;outline:none;font:inherit;color:var(--text);min-width:0}
.ds-search input::placeholder{color:var(--text-3)}
.tb-spacer{flex:1}
.tb-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.tb-balance{
  display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;padding-right:6px;
  border-right:1px solid var(--border);margin-right:4px;
}
.tb-balance .lbl{font-size:11px;color:var(--text-3)}
.tb-balance .val{font-size:15px;font-weight:700}
.tb-hide-sm{display:flex}
@container app (max-width:639px){
  .ds-topbar .tb-hide-sm{display:none}
  .ds-search{display:none}
}

/* mobile bottom nav */
.ds-bottomnav{
  position:absolute;left:0;right:0;bottom:0;z-index:40;
  display:flex;background:color-mix(in srgb,var(--surface) 94%,transparent);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border-top:1px solid var(--border);padding:6px 4px calc(6px + env(safe-area-inset-bottom));
}
.ds-bottomnav button{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  border:none;background:none;color:var(--text-3);font:inherit;font-size:11px;font-weight:500;
  padding:6px 2px;cursor:pointer;border-radius:var(--r-sm);position:relative;
}
.ds-bottomnav button[data-active="true"]{color:var(--accent)}
.ds-bottomnav .ico{width:24px;height:24px}
.ds-bottomnav .bn-badge{position:absolute;top:2px;right:50%;transform:translateX(16px);
  background:var(--accent);color:var(--accent-ink);font-size:10px;font-weight:700;
  min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* drawer (mobile sidebar) */
.ds-scrim{position:absolute;inset:0;background:rgba(10,8,20,.45);z-index:49;opacity:0;pointer-events:none;transition:opacity .2s}
.ds-scrim[data-open="true"]{opacity:1;pointer-events:auto}
.ds-drawer{
  position:absolute;top:0;bottom:0;left:0;width:280px;max-width:84%;z-index:50;
  background:var(--side-bg);border-right:1px solid var(--side-border);
  transform:translateX(-100%);transition:transform .24s cubic-bezier(.3,.7,.4,1);
  display:flex;flex-direction:column;
}
.ds-drawer[data-open="true"]{transform:none}
.ds-drawer .nav-label,.ds-drawer .nav-section{display:revert}

/* ============================================================================
   UI primitives
   ============================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:var(--ctl-h);padding:0 16px;border-radius:var(--r-sm);
  font:inherit;font-weight:600;cursor:pointer;border:1px solid transparent;
  white-space:nowrap;transition:background .13s,border-color .13s,transform .06s,box-shadow .13s;
  user-select:none;
}
.btn:active{transform:translateY(1px)}
.btn .ico{width:18px;height:18px}
.btn-primary{background:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{background:var(--accent-strong)}
.btn-soft{background:var(--accent-soft);color:var(--on-accent-soft)}
.btn-soft:hover{background:color-mix(in srgb,var(--accent) 18%,var(--surface))}
.btn-outline{background:var(--surface);border-color:var(--border-2);color:var(--text)}
.btn-outline:hover{border-color:var(--text-3);background:var(--surface-2)}
.btn-ghost{background:transparent;color:var(--text-2)}
.btn-ghost:hover{background:var(--surface-3);color:var(--text)}
.btn-block{width:100%}
.btn-lg{height:calc(var(--ctl-h) + 8px);padding:0 22px;font-size:1.02em}
.btn-sm{height:32px;padding:0 12px;font-size:.9em;border-radius:var(--r-xs)}
.btn:disabled{opacity:.5;cursor:not-allowed}

.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:var(--ctl-h);height:var(--ctl-h);border-radius:var(--r-sm);
  border:none;background:transparent;color:var(--text-2);cursor:pointer;position:relative;
  transition:background .12s,color .12s;flex-shrink:0;
}
.icon-btn:hover{background:var(--surface-3);color:var(--text)}
.icon-btn .ico{width:22px;height:22px}
.icon-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;
  background:var(--accent);border:2px solid var(--surface)}
.icon-btn .count{position:absolute;top:4px;right:4px;background:var(--accent);color:var(--accent-ink);
  font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--surface)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1)}
.card-pad{padding:var(--card-pad)}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg)}

.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;border-radius:var(--r-pill);
  font-size:12px;font-weight:600;background:var(--surface-3);color:var(--text-2)}
.badge .ico{width:13px;height:13px}
.badge-accent{background:var(--accent-soft);color:var(--on-accent-soft)}
.badge-ok{background:var(--ok-soft);color:var(--ok)}
.badge-warn{background:var(--warn-soft);color:var(--warn)}
.badge-danger{background:var(--danger-soft);color:var(--danger)}

.pill{display:inline-flex;align-items:center;gap:6px;height:26px;padding:0 11px;border-radius:var(--r-pill);
  font-size:12.5px;font-weight:600}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}
.pill-new{background:var(--accent-soft);color:var(--on-accent-soft)}
.pill-assembling{background:var(--warn-soft);color:var(--warn)}
.pill-shipped{background:color-mix(in srgb,#3b82f6 16%,var(--surface));color:#2f72d6}
.portal[data-theme="dark"] .pill-shipped{color:#7fb0ff}
.pill-done{background:var(--ok-soft);color:var(--ok)}
.pill-canceled{background:var(--danger-soft);color:var(--danger)}

.chip{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 14px;border-radius:var(--r-pill);
  border:1px solid var(--border-2);background:var(--surface);color:var(--text-2);font-weight:500;
  font-size:.92em;cursor:pointer;white-space:nowrap;transition:all .12s}
.chip:hover{border-color:var(--text-3);color:var(--text)}
.chip[data-active="true"]{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.chip .ico{width:15px;height:15px}

/* field / input */
.field{display:flex;flex-direction:column;gap:6px}
.field-lbl{font-size:13px;font-weight:600;color:var(--text-2)}
.input{
  width:100%;height:var(--ctl-h);padding:0 13px;border-radius:var(--r-sm);
  border:1px solid var(--border-2);background:var(--surface);color:var(--text);font:inherit;outline:none;
  transition:border-color .12s,box-shadow .12s;
}
.input:focus{border-color:var(--accent-line);box-shadow:var(--ring)}
.input::placeholder{color:var(--text-3)}
textarea.input{height:auto;padding:11px 13px;resize:vertical;min-height:84px;line-height:1.5}
select.input{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23908ea1' d='M1 1.5 6 6.5 11 1.5'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}

/* qty stepper */
.qty{display:inline-flex;align-items:center;border:1px solid var(--border-2);border-radius:var(--r-sm);
  background:var(--surface);height:var(--ctl-h);overflow:hidden}
.qty button{width:36px;height:100%;border:none;background:none;color:var(--text-2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}
.qty button:hover{background:var(--surface-3);color:var(--accent)}
.qty button:disabled{opacity:.35;cursor:not-allowed}
.qty button .ico{width:16px;height:16px}
.qty input{width:46px;height:100%;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);
  text-align:center;font:inherit;font-weight:600;font-variant-numeric:tabular-nums;background:none;color:var(--text);outline:none;
  -moz-appearance:textfield}
.qty input::-webkit-inner-spin-button,.qty input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.qty-sm{height:34px}
.qty-sm button{width:30px}
.qty-sm input{width:38px}

/* avatar */
.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;background:var(--accent-soft);color:var(--on-accent-soft);flex-shrink:0;
  border:1px solid color-mix(in srgb,var(--accent) 20%,transparent)}

/* product thumb placeholder */
.thumb{position:relative;border-radius:var(--r);overflow:hidden;background:var(--surface-3);
  display:flex;align-items:center;justify-content:center;
  background-image:repeating-linear-gradient(135deg,transparent 0 11px,color-mix(in srgb,var(--text-3) 8%,transparent) 11px 12px);
}
.thumb .thumb-cap{font:11px/1.3 "Geist Mono",ui-monospace,monospace;color:var(--text-3);text-align:center;
  letter-spacing:.04em;padding:8px;text-transform:uppercase}
.thumb.thumb-art{background:none;background-image:none}
.thumb .thumb-img{position:absolute;inset:0;display:block}
.thumb .thumb-img svg{width:100%;height:100%;display:block}
.thumb .thumb-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.thumb-tag{position:absolute;top:8px;left:8px}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:.95em}
.tbl th{text-align:left;font-weight:600;color:var(--text-3);font-size:12px;text-transform:uppercase;letter-spacing:.03em;
  padding:0 14px 10px;border-bottom:1px solid var(--border)}
.tbl td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background .1s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}

/* kpi */
.kpi{display:flex;flex-direction:column;gap:10px}
.kpi .kpi-top{display:flex;align-items:center;justify-content:space-between}
.kpi .kpi-ico{width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--on-accent-soft)}
.kpi .kpi-ico .ico{width:20px;height:20px}
.kpi .kpi-val{font-size:26px;font-weight:750;letter-spacing:-.02em;line-height:1}
.kpi .kpi-lbl{font-size:13px;color:var(--text-2)}

/* misc */
.divider{height:1px;background:var(--border);border:none;margin:0}
.muted{color:var(--text-2)}
.faint{color:var(--text-3)}
.price{font-weight:750;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.strike{color:var(--text-3);text-decoration:line-through;font-weight:500}
.h-title{font-size:24px;font-weight:750;letter-spacing:-.02em;margin:0}
.h-sub{color:var(--text-2);margin:4px 0 0}
.stack{display:flex;flex-direction:column}
.row{display:flex;align-items:center}
.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}
.wrap{flex-wrap:wrap}
.grow{flex:1;min-width:0}

.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:48px 24px;color:var(--text-3);gap:16px}
.empty>.ico{box-sizing:border-box;width:56px;height:56px;padding:15px;border-radius:50%;
  background:var(--accent-soft);color:var(--accent);opacity:1}

/* stock dot */
.stock{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600}
.stock::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.stock-in{color:var(--ok)}
.stock-low{color:var(--warn)}
.stock-out{color:var(--text-3)}

/* toast */
.toast-wrap{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:20px;padding-bottom:96px;pointer-events:none;z-index:60}
@container app (min-width:640px){.toast-wrap{padding-bottom:24px}}
.toast{display:flex;align-items:center;gap:12px;background:var(--text);color:var(--surface);
  padding:13px 18px;border-radius:var(--r);box-shadow:var(--sh-pop);font-weight:600;font-size:14px;
  animation:toastIn .28s cubic-bezier(.2,.8,.3,1);pointer-events:auto;max-width:92%}
.toast .ico{width:20px;height:20px;color:#5ee08f}
@keyframes toastIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}

/* fade-in for content swap */
.view-fade{animation:viewFade .26s ease both}
@keyframes viewFade{from{opacity:.4;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.view-fade,.toast{animation:none}}

/* ---- topbar mobile toggles (menu + mark only < 640) --------------------- */
.ds-topbar{--tb-menu-display:inline-flex;--tb-mark-display:inline-flex}
@container app (min-width:640px){.ds-topbar{--tb-menu-display:none;--tb-mark-display:none}}

/* ---- page header --------------------------------------------------------- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.crumb{display:flex;align-items:center;gap:6px;color:var(--text-3);font-size:13px;font-weight:500;margin-bottom:10px;cursor:default}
.crumb button{border:none;background:none;color:var(--text-3);font:inherit;font-weight:500;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:6px}
.crumb button:hover{color:var(--accent)}
.crumb .ico{width:15px;height:15px}

/* ---- product grid + card ------------------------------------------------- */
.prod-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(212px,1fr))}
@container app (max-width:540px){.prod-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}}
.prod-card{display:flex;flex-direction:column;overflow:hidden;cursor:pointer;
  transition:border-color .14s,box-shadow .14s,transform .14s}
.prod-card:hover{border-color:var(--border-2);box-shadow:var(--sh-2);transform:translateY(-2px)}
.prod-card .thumb{aspect-ratio:4/3;border-radius:0;border:none;border-bottom:1px solid var(--border)}
.pc-body{padding:13px 14px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.pc-brand{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.pc-name{font-weight:600;font-size:14px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-sku{font-size:11.5px;color:var(--text-3);font-family:"Geist Mono",ui-monospace,monospace}
.pc-foot{display:flex;flex-direction:column;align-items:stretch;gap:10px;margin-top:auto;padding-top:10px}
.pc-price{display:flex;align-items:baseline;gap:6px;line-height:1.05}
.pc-price .price{font-size:18px}
.pc-unit{font-size:11.5px;color:var(--text-3)}
.pc-add{flex-shrink:0}
.pc-add .btn{width:100%;justify-content:center}
.pc-add>div{width:100%}
.pc-add .qty{display:flex;width:100%}
.pc-add .qty input{flex:1;width:auto;min-width:0}
.fav-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;border:none;
  background:color-mix(in srgb,var(--surface) 80%,transparent);color:var(--text-3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:color .12s,background .12s}
.fav-btn:hover{color:var(--danger)}
.fav-btn[data-on="true"]{color:var(--danger)}
.fav-btn[data-on="true"] .ico{fill:currentColor}

/* horizontal product row (lists) */
.prod-row{display:flex;align-items:center;gap:13px;padding:11px 0;border-bottom:1px solid var(--border)}
.prod-row:last-child{border-bottom:none}
.prod-row .thumb{width:54px;height:54px;flex-shrink:0;border-radius:var(--r-sm)}
.prod-row .pr-main{flex:1;min-width:0}
.prod-row .pr-name{font-weight:600;font-size:13.5px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prod-row .pr-sub{font-size:12px;color:var(--text-3);font-family:"Geist Mono",ui-monospace,monospace}

/* ---- catalog ------------------------------------------------------------- */
.cat-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;margin-bottom:16px}
.chip-rail{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;flex:1;min-width:0}
.chip-rail::-webkit-scrollbar{display:none}
.chip-rail[data-fade-r="true"]{-webkit-mask:linear-gradient(to right,#000 calc(100% - 26px),transparent);mask:linear-gradient(to right,#000 calc(100% - 26px),transparent)}
.chip-rail[data-fade-l="true"]{-webkit-mask:linear-gradient(to right,transparent,#000 26px);mask:linear-gradient(to right,transparent,#000 26px)}
.chip-rail[data-fade-l="true"][data-fade-r="true"]{-webkit-mask:linear-gradient(to right,transparent,#000 26px,#000 calc(100% - 26px),transparent);mask:linear-gradient(to right,transparent,#000 26px,#000 calc(100% - 26px),transparent)}
.rail-arrow{flex:0 0 auto;width:34px;height:34px;display:none;align-items:center;justify-content:center;
  border:1px solid var(--border-2);background:var(--surface);color:var(--text-2);border-radius:50%;cursor:pointer;transition:all .12s}
.rail-arrow:hover{border-color:var(--text-3);color:var(--text);background:var(--surface-2)}
.rail-arrow[data-show="true"]{display:inline-flex}

/* ---- delivery info ------------------------------------------------------- */
.dlv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.dlv-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 22px;margin-top:6px}
.dlv-step{display:flex;gap:12px;align-items:flex-start}
.dlv-step-n{flex:0 0 auto;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--accent);color:var(--accent-ink);font-size:13px;font-weight:700}
@media (max-width:720px){.dlv-grid,.dlv-steps{grid-template-columns:1fr}}

/* ---- order detail page --------------------------------------------------- */
.od-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start}
.od-side{position:sticky;top:0}
.crumb-current{color:var(--text-3);font-weight:600}
@container app (max-width:1023px){.od-grid{grid-template-columns:minmax(0,1fr)}.od-side{position:static}}

/* ---- product page -------------------------------------------------------- */
.prod-page{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,380px);gap:30px;align-items:start}
@container app (max-width:880px){.prod-page{grid-template-columns:1fr;gap:22px}}
.gallery-main{aspect-ratio:4/3;width:100%}
.gallery-thumbs{display:flex;gap:10px;margin-top:10px}
.gallery-thumbs .thumb{width:74px;height:60px;cursor:pointer;border:1px solid var(--border)}
.gallery-thumbs .thumb[data-on="true"]{border-color:var(--accent);box-shadow:var(--ring)}
.buybox{position:sticky;top:0;display:flex;flex-direction:column;gap:16px;padding:var(--card-pad)}
.spec-tbl{width:100%;border-collapse:collapse}
.spec-tbl td{padding:11px 0;border-bottom:1px solid var(--border);font-size:14px;vertical-align:top}
.spec-tbl td:first-child{color:var(--text-2);width:48%}
.spec-tbl td:last-child{font-weight:600;text-align:right}
.spec-tbl tr:last-child td{border-bottom:none}
.seg{display:flex;gap:4px;padding:4px;background:var(--surface-3);border-radius:var(--r);margin-bottom:18px}
.seg button{flex:1;height:34px;border:none;background:none;border-radius:var(--r-sm);font:inherit;font-weight:600;
  font-size:13.5px;color:var(--text-2);cursor:pointer;transition:background .12s,color .12s}
.seg button[data-on="true"]{background:var(--surface);color:var(--text);box-shadow:var(--sh-1)}

/* ---- cart ---------------------------------------------------------------- */
.cart-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;align-items:start}
@container app (max-width:860px){.cart-grid{grid-template-columns:1fr}}
.cart-line{display:grid;grid-template-columns:64px minmax(0,1fr) auto;gap:14px;align-items:center;
  padding:16px 0;border-bottom:1px solid var(--border)}
.cart-line .thumb{width:64px;height:64px;border-radius:var(--r-sm)}
.cart-line .cl-name{font-weight:600;font-size:14px;line-height:1.3}
.cart-line .cl-controls{display:flex;align-items:center;gap:14px}
@container app (max-width:560px){
  .cart-line{grid-template-columns:56px minmax(0,1fr);grid-template-areas:"img main" "ctl ctl";row-gap:12px}
  .cart-line .thumb{width:56px;height:56px}
  .cart-line .cl-img{grid-area:img}.cart-line .cl-main{grid-area:main}.cart-line .cl-controls{grid-area:ctl;justify-content:space-between}
}
.summary{position:sticky;top:0;display:flex;flex-direction:column;gap:12px;padding:var(--card-pad)}
.sum-row{display:flex;align-items:center;justify-content:space-between;font-size:14px}
.sum-row.total{font-size:19px;font-weight:750;padding-top:12px;border-top:1px solid var(--border);margin-top:4px}

/* ---- dashboard ----------------------------------------------------------- */
.kpi-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(196px,1fr))}
.dash-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px;margin-top:20px;align-items:stretch}
@container app (max-width:920px){.dash-grid{grid-template-columns:minmax(0,1fr)}}
.qa-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(158px,1fr));margin-top:16px}
.qa-card{display:flex;flex-direction:column;gap:12px;padding:16px;cursor:pointer;text-align:left;
  border:1px solid var(--border);background:var(--surface);border-radius:var(--r-lg);transition:border-color .13s,box-shadow .13s,transform .13s}
.qa-card:hover{border-color:var(--accent-line);box-shadow:var(--sh-2);transform:translateY(-2px)}
.qa-ico{width:42px;height:42px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;
  background:var(--accent-soft);color:var(--on-accent-soft)}
.qa-ico .ico{width:22px;height:22px}
.manager-card{display:flex;flex-direction:column;gap:14px;padding:var(--card-pad)}
.tb-profile{display:flex;align-items:center;gap:9px;border:none;background:none;cursor:pointer;padding:4px 6px 4px 4px;border-radius:var(--r-sm);max-width:230px}
.tb-profile:hover{background:var(--surface-3)}
.tb-profile .avatar{flex-shrink:0}
.tb-profile-txt{display:flex;flex-direction:column;gap:1px;line-height:1.15;text-align:left;min-width:0}
.tb-profile-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-profile-role{font-size:11.5px;color:var(--text-3)}

/* progress */
.bar{height:8px;border-radius:999px;background:var(--surface-3);overflow:hidden}
.bar > i{display:block;height:100%;border-radius:999px;background:var(--accent)}

/* quick order */
.qo-row{display:grid;grid-template-columns:minmax(0,1fr) 120px 150px 40px;gap:10px;align-items:center}
@container app (max-width:600px){.qo-row{grid-template-columns:minmax(0,1fr) 90px;grid-template-areas:"sku qty" "res res";gap:8px}
  .qo-row .qo-sku{grid-area:sku}.qo-row .qo-qty{grid-area:qty}.qo-row .qo-res{grid-area:res}.qo-row .qo-del{display:none}}
.qo-res{font-size:13px}

/* ---- brand logo --------------------------------------------------------- */
.ds-logo-img{display:block;width:auto}
.ds-logo-lockup{display:inline-flex;align-items:center;gap:9px}
.ds-wm{font-weight:800;font-size:18px;letter-spacing:-.02em;color:#fff;display:inline-flex;
  align-items:center;gap:8px;white-space:nowrap;line-height:1}
.ds-pill{font-style:normal;font-weight:700;font-size:10.5px;letter-spacing:0;
  background:rgba(255,255,255,.18);color:#fff;padding:3px 7px;border-radius:5px}
.logo-full-wrap,.logo-mark-wrap{display:inline-flex;align-items:center;min-width:0}
.ds-side .logo-full-wrap{display:none}
.ds-side .logo-mark-wrap{display:inline-flex}
@container app (min-width:1024px){
  .ds-side .logo-full-wrap{display:inline-flex}
  .ds-side .logo-mark-wrap{display:none}
}

/* ---- preview stage + device frames -------------------------------------- */
.portal{position:fixed;inset:0}
.portal-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:#e5e5ee;overflow:hidden;transition:background .2s}
.portal[data-theme="dark"] .portal-stage{background:#08070d}
.device{background:var(--bg);overflow:hidden;position:relative;
  transition:width .3s cubic-bezier(.3,.7,.4,1),height .3s cubic-bezier(.3,.7,.4,1),border-radius .3s;
  max-width:calc(100% - 24px)}
.device-desktop{width:100%;height:100%;border-radius:0}
.device-tablet{width:860px;height:min(1120px,calc(100% - 96px));border-radius:22px;
  box-shadow:0 30px 80px rgba(20,12,50,.30),0 0 0 1px rgba(0,0,0,.05)}
.device-phone{width:390px;height:min(840px,calc(100% - 96px));border-radius:34px;
  box-shadow:0 30px 80px rgba(20,12,50,.30),0 0 0 1px rgba(0,0,0,.05)}
.portal[data-theme="dark"] .device-tablet,.portal[data-theme="dark"] .device-phone{box-shadow:0 30px 90px rgba(0,0,0,.6)}

/* app boot loader */
.ds-boot{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#e5e5ee}
.ds-boot i{width:30px;height:30px;border-radius:50%;border:3px solid rgba(108,77,224,.25);
  border-top-color:#6c4de0;animation:dsspin .8s linear infinite}
@keyframes dsspin{to{transform:rotate(360deg)}}



/* Product deployment: hide prototype-only controls. */
[data-omelette-chrome]{display:none!important}
.twk-panel{display:none!important}
