/* ============================================================================
   storefront-theme.css — shared, MOBILE-FIRST design system
   ----------------------------------------------------------------------------
   Used by the WEDLIF (purple B2C) and HEMPEXPORT (teal/yellow B2B) storefronts.
   Inspired by simplygreentrade.com: clean teal header, bright CTA buttons,
   white cards on light grey, rounded corners, soft shadows.

   EVERYTHING colour-related uses CSS custom properties so the look themes per
   store. The per-store base.html only has to set :root { --accent / --cta / … }.

   Mobile-first: base rules target phones (80–90% of traffic). Desktop is layered
   on with @media(min-width:…). Touch targets are >= 44px.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   Theme tokens — overridden per store in base.html :root{}
   -------------------------------------------------------------------------- */
:root{
  /* brand colours (defaults; per-store base overrides --accent / --cta) */
  --accent:#0f7d7a;          /* primary brand colour (header, links, accents) */
  --accent-dark:#0a615f;     /* hover / darker shade */
  --accent-soft:#e6f2f1;     /* tint used for hover backgrounds, chips */
  --on-accent:#ffffff;       /* text/icon colour on the accent background */
  --cta:#ffe000;             /* call-to-action button (bright) */
  --cta-dark:#f5d000;        /* CTA hover */
  --on-cta:#1a1a1a;          /* text on CTA */

  /* neutrals */
  --ink:#1f2937;             /* primary text */
  --ink-soft:#4b5563;        /* secondary text */
  --muted:#8a949e;           /* tertiary / hints */
  --bg:#f4f6f6;              /* page background (light grey) */
  --card:#ffffff;            /* card / surface background */
  --line:#e6eaea;            /* hairline borders */
  --line-soft:#f0f3f3;

  /* status */
  --ok:#15a34a;
  --warn:#d97706;
  --danger:#dc2626;
  --sale:#dc2626;

  /* shape + depth */
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:20px;
  --shadow:0 4px 18px rgba(15,40,40,.07);
  --shadow-lg:0 10px 34px rgba(15,40,40,.12);
  --maxw:1320px;

  /* type */
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* ----------------------------------------------------------------------------
   Reset / base
   -------------------------------------------------------------------------- */
*{box-sizing:border-box}
[hidden]{display:none!important}  /* hidden attr must beat .sf-grid{display:grid} for the cards/table toggle */
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
  line-height:1.5;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
h1,h2,h3,h4{margin:0;line-height:1.2;letter-spacing:-.02em}

.sf-wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px;width:100%}
.sf-main{flex:1 0 auto}
.sf-visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ----------------------------------------------------------------------------
   Buttons
   -------------------------------------------------------------------------- */
.sf-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;
  padding:13px 20px;font-size:15px;line-height:1;text-align:center;
  transition:filter .12s,background .12s,box-shadow .12s,transform .04s;
  min-height:46px;white-space:nowrap;
}
.sf-btn:active{transform:translateY(1px)}
.sf-btn-cta{background:var(--cta);color:var(--on-cta)}
.sf-btn-cta:hover{filter:brightness(.96)}
.sf-btn-accent{background:var(--accent);color:var(--on-accent)}
.sf-btn-accent:hover{background:var(--accent-dark)}
.sf-btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.sf-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.sf-btn-block{width:100%}
.sf-btn-sm{padding:9px 14px;min-height:38px;font-size:13.5px;border-radius:8px}
.sf-btn[disabled]{opacity:.55;cursor:not-allowed}

/* ----------------------------------------------------------------------------
   Header (sticky, compact on mobile)
   -------------------------------------------------------------------------- */
.sf-utility{background:var(--accent-dark);color:#fff;font-size:12.5px}
.sf-utility .sf-wrap{display:flex;justify-content:flex-end;gap:22px;height:34px;align-items:center}
.sf-utility a{opacity:.92}
.sf-utility a:hover{opacity:1}
@media(max-width:899px){.sf-utility{display:none}}

.sf-header{background:var(--accent);color:var(--on-accent);position:sticky;top:0;z-index:50}

/* desktop bar */
.sf-header .sf-bar{display:none}
@media(min-width:900px){
  .sf-header .sf-bar{display:flex;align-items:center;gap:14px;height:70px}
}

.sf-logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:21px;letter-spacing:-.02em;color:var(--on-accent);white-space:nowrap}
.sf-logo svg,.sf-logo img{flex-shrink:0}
.sf-logo img{height:34px;width:auto}
.sf-logo b{color:var(--cta)}

/* search */
.sf-search{flex:1;position:relative;max-width:760px}
.sf-search input{width:100%;height:46px;border:none;border-radius:30px;padding:0 56px 0 20px;font-size:15px;color:var(--ink);outline:none;background:#fff}
.sf-search input::placeholder{color:var(--muted)}
.sf-search button{position:absolute;right:4px;top:4px;height:38px;width:46px;border:none;border-radius:24px;background:var(--cta);cursor:pointer;display:flex;align-items:center;justify-content:center}
.sf-search button svg{stroke:var(--on-cta)}

.sf-icons{display:flex;align-items:center;gap:6px}
.sf-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--on-accent);position:relative}
.sf-icon:hover{background:rgba(255,255,255,.14)}
/* Product-detail action buttons (favourite / price-watch) — sit on a white
   panel, so they need visible accent colour, not the white header .sf-icon. */
.sf-pd-iconbtn{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1.5px solid var(--accent);color:var(--accent);background:#fff;cursor:pointer;
  transition:background .15s,color .15s,border-color .15s}
.sf-pd-iconbtn:hover{background:var(--accent);color:#fff}
.sf-pd-iconbtn.is-on{background:var(--accent);color:#fff}
.sf-pd-iconbtn.is-fav{border-color:var(--danger);color:var(--danger)}
.sf-pd-iconbtn.is-fav:hover,.sf-pd-iconbtn.is-fav.is-on{background:var(--danger);color:#fff;border-color:var(--danger)}
.sf-cart{background:var(--accent-dark);border-radius:30px;padding:0 16px;min-height:44px;display:flex;align-items:center;gap:8px;color:var(--on-accent);font-weight:700;font-size:14px}
.sf-cart:hover{filter:brightness(1.08)}
.sf-badge{position:absolute;top:2px;right:2px;background:var(--cta);color:var(--on-cta);font-size:10px;font-weight:800;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* mobile header */
.sf-mhead{display:block}
@media(min-width:900px){.sf-mhead{display:none}}
.sf-mhead .sf-row1{display:flex;align-items:center;gap:10px;height:58px}
.sf-mhead .sf-row2{padding-bottom:12px}
.sf-burger{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,.16);border:none;color:var(--on-accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sf-mhead .sf-icon{flex-shrink:0}

/* ----------------------------------------------------------------------------
   Primary nav (desktop category bar)
   -------------------------------------------------------------------------- */
.sf-nav{background:#fff;border-bottom:1px solid var(--line);display:none}
@media(min-width:900px){.sf-nav{display:block}}
.sf-nav .sf-wrap{display:flex;align-items:center;gap:6px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}
.sf-nav .sf-wrap::-webkit-scrollbar{display:none}
/* Two-row nav: row 1 = categories, row 2 = secondary action links */
.sf-nav .sf-nav-row1{height:52px}
.sf-nav .sf-nav-row2{height:40px;gap:2px;border-top:1px solid var(--line)}
.sf-nav-row2 .sf-navlink{font-size:13px;color:var(--muted,#5b5b5b);padding:7px 10px}
.sf-nav-row2 .sf-navlink:hover{color:var(--accent);background:var(--accent-soft)}
.sf-browse{display:flex;align-items:center;gap:9px;background:var(--accent);color:var(--on-accent);font-weight:700;border-radius:8px;padding:9px 16px;white-space:nowrap;font-size:14px;cursor:pointer;flex-shrink:0}
.sf-browse:hover{background:var(--accent-dark)}
.sf-navlink{font-weight:600;font-size:14px;color:var(--ink);padding:9px 12px;white-space:nowrap;border-radius:8px}
.sf-navlink:hover{color:var(--accent);background:var(--accent-soft)}
.sf-navlink .sf-hot{background:var(--danger);color:#fff;font-size:9px;font-weight:800;border-radius:5px;padding:2px 5px;margin-left:5px;vertical-align:middle;text-transform:uppercase}
.sf-nav-spacer{flex:1}

/* Mega-panel dimming scrim — focuses attention on the open panel + primary navbar.
   Toggled by adding `mega-open` to <body>. Only the PRIMARY navbar (utility strip
   + header bar) lifts above the scrim; secondary link rows stay dimmed. Each store
   lifts its own panel-carrying container as needed (see per-store <style>). */
.sf-mega-scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:100}
body.mega-open .sf-mega-scrim{opacity:1;pointer-events:auto}
body.mega-open .sf-header{z-index:110}
body.mega-open .sf-utility{position:relative;z-index:110}

/* ----------------------------------------------------------------------------
   Off-canvas mobile drawer
   -------------------------------------------------------------------------- */
.sf-drawer{position:fixed;inset:0;z-index:100;visibility:hidden;opacity:0;transition:opacity .2s,visibility .2s}
.sf-drawer.open{visibility:visible;opacity:1}
.sf-drawer .sf-scrim{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.sf-drawer .sf-panel{position:absolute;top:0;left:0;bottom:0;width:86%;max-width:340px;background:#fff;transform:translateX(-100%);transition:transform .22s;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}
.sf-drawer.open .sf-panel{transform:none}
.sf-drawer .sf-dhead{background:var(--accent);color:var(--on-accent);padding:18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:2}
.sf-drawer .sf-dhead b{font-weight:800;font-size:17px}
.sf-drawer .sf-dclose{background:none;border:none;color:var(--on-accent);display:flex;padding:4px}
.sf-dsection{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:18px 18px 6px}
.sf-dlink{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line-soft);font-weight:600;color:var(--ink);min-height:48px}
.sf-dlink:hover{background:var(--accent-soft)}
.sf-dlink svg{color:var(--muted);flex-shrink:0}
/* collapsible category w/ subs in drawer */
.sf-dcat{border-bottom:1px solid var(--line-soft)}
.sf-dcat>summary{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;font-weight:600;cursor:pointer;list-style:none;min-height:48px}
.sf-dcat>summary::-webkit-details-marker{display:none}
.sf-dcat>summary .sf-chev{transition:transform .2s;color:var(--muted)}
.sf-dcat[open]>summary .sf-chev{transform:rotate(180deg)}
.sf-dsubs{background:var(--bg);padding:4px 0 8px}
.sf-dsubs a{display:block;padding:9px 18px 9px 30px;font-size:14px;color:var(--ink-soft)}
.sf-dsubs a:hover{color:var(--accent)}
.sf-dsubs a.sf-dsub-all{color:var(--accent);font-weight:700}

/* ----------------------------------------------------------------------------
   Sections / headings
   -------------------------------------------------------------------------- */
.sf-section{padding:28px 0}
@media(min-width:760px){.sf-section{padding:40px 0}}
.sf-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.sf-section-title{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0}
@media(min-width:760px){.sf-section-title{font-size:28px}}
.sf-section-sub{color:var(--ink-soft);font-size:14px;margin:4px 0 0}
.sf-link-more{color:var(--accent);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.sf-link-more:hover{color:var(--accent-dark)}

/* ----------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.sf-hero{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--on-accent);border-radius:var(--radius-lg);padding:32px 22px;margin:18px 0;text-align:center;box-shadow:var(--shadow)}
@media(min-width:760px){.sf-hero{padding:54px 48px;text-align:left}}
.sf-hero h1{font-size:28px;font-weight:800;line-height:1.12;margin:0 0 12px}
@media(min-width:760px){.sf-hero h1{font-size:44px;max-width:18ch}}
.sf-hero p{font-size:15px;opacity:.92;margin:0 0 22px;max-width:48ch}
@media(min-width:760px){.sf-hero p{font-size:18px}}
.sf-hero .sf-hero-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
@media(min-width:760px){.sf-hero .sf-hero-actions{justify-content:flex-start}}

/* trust / USP strip */
.sf-usps{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:18px 0}
@media(min-width:760px){.sf-usps{grid-template-columns:repeat(4,1fr)}}
.sf-usp{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;gap:12px;align-items:center;box-shadow:var(--shadow);color:var(--ink,#1f2a37);text-decoration:none;transition:border-color .15s,box-shadow .15s}
a.sf-usp:hover{border-color:var(--accent);box-shadow:0 6px 18px rgba(0,0,0,.08)}
.sf-usp .sf-usp-ic{width:38px;height:38px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sf-usp b{display:block;font-size:13.5px;font-weight:700}
.sf-usp span{font-size:12px;color:var(--ink-soft)}

/* ── Account pages (theme-agnostic; brand via --accent → teal/purple/green) ── */
.sf-acc{max-width:920px;margin:0 auto;padding:24px 16px 48px}
.sf-acc-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 24px;flex-wrap:wrap}
.sf-acc-head h1{font-size:24px;font-weight:800;margin:0}
.sf-acc-sub{font-size:14px;color:var(--ink-soft,#6b7280)}
.sf-acc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px}
@media(min-width:680px){.sf-acc-grid{grid-template-columns:repeat(4,1fr)}}
.sf-acc-card{display:block;width:100%;text-align:left;background:var(--card,#fff);border:1px solid var(--line,#e5e7eb);border-radius:var(--radius,12px);padding:18px;text-decoration:none;color:var(--ink,#1f2a37);cursor:pointer;transition:border-color .15s,box-shadow .15s}
.sf-acc-card:hover{border-color:var(--accent);box-shadow:0 6px 18px rgba(0,0,0,.07)}
.sf-acc-ic{color:var(--accent);display:block;margin-bottom:6px}
.sf-acc-num{font-size:28px;font-weight:800;color:var(--accent);line-height:1}
.sf-acc-lbl{font-size:13px;color:var(--ink-soft,#6b7280);margin-top:4px}
.sf-acc-sec{margin-top:8px}
.sf-acc-sec-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.sf-acc-sec-head h2{font-size:18px;font-weight:700;margin:0}
.sf-acc-panel{background:var(--card,#fff);border:1px solid var(--line,#e5e7eb);border-radius:var(--radius,12px);overflow:hidden}
.sf-acc-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;text-decoration:none;color:var(--ink,#1f2a37)}
.sf-acc-row+.sf-acc-row{border-top:1px solid var(--line,#f0f0f0)}
.sf-acc-row:hover{background:#f9fafb}
.sf-acc-empty{background:var(--card,#fff);border:1px solid var(--line,#e5e7eb);border-radius:var(--radius,12px);padding:32px;text-align:center;color:var(--ink-soft,#6b7280)}
.sf-acc-badge{font-size:12px;padding:3px 10px;border-radius:999px;background:var(--accent-soft,#eef);color:var(--accent);white-space:nowrap}
.sf-acc-link{color:var(--accent);text-decoration:none;font-size:14px}
.sf-acc-link:hover{text-decoration:underline}
.sf-acc-field{display:block;margin-bottom:14px}
.sf-acc-field>label,.sf-acc-label{display:block;font-size:13px;font-weight:600;color:var(--ink,#374151);margin-bottom:5px}
.sf-acc-input,.sf-acc-field input,.sf-acc-field select,.sf-acc-field textarea{width:100%;padding:10px 12px;border:1px solid var(--line,#d1d5db);border-radius:10px;font-size:14px;background:#fff;color:var(--ink,#1f2a37)}
.sf-acc-input:focus,.sf-acc-field input:focus,.sf-acc-field select:focus,.sf-acc-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft,rgba(0,0,0,.06))}

/* ----------------------------------------------------------------------------
   Category icon row (circular, horizontal-scroll on mobile)
   -------------------------------------------------------------------------- */
.sf-cat-icons{display:flex;gap:14px;overflow-x:auto;padding:4px 0 10px;-ms-overflow-style:none;scrollbar-width:none;scroll-snap-type:x proximity}
.sf-cat-icons::-webkit-scrollbar{display:none}
@media(min-width:900px){.sf-cat-icons{display:grid;grid-template-columns:repeat(8,1fr);overflow:visible}}
.sf-cat-icon{flex:0 0 auto;width:84px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;scroll-snap-align:start}
@media(min-width:900px){.sf-cat-icon{width:auto}}
.sf-cat-icon .sf-cat-circle{width:68px;height:68px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;overflow:hidden}
.sf-cat-icon .sf-cat-circle img{width:100%;height:100%;object-fit:cover}
.sf-cat-icon:hover .sf-cat-circle{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.sf-cat-icon span{font-size:12.5px;font-weight:600;line-height:1.2;color:var(--ink)}

/* ----------------------------------------------------------------------------
   Product grid + cards
   -------------------------------------------------------------------------- */
.sf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:560px){.sf-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.sf-grid{grid-template-columns:repeat(4,1fr);gap:20px}}
@media(min-width:1180px){.sf-grid{grid-template-columns:repeat(5,1fr)}}

/* horizontal scroll rail (homepage rows on mobile) */
.sf-rail{display:flex;gap:14px;overflow-x:auto;padding:2px 0 12px;-ms-overflow-style:none;scrollbar-width:none;scroll-snap-type:x proximity}
.sf-rail::-webkit-scrollbar{display:none}
.sf-rail>.sf-card{flex:0 0 64%;max-width:230px;scroll-snap-align:start}
@media(min-width:560px){.sf-rail>.sf-card{flex-basis:42%}}
@media(min-width:900px){
  .sf-rail{display:grid;grid-template-columns:repeat(5,1fr);overflow:visible;gap:20px}
  .sf-rail>.sf-card{flex:initial;max-width:none}
}

.sf-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;position:relative;transition:box-shadow .14s,transform .06s,border-color .14s}
.sf-card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent-soft)}
.sf-card-media{position:relative;display:block;aspect-ratio:1/1;background:#fff;overflow:hidden}
.sf-card-media img{width:100%;height:100%;object-fit:contain;padding:10px;transition:transform .2s}
.sf-card:hover .sf-card-media img{transform:scale(1.03)}
.sf-card-media .sf-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--line);background:var(--line-soft)}
.sf-card-body{padding:12px;display:flex;flex-direction:column;gap:6px;flex:1}
@media(min-width:760px){.sf-card-body{padding:14px}}
.sf-card-brand{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.sf-card-name{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.sf-card-name:hover{color:var(--accent)}
.sf-card-foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:8px;padding-top:6px}
.sf-card .sf-add{width:42px;height:42px;border-radius:10px;background:var(--cta);color:var(--on-cta);border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:filter .12s}
.sf-card .sf-add:hover{filter:brightness(.95)}
.sf-card .sf-add svg{stroke:var(--on-cta)}

/* price */
.sf-price{font-size:17px;font-weight:800;color:var(--ink);line-height:1.1}
.sf-price small{font-size:11px;font-weight:600;color:var(--muted)}
.sf-price-was{font-size:12.5px;color:var(--muted);text-decoration:line-through;font-weight:600;display:block}
.sf-price-from{font-size:11px;font-weight:600;color:var(--muted);display:block}
/* B2B catalog mode: "Login for price" instead of a number */
.sf-login-price{display:inline-flex;align-items:center;gap:6px;background:var(--cta);color:var(--on-cta);font-weight:700;font-size:12.5px;border-radius:8px;padding:9px 12px;line-height:1;white-space:nowrap;min-height:38px}
.sf-login-price:hover{filter:brightness(.95)}
/* B2B catalog-mode card footer holds only the "Login for price" CTA (no add
   button), so stretch it full-width + centred for a consistent baseline across
   every card regardless of label length. */
.sf-card-foot--login{justify-content:center}
.sf-card-foot--login .sf-login-price{width:100%;justify-content:center;text-align:center;white-space:normal}

/* badges */
.sf-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:5px;z-index:2}
.sf-tag{font-size:10px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;border-radius:6px;padding:4px 7px;line-height:1;color:#fff;backdrop-filter:saturate(1.2)}
.sf-tag-new{background:var(--accent)}
.sf-tag-sale{background:var(--sale)}
.sf-tag-best{background:var(--warn)}
.sf-tag-soldout{background:var(--muted)}
.sf-tag-gift{background:var(--ok)}
/* stock pill */
.sf-stock{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600}
.sf-stock-in{color:var(--ok)}
.sf-stock-low{color:var(--warn)}
.sf-stock-out{color:var(--muted)}
.sf-stock .sf-dot{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block}

/* ----------------------------------------------------------------------------
   Brand-logo tiles
   -------------------------------------------------------------------------- */
.sf-brand-tiles{display:flex;gap:12px;overflow-x:auto;padding:2px 0 12px;-ms-overflow-style:none;scrollbar-width:none}
.sf-brand-tiles::-webkit-scrollbar{display:none}
@media(min-width:900px){.sf-brand-tiles{display:grid;grid-template-columns:repeat(6,1fr);overflow:visible}}
.sf-brand-tile{flex:0 0 auto;width:130px;height:78px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;padding:14px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}
@media(min-width:900px){.sf-brand-tile{width:auto}}
.sf-brand-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.sf-brand-tile img{max-height:100%;max-width:100%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.8;transition:filter .15s,opacity .15s}
.sf-brand-tile:hover img{filter:none;opacity:1}
.sf-brand-tile span{font-weight:700;color:var(--ink-soft);font-size:14px}

/* ----------------------------------------------------------------------------
   Breadcrumbs
   -------------------------------------------------------------------------- */
.sf-crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);padding:14px 0}
.sf-crumbs a:hover{color:var(--accent)}
.sf-crumbs .sf-crumb-sep{color:var(--line)}
.sf-crumbs .sf-crumb-cur{color:var(--ink);font-weight:600}

/* ----------------------------------------------------------------------------
   Category page layout (toolbar, subcats, filters)
   -------------------------------------------------------------------------- */
.sf-cat-head{margin:6px 0 18px}
.sf-cat-head h1{font-size:24px;font-weight:800}
@media(min-width:760px){.sf-cat-head h1{font-size:32px}}
.sf-cat-desc{color:var(--ink-soft);font-size:14px;margin-top:8px;max-width:70ch}

.sf-subcats{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;-ms-overflow-style:none;scrollbar-width:none}
.sf-subcats::-webkit-scrollbar{display:none}
.sf-chip{flex:0 0 auto;background:var(--card);border:1px solid var(--line);border-radius:30px;padding:8px 15px;font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;min-height:38px;display:inline-flex;align-items:center}
.sf-chip:hover{border-color:var(--accent);color:var(--accent)}
.sf-chip.is-active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

.sf-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:6px 0 18px}
.sf-toolbar .sf-count{font-size:13.5px;color:var(--ink-soft)}
.sf-toolbar .sf-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
/* toolbar selects must stay content-width — the forms rule sets .sf-select{width:100%} */
.sf-toolbar .sf-select{width:auto;max-width:240px}
.sf-select{height:42px;border:1px solid var(--line);border-radius:10px;padding:0 36px 0 14px;font-size:14px;color:var(--ink);background:var(--card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a949e' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;appearance:none;cursor:pointer}
.sf-viewtoggle{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--card)}
.sf-viewtoggle button{border:none;background:none;padding:9px 12px;color:var(--muted);cursor:pointer;display:flex;align-items:center;min-height:42px}
.sf-viewtoggle button.is-active{background:var(--accent);color:var(--on-accent)}

/* empty state */
.sf-empty{background:var(--card);border:1px dashed var(--line);border-radius:var(--radius);padding:48px 24px;text-align:center;color:var(--ink-soft)}
.sf-empty svg{color:var(--line);margin:0 auto 12px}

/* pagination */
.sf-pager{display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap;padding:28px 0}
.sf-pager a,.sf-pager span{min-width:42px;height:42px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;font-weight:600;font-size:14px;border:1px solid var(--line);background:var(--card);color:var(--ink)}
.sf-pager a:hover{border-color:var(--accent);color:var(--accent)}
.sf-pager .is-active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}
.sf-pager .is-disabled{opacity:.45;pointer-events:none}

/* ----------------------------------------------------------------------------
   B2B wholesale table (HEMPEXPORT) — collapses to stacked rows on mobile
   -------------------------------------------------------------------------- */
.sf-table-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.sf-table{width:100%;border-collapse:collapse;font-size:14px}
.sf-table thead{display:none}
@media(min-width:840px){.sf-table thead{display:table-header-group}}
.sf-table thead th{background:var(--accent);color:var(--on-accent);text-align:left;font-weight:700;font-size:12.5px;letter-spacing:.02em;padding:13px 14px;white-space:nowrap}
.sf-table tbody tr{display:block;border-bottom:8px solid var(--bg);background:var(--card);padding:12px 0}
@media(min-width:840px){.sf-table tbody tr{display:table-row;border-bottom:1px solid var(--line);padding:0}}
.sf-table tbody tr:hover{background:var(--accent-soft)}
.sf-table td{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 14px;border:none}
@media(min-width:840px){.sf-table td{display:table-cell;vertical-align:middle;padding:12px 14px;border-bottom:1px solid var(--line)}}
/* mobile data labels */
.sf-table td::before{content:attr(data-label);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);flex-shrink:0}
@media(min-width:840px){.sf-table td::before{display:none}}
.sf-table .sf-tcell-prod{font-weight:600}
.sf-table .sf-tthumb{width:46px;height:46px;border-radius:8px;border:1px solid var(--line);object-fit:contain;background:#fff;flex-shrink:0;display:inline-block;overflow:hidden;font-size:0;line-height:0;color:transparent}
.sf-table .sf-tsku{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:var(--ink-soft)}
.sf-table .sf-tbrand{max-height:28px;max-width:92px;width:auto;height:auto;object-fit:contain;display:inline-block;vertical-align:middle}
/* Thumbnail hover preview (full-size image, appended to body so it isn't clipped) */
.sf-thumb-pop{position:absolute;z-index:300;display:none;background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px;box-shadow:var(--shadow-lg);pointer-events:none}
.sf-thumb-pop.is-on{display:block}
.sf-thumb-pop img{display:block;width:268px;height:268px;object-fit:contain;border-radius:8px}

/* quantity stepper */
.sf-stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--card)}
.sf-stepper button{width:38px;height:42px;border:none;background:var(--line-soft);color:var(--ink);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sf-stepper button:hover{background:var(--accent-soft);color:var(--accent)}
.sf-stepper input{width:46px;height:42px;border:none;text-align:center;font-size:15px;font-weight:700;color:var(--ink);outline:none;-moz-appearance:textfield}
.sf-stepper input::-webkit-outer-spin-button,.sf-stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* ----------------------------------------------------------------------------
   Product detail page
   -------------------------------------------------------------------------- */
.sf-pd{display:grid;grid-template-columns:1fr;gap:24px;margin:8px 0 8px}
@media(min-width:900px){.sf-pd{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:42px}}
.sf-pd-gallery{position:relative}
.sf-pd-main{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);aspect-ratio:1/1;overflow:hidden;display:flex;align-items:center;justify-content:center}
.sf-pd-main img{width:100%;height:100%;object-fit:contain;padding:18px}
.sf-pd-thumbs{display:flex;gap:8px;overflow-x:auto;padding-top:10px;-ms-overflow-style:none;scrollbar-width:none}
.sf-pd-thumbs::-webkit-scrollbar{display:none}
.sf-pd-thumb{flex:0 0 auto;width:64px;height:64px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;cursor:pointer}
.sf-pd-thumb img{width:100%;height:100%;object-fit:contain;padding:5px}
.sf-pd-thumb.is-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}

.sf-pd-brand{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.sf-pd-title{font-size:24px;font-weight:800;margin:6px 0 10px;line-height:1.2}
@media(min-width:760px){.sf-pd-title{font-size:30px}}
.sf-pd-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:14px 0}
.sf-pd-price .sf-now{font-size:30px;font-weight:800;color:var(--ink)}
.sf-pd-price .sf-was{font-size:17px;color:var(--muted);text-decoration:line-through;font-weight:600}
.sf-pd-vat{font-size:12px;color:var(--muted)}
.sf-pd-actions{display:flex;gap:10px;align-items:center;margin:18px 0;flex-wrap:wrap}
.sf-variants{display:flex;flex-direction:column;gap:10px;margin:16px 0}
.sf-variant-row label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;color:var(--ink-soft)}
.sf-variant-opts{display:flex;flex-wrap:wrap;gap:8px}
.sf-variant-opt{border:1px solid var(--line);background:var(--card);border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer;min-height:42px;display:inline-flex;align-items:center}
.sf-variant-opt:hover{border-color:var(--accent)}
.sf-variant-opt.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.sf-variant-opt.is-disabled{opacity:.4;text-decoration:line-through;pointer-events:none}
.sf-pd-desc{margin-top:8px;color:var(--ink-soft);line-height:1.7}
.sf-specs{width:100%;border-collapse:collapse;margin-top:10px;font-size:14px}
.sf-specs th,.sf-specs td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
.sf-specs th{color:var(--ink-soft);font-weight:600;width:45%}

/* rich-text content (descriptions, admin HTML) */
.sf-richtext h2{font-size:19px;font-weight:800;color:var(--accent);margin:18px 0 8px}
.sf-richtext h3{font-size:16px;font-weight:700;margin:14px 0 6px}
.sf-richtext p{margin:0 0 12px;line-height:1.7}
.sf-richtext ul{margin:0 0 12px;padding-left:20px;list-style:disc}
.sf-richtext ol{margin:0 0 12px;padding-left:20px;list-style:decimal}
.sf-richtext ol li[data-list="bullet"]{list-style:disc}
.sf-richtext a{color:var(--accent);text-decoration:underline}
.sf-richtext img{border-radius:var(--radius-sm);margin:10px 0}

/* ----------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.sf-foot{background:var(--accent-dark);color:rgba(255,255,255,.78);margin-top:48px;padding:40px 0 24px;font-size:14px;flex-shrink:0}
.sf-foot h4{color:#fff;font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin:0 0 14px}
.sf-foot a{color:rgba(255,255,255,.78);display:block;padding:5px 0}
.sf-foot a:hover{color:var(--cta)}
.sf-foot .sf-foot-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 20px}
@media(min-width:760px){.sf-foot .sf-foot-cols{grid-template-columns:repeat(4,1fr) 1.4fr}}
.sf-foot .sf-foot-top{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;margin-bottom:22px;flex-wrap:wrap}
.sf-foot .sf-foot-about{color:rgba(255,255,255,.6);margin:0}
.sf-foot .sf-foot-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:30px;padding-top:18px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;color:rgba(255,255,255,.55);font-size:12.5px}

/* ============================================================================
   FORMS — inputs, labels, validation  (CONSUME these in checkout/auth builders)
   ----------------------------------------------------------------------------
   .sf-form          vertical form wrapper (stacks .sf-field, 18px gap)
   .sf-form-row      2-col row on >=560px (e.g. first/last name), 1-col mobile
   .sf-field         one label+input+help/error group (the row child)
   .sf-label         block field label; add <span class="sf-req"> for the * mark
   .sf-input         text/email/tel/number/password input (44px, themed focus)
   .sf-select        native <select> with chevron (shares look with .sf-input)
   .sf-textarea      multi-line input (min-height 96px)
   .sf-input.is-error / .sf-select.is-error / .sf-textarea.is-error  red border
   .sf-input-group   horizontal input cluster (e.g. phone prefix btn + number)
   .sf-help          small muted hint under a field
   .sf-error         inline red validation message under a field (with !icon)
   .sf-checkrow      flex row: checkbox/radio + its inline label (44px target)
   .sf-checkbox / .sf-radio   themed native checkbox/radio (accent-color)
   .sf-fieldset      bordered, titled group — used for the optional Business/VAT
                     block; pair with <legend class="sf-legend">
   .sf-alert (+ -error/-success/-info)  full-width banner (e.g. login "bad creds")
   ========================================================================== */
.sf-form{display:flex;flex-direction:column;gap:18px}
.sf-form-row{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:560px){.sf-form-row{grid-template-columns:1fr 1fr}}
.sf-form-row.sf-cols-1{grid-template-columns:1fr}
.sf-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.sf-field.sf-col-span{grid-column:1/-1}
.sf-label{font-size:13.5px;font-weight:700;color:var(--ink-soft);line-height:1.2}
.sf-label .sf-req{color:var(--danger);margin-left:2px}
.sf-input,
.sf-textarea{
  width:100%;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  background:var(--card);color:var(--ink);font-family:inherit;font-size:15px;
  padding:11px 14px;min-height:46px;outline:none;
  transition:border-color .12s,box-shadow .12s;
}
.sf-textarea{min-height:96px;line-height:1.5;resize:vertical}
.sf-input::placeholder,
.sf-textarea::placeholder{color:var(--muted)}
.sf-input:focus,
.sf-textarea:focus,
.sf-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
/* number inputs: hide spinners (qty handled by .sf-stepper instead) */
.sf-input[type=number]{-moz-appearance:textfield}
.sf-input[type=number]::-webkit-outer-spin-button,
.sf-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
/* .sf-select already defined in the category toolbar block above; extend it to
   match the form input height + focus ring here without redeclaring its arrow. */
.sf-select{width:100%;min-height:46px;height:auto;border-width:1.5px;border-radius:var(--radius-sm);font-size:15px;padding:11px 40px 11px 14px}
/* error state */
.sf-input.is-error,
.sf-select.is-error,
.sf-textarea.is-error{border-color:var(--danger)}
.sf-input.is-error:focus,
.sf-select.is-error:focus,
.sf-textarea.is-error:focus{box-shadow:0 0 0 3px rgba(220,38,38,.14)}
/* horizontal input cluster (phone prefix + number, PSČ + city, etc.) */
.sf-input-group{display:flex;align-items:stretch}
.sf-input-group>.sf-input{border-radius:0}
.sf-input-group>*:first-child{border-top-left-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm)}
.sf-input-group>*:last-child{border-top-right-radius:var(--radius-sm);border-bottom-right-radius:var(--radius-sm)}
.sf-input-group>*+*{margin-left:-1.5px}
.sf-input-addon{display:flex;align-items:center;gap:6px;padding:0 12px;border:1.5px solid var(--line);background:var(--line-soft);color:var(--ink-soft);font-size:14px;white-space:nowrap;cursor:pointer}
.sf-input-addon:hover{background:var(--accent-soft);color:var(--accent)}
.sf-help{font-size:12px;color:var(--muted);line-height:1.4}
.sf-error{font-size:12.5px;color:var(--danger);font-weight:600;line-height:1.4;display:flex;align-items:flex-start;gap:5px}
.sf-error::before{content:"!";flex-shrink:0;width:15px;height:15px;border-radius:50%;background:var(--danger);color:#fff;font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;margin-top:1px}
/* checkbox / radio rows */
.sf-checkrow{display:flex;align-items:flex-start;gap:10px;cursor:pointer;min-height:32px;font-size:14px;color:var(--ink-soft);line-height:1.45}
.sf-checkrow a{color:var(--accent);text-decoration:underline}
.sf-checkbox,
.sf-radio{flex-shrink:0;width:20px;height:20px;margin-top:1px;accent-color:var(--accent);cursor:pointer}
.sf-radio{border-radius:50%}
.sf-checkrow-note{display:block;font-size:12px;color:var(--muted);margin-top:2px}
/* bordered titled group (optional Business / VAT block) */
.sf-fieldset{border:1.5px solid var(--line);border-radius:var(--radius);padding:18px;margin:0}
.sf-legend{font-size:13.5px;font-weight:800;color:var(--ink);padding:0 8px;letter-spacing:-.01em}
/* full-width inline alert banner */
.sf-alert{border-radius:var(--radius-sm);padding:12px 14px;font-size:13.5px;line-height:1.45;border:1px solid var(--line);background:var(--card);color:var(--ink-soft)}
.sf-alert-error{border-color:rgba(220,38,38,.3);background:rgba(220,38,38,.06);color:#b91c1c}
.sf-alert-success{border-color:rgba(21,163,74,.3);background:rgba(21,163,74,.07);color:#15803d}
.sf-alert-info{border-color:var(--accent-soft);background:var(--accent-soft);color:var(--accent-dark)}

/* ============================================================================
   AUTH CARD — centered narrow card for login / register / reset
   ----------------------------------------------------------------------------
   .sf-auth-wrap     centers the card vertically with comfortable page padding
   .sf-auth-card     the white card (max 440px) holding the form
   .sf-auth-title    centered heading
   .sf-auth-sub      muted centered subline under the title
   .sf-auth-divider  "or" separator (used before the Google button)
   .sf-auth-foot     centered footer link row ("Already have an account?")
   .sf-oauth-btn     full-width outlined OAuth button (Google), icon + label
   ========================================================================== */
.sf-auth-wrap{max-width:480px;margin:0 auto;padding:32px 16px 56px}
@media(min-width:760px){.sf-auth-wrap{padding:56px 16px 72px}}
.sf-auth-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:28px 22px}
@media(min-width:560px){.sf-auth-card{padding:34px 32px}}
.sf-auth-title{font-size:24px;font-weight:800;text-align:center;margin:0 0 6px}
.sf-auth-sub{font-size:14px;color:var(--ink-soft);text-align:center;margin:0 0 22px}
.sf-auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:13px}
.sf-auth-divider::before,
.sf-auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.sf-auth-foot{text-align:center;font-size:14px;color:var(--ink-soft);margin-top:18px}
.sf-auth-foot a{color:var(--accent);font-weight:700}
.sf-auth-foot a:hover{color:var(--accent-dark)}
.sf-auth-link{font-size:13.5px;color:var(--ink-soft);text-align:center;display:block;margin-top:12px}
.sf-auth-link a:hover{color:var(--accent)}
.sf-oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:48px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:var(--card);color:var(--ink);font-weight:700;font-size:14.5px;cursor:pointer;transition:background .12s,border-color .12s}
.sf-oauth-btn:hover{background:var(--line-soft);border-color:var(--muted)}
.sf-oauth-btn svg{flex-shrink:0}

/* ============================================================================
   CART PAGE — line-item list + totals box  (use on /kosik/ cart.html)
   ----------------------------------------------------------------------------
   .sf-cart-layout   2-col on desktop (lines + sticky totals), 1-col mobile
   .sf-cart-lines    column holding the cart line cards
   .sf-cart-line     one line-item card (thumb / info / qty / price+remove)
   .sf-cart-thumb    64–80px square product image link
   .sf-cart-info     middle column (name link, variant, unit price)
   .sf-cart-name     product name link (clamped to 2 lines)
   .sf-cart-variant  small muted variant label
   .sf-cart-actions  right column: line total + remove button (stacked)
   .sf-cart-remove   text/icon "remove" button (danger on hover)
   .sf-qty           qty control wrapper — alias of .sf-stepper sizing for cart
                     (reuse .sf-stepper markup; .sf-qty just constrains width)
   --- TOTALS (also used as the checkout order-review summary) ---
   .sf-totals        sticky white summary box (top:88px on desktop)
   .sf-totals-row    label/amount line (justify-between)
   .sf-totals-row.is-discount   green discount line
   .sf-totals-sep    hairline divider inside the box
   .sf-totals-grand  bold grand-total row (accent amount)
   .sf-totals-note   tiny "incl. VAT" muted note
   --- COUPON ---
   .sf-coupon        applied-coupon row OR the code-entry form wrapper
   .sf-coupon-form   flex: text input + apply button
   .sf-coupon-tag    pill showing the applied code (with remove ✕)
   ========================================================================== */
.sf-cart-layout{display:grid;grid-template-columns:1fr;gap:20px;align-items:start;margin:8px 0 8px}
@media(min-width:900px){.sf-cart-layout{grid-template-columns:minmax(0,1fr) 360px;gap:28px}}
.sf-cart-lines{display:flex;flex-direction:column;gap:12px;min-width:0}
.sf-cart-line{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"thumb info actions" "thumb qty actions";gap:6px 14px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
@media(min-width:560px){.sf-cart-line{grid-template-columns:auto 1fr auto auto;grid-template-areas:"thumb info qty actions";align-items:center;gap:16px}}
.sf-cart-thumb{grid-area:thumb;display:block;width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;background:#fff;border:1px solid var(--line);flex-shrink:0}
.sf-cart-thumb img{width:100%;height:100%;object-fit:contain;padding:4px}
.sf-cart-info{grid-area:info;min-width:0}
.sf-cart-name{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sf-cart-name:hover{color:var(--accent)}
.sf-cart-variant{font-size:12.5px;color:var(--muted);margin-top:2px}
.sf-cart-unit{font-size:13px;color:var(--ink-soft);font-weight:600;margin-top:4px}
.sf-cart-qty{grid-area:qty;display:flex;align-items:center}
.sf-cart-actions{grid-area:actions;display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;gap:8px;height:100%;white-space:nowrap}
.sf-cart-linetotal{font-size:15px;font-weight:800;color:var(--ink)}
.sf-cart-remove{background:none;border:none;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:4px;transition:color .12s}
.sf-cart-remove:hover{color:var(--danger)}
/* width constraint so the shared .sf-stepper looks right in a cart line */
.sf-qty{flex-shrink:0}
.sf-qty .sf-stepper{width:auto}
/* totals / order-review box */
.sf-totals{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
@media(min-width:900px){.sf-totals{position:sticky;top:88px}}
.sf-totals-title{font-size:16px;font-weight:800;margin:0 0 14px}
.sf-totals-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;color:var(--ink-soft);padding:5px 0}
.sf-totals-row span:last-child{font-weight:700;color:var(--ink);white-space:nowrap}
.sf-totals-row.is-discount,
.sf-totals-row.is-discount span:last-child{color:var(--ok)}
.sf-totals-row.is-free span:last-child{color:var(--ok)}
.sf-totals-sep{height:1px;background:var(--line);margin:10px 0}
.sf-totals-grand{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:18px;font-weight:800;padding-top:6px}
.sf-totals-grand span:last-child{color:var(--accent)}
.sf-totals-note{font-size:12px;color:var(--muted);margin:6px 0 0}
.sf-totals .sf-btn{margin-top:16px}
/* coupon */
.sf-coupon{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.sf-coupon-form{display:flex;gap:8px;align-items:stretch}
.sf-coupon-form .sf-input{flex:1;min-height:0}
.sf-coupon-form .sf-btn{margin-top:0;flex-shrink:0;white-space:nowrap}
.sf-coupon-tag{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:9px 12px;font-size:13.5px}
.sf-coupon-tag b{color:var(--accent-dark);font-weight:800}
.sf-coupon-tag .sf-coupon-meta{color:var(--ink-soft);font-weight:600}
.sf-coupon-remove{background:none;border:none;color:var(--danger);font-weight:700;font-size:12.5px;cursor:pointer;padding:2px 4px}
.sf-coupon-remove:hover{text-decoration:underline}
/* add-to-cart toast */
.sf-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(16px);z-index:9999;display:flex;align-items:center;gap:8px;background:var(--accent);color:var(--on-accent);padding:12px 20px;border-radius:999px;box-shadow:var(--shadow);font-weight:700;font-size:14px;opacity:0;transition:opacity .25s ease,transform .25s ease;pointer-events:none}
.sf-toast.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================================
   CHECKOUT — 2-col layout (form + sticky order review) and payment methods
   ----------------------------------------------------------------------------
   .sf-checkout-grid 2-col on desktop (form 7 / review 5), 1-col mobile;
                     review comes FIRST in DOM order is NOT required — on mobile
                     put the form first, review collapses below it.
   .sf-checkout-main left column: stacked .sf-checkout-section cards
   .sf-checkout-side right column: holds the sticky .sf-order-review
   .sf-checkout-section  a titled white card (Contact / Shipping / Payment …)
   .sf-checkout-section-title  the h2 inside a section
   .sf-order-review  reuse .sf-totals styling; this is the sticky summary that
                     also lists the cart line items in compact form
   .sf-review-items  compact item list inside the order review
   .sf-review-item   one compact line: thumb + name/qty + line total
   .sf-review-thumb  48px square thumb in the review
   --- chosen-option radio cards (shipping + payment) ---
   .sf-pay-methods / .sf-ship-methods   vertical stack of selectable cards
   .sf-pay-method  / .sf-ship-method    one selectable card (label>input:radio)
                     add .is-active when its radio is checked (JS toggles it)
   .sf-method-main   left side of the card (radio + name + sub-desc)
   .sf-method-name   bold option name
   .sf-method-desc   muted small description / sub-line
   .sf-method-price  right side price ("Free" or "€X.XX") / discount note
   .sf-method-price.is-discount  green ("−€X.XX")
   --- packeta pickup-point picker (reused control) ---
   .sf-pickup        dashed "choose pickup point" button (full width)
   .sf-pickup.is-chosen  solid state once a point is selected
   ========================================================================== */
.sf-checkout-grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:start;margin:8px 0 8px}
@media(min-width:960px){.sf-checkout-grid{grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:28px}}
.sf-checkout-main{display:flex;flex-direction:column;gap:16px;min-width:0}
.sf-checkout-side{min-width:0}
.sf-checkout-section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
@media(min-width:560px){.sf-checkout-section{padding:22px 24px}}
.sf-checkout-section-title{font-size:16px;font-weight:800;margin:0 0 16px}
/* order review = totals box that also lists items; reuse .sf-totals + this */
.sf-order-review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
@media(min-width:960px){.sf-order-review{position:sticky;top:88px}}
.sf-review-items{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.sf-review-item{display:flex;align-items:center;gap:10px}
.sf-review-thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;background:#fff;border:1px solid var(--line);flex-shrink:0}
.sf-review-thumb img{width:100%;height:100%;object-fit:contain;padding:3px}
.sf-review-item .sf-review-meta{flex:1;min-width:0}
.sf-review-name{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sf-review-qty{font-size:11.5px;color:var(--muted);margin-top:1px}
.sf-review-line{font-size:13.5px;font-weight:700;color:var(--ink);white-space:nowrap}
/* selectable method cards (shipping + payment) */
.sf-pay-methods,
.sf-ship-methods{display:flex;flex-direction:column;gap:10px}
.sf-pay-method,
.sf-ship-method{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:14px;cursor:pointer;transition:border-color .12s,background .12s;min-height:56px}
.sf-pay-method:hover,
.sf-ship-method:hover{border-color:var(--accent)}
.sf-pay-method.is-active,
.sf-ship-method.is-active{border-color:var(--accent);background:var(--accent-soft)}
.sf-method-main{display:flex;align-items:center;gap:12px;min-width:0}
.sf-method-main input[type=radio]{flex-shrink:0;width:20px;height:20px;accent-color:var(--accent)}
.sf-method-text{min-width:0}
.sf-method-name{font-size:14px;font-weight:700;color:var(--ink)}
.sf-method-desc{font-size:12px;color:var(--ink-soft);margin-top:1px}
.sf-method-tag{font-size:11px;font-weight:700;color:var(--accent);margin-left:4px}
.sf-method-price{font-size:14px;font-weight:800;color:var(--ink);white-space:nowrap;flex-shrink:0;text-align:right}
.sf-method-price.is-discount{color:var(--ok)}
.sf-method-price small{display:block;font-size:11px;font-weight:600;color:var(--ok)}
/* packeta pickup-point picker */
.sf-pickup{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:48px;margin-top:12px;border:1.5px dashed var(--line);border-radius:var(--radius-sm);background:var(--card);color:var(--ink-soft);font-weight:700;font-size:14px;cursor:pointer;transition:border-color .12s,color .12s}
.sf-pickup:hover{border-color:var(--accent);color:var(--accent)}
.sf-pickup.is-error{border-color:var(--danger);color:var(--danger)}
.sf-pickup-chosen{display:flex;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;color:var(--accent-dark)}
.sf-pickup-chosen svg{flex-shrink:0}

/* ----------------------------------------------------------------------------
   Utilities
   -------------------------------------------------------------------------- */
.sf-muted{color:var(--muted)}
.sf-center{text-align:center}
.sf-mt-0{margin-top:0}
