/* ============================================================
   Houby z Vršovic — e-shop · design system
   ============================================================ */
:root{
  --cream:#F2EEE1; --cream-2:#EBE3D1; --paper:#FBF9F2;
  --ink:#20231C; --ink-2:#5A5C50; --muted:#6F7163;
  --line:#E4DBC8; --line-2:#D8CDB6;
  --forest:#1F3D2B; --forest-2:#2C4A36; --moss:#657A46;
  --brown:#8A5E3B; --taupe:#897A6A; --beige:#CBB89D;
  --amber:#D6A84F; --slate:#243038; --slate-2:#2C3C45; --yellow:#F1D981;
  --accent:#D6A84F;
  --radius:20px; --radius-lg:26px; --radius-sm:14px;
  --shadow:0 16px 38px -18px rgba(40,33,18,.30);
  --shadow-sm:0 8px 20px -12px rgba(40,33,18,.24);
  --font-head:'Poppins'; --font-body:'Mulish';
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--cream); color:var(--ink);
  font-family:var(--font-body),system-ui,sans-serif;
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--font-head),sans-serif; font-weight:700; line-height:1.08; letter-spacing:-.01em; color:var(--ink); margin:0}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none}
::selection{background:var(--accent); color:#1d1a10}
.stage{min-height:100vh; display:flex; flex-direction:column}
.stage.tone-dark{background:#1f271e}
.stage.tone-dark .shop, .stage.tone-dark .pdp{background:#1f271e}
.stage.tone-dark .shop *:not(.btn):not(.media-badge):not(.catpill):not(.badge):not(.sensor *),
.stage.tone-dark .shop h1, .stage.tone-dark .shop h2, .stage.tone-dark .shop h3{color:#F2EEE1}
.stage.tone-dark .card{background:#28311f; border-color:#36412c}
.stage.tone-dark .card-latin,.stage.tone-dark .card-benefit,.stage.tone-dark .resultcount{color:#b9c1a8}
.stage.tone-dark .freshband{background:#28311f; border-color:#3a4530}
.stage.tone-dark .trust{background:#28311f; border-color:#36412c}
.stage.tone-dark .trust-tx em{color:#aab199}
.stage.tone-dark .freshband-tag{color:var(--forest)}
.stage.tone-dark .freshband p strong{color:#F2EEE1}

/* ---------- layout container ---------- */
.wrap{width:min(1240px,100% - 64px); margin-inline:auto}

/* ---------- Header ---------- */
.hd{position:sticky; top:0; z-index:40; background:rgba(251,249,242,.86); backdrop-filter:blur(10px); border-bottom:1px solid transparent; transition:.25s}
.hd-solid{border-color:var(--line); box-shadow:0 6px 24px -20px rgba(0,0,0,.5)}
.hd-in{width:min(1240px,100% - 48px); margin-inline:auto; height:74px; display:flex; align-items:center; gap:24px}
.hd-nav{display:flex; gap:22px; margin-left:8px; flex:1; flex-wrap:wrap}
.hd-nav a{font-size:14.5px; font-weight:600; color:var(--ink); padding:6px 0; position:relative; opacity:.82}
.hd-nav a:hover{opacity:1}
.hd-nav a.on{opacity:1}
.hd-nav a.on::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--forest); border-radius:2px}
.hd-act{display:flex; align-items:center; gap:12px}
.lang{display:flex; align-items:center; gap:5px; font-size:13.5px; font-weight:700; color:var(--ink); padding:7px 10px; border-radius:999px; border:1px solid var(--line)}
.lang:hover{background:#fff}
.flag{width:18px; height:13px; border-radius:2px; background:
  linear-gradient(to bottom,#fff 0 50%,#D7141A 50% 100%); position:relative; overflow:hidden}
.flag::before{content:""; position:absolute; left:0; top:0; border-style:solid; border-width:6.5px 7px 6.5px 0; border-color:transparent #11457E transparent transparent}
.cartbtn{position:relative; width:42px; height:42px; border-radius:999px; display:grid; place-items:center; color:var(--ink); border:1px solid var(--line)}
.cartbtn:hover{background:var(--forest); color:#fff; border-color:var(--forest)}
.cartbtn-c{position:absolute; top:-4px; right:-4px; min-width:19px; height:19px; padding:0 5px; border-radius:999px; background:var(--accent); color:#1d1a10; font-size:11px; font-weight:800; display:grid; place-items:center; box-shadow:0 0 0 2px var(--cream)}

/* ---------- Brand logo lockup ---------- */
.brand{display:flex; align-items:center; gap:11px}
.brand-crest{width:42px; height:42px; border-radius:12px; background:var(--yellow); display:grid; place-items:center; box-shadow:inset 0 0 0 2px rgba(0,0,0,.06)}
.brand-crest-glyph{color:var(--forest); display:grid; place-items:center}
.brand-words{display:flex; flex-direction:column; line-height:1}
.brand-name{font-family:var(--font-head); font-weight:800; font-size:17px; letter-spacing:.01em; color:var(--forest); white-space:nowrap}
.brand-name em{font-style:normal; font-weight:600}
.brand-sub{font-size:8.5px; font-weight:800; letter-spacing:.16em; color:#fff; background:var(--brown); padding:2px 6px; border-radius:5px; margin-top:4px; align-self:flex-start; white-space:nowrap}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-head); font-weight:600; border-radius:999px; transition:.18s; white-space:nowrap; line-height:1}
.btn svg{flex:none}
.btn-sm{font-size:13.5px; padding:9px 15px}
.btn-md{font-size:15px; padding:12px 22px}
.btn-lg{font-size:16px; padding:15px 26px}
.btn-primary{background:var(--forest); color:#F6F2E6}
.btn-primary:hover{background:var(--forest-2); transform:translateY(-1px)}
.btn-primary:disabled{background:#b9b3a3; transform:none; cursor:not-allowed}
.btn-dark{background:var(--ink); color:#F6F2E6}
.btn-dark:hover{background:#34372d; transform:translateY(-1px)}
.btn-ghost{background:transparent; color:var(--forest); box-shadow:inset 0 0 0 1.5px var(--forest)}
.btn-ghost:hover{background:var(--forest); color:#fff}
.btn-ghost-dark{background:transparent; color:#F6F2E6; box-shadow:inset 0 0 0 1.5px rgba(246,242,230,.5)}
.btn-ghost-dark:hover{background:rgba(246,242,230,.12)}
.btn .full,.btn.full{width:100%}
.full{width:100%}

/* ---------- badges / stars / price ---------- */
.badge{display:inline-flex; align-items:center; font-size:11.5px; font-weight:800; letter-spacing:.02em; padding:4px 9px; border-radius:999px}
.stars{display:inline-flex; align-items:center; gap:5px; font-size:13px; color:var(--muted)}
.stars-row{display:inline-flex; color:var(--amber)}
.stars-row .off{color:#d9cfb8}
.stars-num{font-weight:800; color:var(--ink)}
.stars-empty{font-size:12.5px; font-style:italic}
.price{display:inline-flex; align-items:baseline; gap:5px; font-family:var(--font-head)}
.price-from{font-size:12px; font-weight:600; color:var(--muted); font-family:var(--font-body)}
.price-val{font-weight:800; color:var(--ink)}
.price-md .price-val{font-size:19px}
.price-lg .price-val{font-size:30px}
.price-sm .price-val{font-size:15px}

/* ---------- stepper ---------- */
.stepper{display:inline-flex; align-items:center; border:1px solid var(--line-2); border-radius:999px; background:#fff; overflow:hidden}
.stepper button{width:34px; height:34px; display:grid; place-items:center; color:var(--ink)}
.stepper button:hover{background:var(--cream-2)}
.stepper button:disabled{opacity:.35; cursor:default}
.stepper span{min-width:30px; text-align:center; font-weight:800; font-family:var(--font-head); font-size:14px}
.stepper-lg button{width:44px; height:44px}
.stepper-lg span{min-width:38px; font-size:16px}
.stepper-sm button{width:28px; height:28px}
.stepper-sm span{min-width:24px; font-size:13px}

/* ---------- photo placeholders ---------- */
.photo{position:relative; overflow:hidden; display:grid; place-items:center}
.photo-cream{background:linear-gradient(135deg,#efe7d3,#e0d4ba)}
.photo-beige{background:linear-gradient(135deg,#d9c9 ad,#c2ac89)}
.photo-beige{background:linear-gradient(135deg,#dacbb0,#c3ad8a)}
.photo-brown{background:linear-gradient(135deg,#9d784f,#76502f)}
.photo-slate{background:linear-gradient(135deg,#2d3d46,#1d2930)}
.photo-grain{position:absolute; inset:0; background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.10) 0 2px,transparent 2px 11px); mix-blend-mode:soft-light; pointer-events:none}
.photo-label{font-family:'JetBrains Mono',ui-monospace,monospace; font-size:11px; letter-spacing:.04em; color:rgba(40,33,18,.5); text-align:center; padding:0 10px}
.photo-brown .photo-label,.photo-slate .photo-label{color:rgba(255,255,255,.62)}
.media-badge{position:absolute; top:12px; left:12px; font-size:11.5px; font-weight:800; padding:5px 10px; border-radius:999px; letter-spacing:.01em; white-space:nowrap}
.media-badge-fresh{background:var(--forest); color:#F6F2E6}
.media-badge-preorder{background:var(--accent); color:#241d09}
.media-badge-stock{background:#fff; color:var(--forest)}

/* ---------- trust bar ---------- */
.trustbar{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:26px 0 6px}
.trust{display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); padding:14px 16px}
.trust-ic{width:38px; height:38px; border-radius:11px; background:var(--cream); color:var(--forest); display:grid; place-items:center; flex:none}
.trust-tx{display:flex; flex-direction:column; line-height:1.25}
.trust-tx strong{font-size:14px; font-family:var(--font-head)}
.trust-tx em{font-style:normal; font-size:12.5px; color:var(--muted)}

/* ---------- shop ---------- */
.shop{padding:34px 0 10px}
.shop>*{width:min(1240px,100% - 48px); margin-inline:auto}
.crumb{display:flex; align-items:center; gap:8px; font-size:13px; color:var(--muted); margin-bottom:14px}
.crumb a:hover{color:var(--forest)}
.crumb b{color:var(--ink)}
.shop-hero h1{font-size:clamp(40px,6vw,62px); margin:2px 0 12px}
.shop-hero p{max-width:60ch; color:var(--ink-2); font-size:17px}
.freshband{display:flex; align-items:center; gap:13px; margin-top:24px; background:#fff; border:1px solid var(--line); border-left:4px solid var(--moss); border-radius:var(--radius-sm); padding:14px 18px; color:var(--forest)}
.freshband p{margin:0; font-size:14.5px; color:var(--ink-2)}
.freshband strong{color:var(--ink)}
.freshband-tag{margin-left:auto; background:var(--cream-2); color:var(--forest); font-weight:800; font-size:12.5px; padding:5px 12px; border-radius:999px; white-space:nowrap}

.shop-body{display:block; margin-top:6px}
.shop-body.with-side{display:grid; grid-template-columns:230px 1fr; gap:32px; align-items:start}
.shop-side{position:sticky; top:90px}
.shop-side h4{font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:12px}
.shop-toolbar{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin:26px 0 22px}
.catpills{display:flex; gap:9px; flex-wrap:wrap}
.side-filters .catpills{flex-direction:column; align-items:stretch}
.catpill{font-family:var(--font-head); font-weight:600; font-size:14px; padding:9px 17px; border-radius:999px; background:#fff; border:1px solid var(--line-2); color:var(--ink); transition:.15s; text-align:left}
.catpill:hover{border-color:var(--forest)}
.catpill.on{background:var(--forest); color:#F6F2E6; border-color:var(--forest)}
.freshtoggle{display:flex; align-items:center; gap:10px; margin-top:16px; font-size:14px; cursor:pointer}
.freshtoggle input{display:none}
.ft-box{width:22px; height:22px; border-radius:7px; border:1.5px solid var(--line-2); display:grid; place-items:center; color:transparent; background:#fff}
.freshtoggle input:checked + .ft-box{background:var(--forest); border-color:var(--forest); color:#fff}
.toolbar-right{display:flex; align-items:center; gap:18px}
.resultcount{font-size:13.5px; color:var(--muted)}
.sortsel{position:relative; display:flex; align-items:center; gap:7px; font-size:13.5px; color:var(--muted); font-weight:600}
.sortsel select{appearance:none; font-family:var(--font-body); font-weight:700; font-size:13.5px; color:var(--ink); background:#fff; border:1px solid var(--line-2); border-radius:999px; padding:8px 30px 8px 14px}
.sortsel svg{position:absolute; right:10px; pointer-events:none; color:var(--muted)}

/* ---------- product grid + cards ---------- */
.grid{display:grid; gap:24px}
.grid-image{grid-template-columns:repeat(3,1fr)}
.grid-info{grid-template-columns:repeat(2,1fr)}
.card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:.2s}
.card:hover{transform:translateY(-3px); box-shadow:var(--shadow)}
.card-info{flex-direction:row}
.card-media{display:block; padding:0; position:relative; line-height:0; background:none; border:none; width:100%}
.card-info .card-media{width:42%; flex:none}
.card-info .photo{height:100%}
.card-body{padding:18px 18px 18px; display:flex; flex-direction:column; gap:7px; flex:1}
.card-meta{display:flex; align-items:center; justify-content:space-between; gap:10px}
.card-cat{font-size:11.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--moss)}
.card-name{font-size:19px; cursor:pointer; margin-top:2px}
.card-name:hover{color:var(--forest)}
.card-latin{font-size:13px; color:var(--muted); font-style:italic; margin:-2px 0 0}
.card-benefit{font-size:13.5px; color:var(--ink-2); margin:2px 0}
.card-foot{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:auto; padding-top:10px}
.card-soon{opacity:.96}

/* ---------- wholesale ---------- */
.wholesale{margin-top:46px; background:var(--forest); color:#EFEAD9}
.wholesale-in{width:min(1240px,100% - 48px); margin-inline:auto; padding:46px 0; display:grid; grid-template-columns:1.4fr 1fr; gap:30px; align-items:center}
.wholesale .eyebrow{display:inline-block; font-size:12.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:12px}
.wholesale h2{font-size:34px; color:#F6F2E6; margin-bottom:12px}
.wholesale p{color:#cfd3bf; max-width:54ch; font-size:15.5px}
.wholesale-act{display:flex; flex-direction:column; gap:12px; align-items:flex-start}
.wholesale-act .btn{align-self:stretch}

/* ---------- PDP ---------- */
.pdp{padding:30px 0 20px}
.pdp>*{width:min(1180px,100% - 48px); margin-inline:auto}
.pdp-top{display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:start; margin-top:6px}
.pdp-gallery{position:sticky; top:92px}
.pdp-thumbs{display:flex; gap:10px; margin-top:12px}
.thumb{width:74px; height:74px; border-radius:12px; overflow:hidden; position:relative; border:2px solid transparent; cursor:pointer}
.thumb.on{border-color:var(--forest)}
.thumb-cream{background:linear-gradient(135deg,#efe7d3,#e0d4ba)}
.thumb-beige{background:linear-gradient(135deg,#dacbb0,#c3ad8a)}
.thumb-brown{background:linear-gradient(135deg,#9d784f,#76502f)}
.thumb-slate{background:linear-gradient(135deg,#2d3d46,#1d2930)}
.pdp-meta{display:flex; align-items:center; gap:14px; margin-bottom:10px}
.pdp-info h1{font-size:clamp(30px,4.4vw,44px)}
.pdp-latin{font-style:italic; color:var(--muted); margin:6px 0 0; font-size:15px}
.pdp-tag{font-size:17px; color:var(--ink-2); margin:14px 0 0}
.pdp-price{display:flex; align-items:baseline; gap:10px; margin:20px 0 4px}
.pdp-was{text-decoration:line-through; color:var(--muted); font-size:17px}
.pdp-unit{color:var(--muted); font-size:14px}
.pdp-variants{margin-top:22px}
.vlabel{display:block; font-size:13px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); margin-bottom:10px}
.vpills{display:flex; gap:10px; flex-wrap:wrap}
.vpill{display:flex; flex-direction:column; align-items:flex-start; gap:2px; padding:10px 16px; border-radius:14px; background:#fff; border:1.5px solid var(--line-2); transition:.15s; min-width:96px}
.vpill b{font-family:var(--font-head); font-size:15px}
.vpill em{font-style:normal; font-size:11.5px; color:var(--muted)}
.vpill:hover{border-color:var(--forest)}
.vpill.on{border-color:var(--forest); background:var(--cream); box-shadow:inset 0 0 0 1px var(--forest)}
.pdp-sub{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
.subopt{display:flex; align-items:center; gap:10px; padding:13px 16px; border-radius:14px; border:1.5px solid var(--line-2); background:#fff; font-weight:700; font-size:14px; flex:1; min-width:200px}
.subopt em{font-style:normal; color:var(--moss); font-weight:800; margin-left:auto; font-size:12.5px}
.subopt.on{border-color:var(--forest); background:var(--cream)}
.radio{width:18px; height:18px; border-radius:999px; border:2px solid var(--line-2); flex:none; position:relative}
.subopt.on .radio,.opt.on .radio{border-color:var(--forest)}
.subopt.on .radio::after,.opt.on .radio::after{content:""; position:absolute; inset:3px; border-radius:999px; background:var(--forest)}
.pdp-buy{display:flex; gap:12px; margin-top:24px; align-items:stretch}
.addbtn{flex:1}
.freshcard{display:flex; gap:12px; align-items:flex-start; margin-top:18px; background:var(--cream); border:1px solid var(--line); border-radius:var(--radius-sm); padding:14px 16px; color:var(--forest)}
.freshcard div{display:flex; flex-direction:column; gap:3px}
.freshcard strong{font-size:14px}
.freshcard span{font-size:13px; color:var(--ink-2)}
.pdp-trust{display:flex; gap:18px; flex-wrap:wrap; margin-top:18px; padding-top:18px; border-top:1px solid var(--line)}
.pdp-trust span{display:flex; align-items:center; gap:7px; font-size:13px; font-weight:600; color:var(--ink-2)}
.pdp-trust svg{color:var(--moss)}
.pdp-acc{margin-top:18px; border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc>button{width:100%; display:flex; align-items:center; justify-content:space-between; padding:16px 2px; font-family:var(--font-head); font-weight:600; font-size:16px; color:var(--ink)}
.acc>button svg{transition:.2s; color:var(--muted)}
.acc.on>button svg{transform:rotate(180deg)}
.acc-body{padding:0 2px 18px; color:var(--ink-2); font-size:14.5px}
.spectable{margin:0; display:flex; flex-direction:column; gap:0}
.spectable div{display:flex; justify-content:space-between; gap:14px; padding:8px 0; border-bottom:1px dashed var(--line)}
.spectable div:last-child{border-bottom:none}
.spectable dt{color:var(--muted)}
.spectable dd{margin:0; font-weight:700; color:var(--ink); text-align:right}

/* PDP farm strip */
.pdp-farm{margin-top:50px; background:var(--slate); border-radius:var(--radius-lg); padding:38px; display:grid; grid-template-columns:1fr 1.1fr; gap:34px; align-items:center; color:#E8EBE3}
.pdp-farm .eyebrow{display:inline-block; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:12px}
.pdp-farm h2{color:#F2F4EC; font-size:28px; margin-bottom:12px}
.pdp-farm p{color:#aeb6ac; font-size:15px; max-width:46ch}
.sensors{display:grid; grid-template-columns:repeat(2,1fr); gap:16px}
.sensors-row{grid-template-columns:repeat(4,1fr)}
.sensor{background:var(--slate-2); border-radius:18px; padding:20px; display:flex; flex-direction:column; gap:6px; box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.sensor-ic{color:#fff; opacity:.9}
.sensor-ic .co2{display:inline-grid; place-items:center; width:24px; height:24px; border:2px solid currentColor; border-radius:999px; font-size:8px; font-weight:800; color:#fff}
.sensor-label{font-size:13px; color:#9aa49a}
.sensor-v{font-family:var(--font-head); font-weight:800; font-size:30px; color:#fff; line-height:1}
.sensor-v em{font-style:normal; font-size:14px; color:#9aa49a; margin-left:4px}

/* related */
.related{margin-top:54px}
.related h2{font-size:28px; margin-bottom:22px}

/* ---------- cart drawer ---------- */
.drawer-wrap{position:fixed; inset:0; z-index:80; pointer-events:none}
.drawer-ovl{position:absolute; inset:0; background:rgba(28,24,14,.42); opacity:0; transition:.3s}
.drawer{position:absolute; top:0; right:0; height:100%; width:min(440px,100%); background:var(--paper); box-shadow:-20px 0 60px -30px rgba(0,0,0,.5); transform:translateX(100%); transition:transform .32s cubic-bezier(.4,0,.1,1); display:flex; flex-direction:column}
.drawer-wrap.on{pointer-events:auto}
.drawer-wrap.on .drawer-ovl{opacity:1}
.drawer-wrap.on .drawer{transform:none}
.drawer-hd{display:flex; align-items:center; justify-content:space-between; padding:20px 22px; border-bottom:1px solid var(--line)}
.drawer-hd h3{display:flex; align-items:center; gap:9px; font-size:19px}
.drawer-hd h3 span{background:var(--forest); color:#fff; font-size:12px; font-weight:800; min-width:22px; height:22px; border-radius:999px; display:grid; place-items:center; font-family:var(--font-body)}
.iconbtn{width:38px; height:38px; border-radius:999px; display:grid; place-items:center; color:var(--ink)}
.iconbtn:hover{background:var(--cream-2)}
.drawer-empty{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; color:var(--muted)}
.drawer-empty svg{width:46px; height:46px; opacity:.4}
.ship-progress{padding:16px 22px; background:var(--cream); border-bottom:1px solid var(--line)}
.ship-progress p{margin:0 0 9px; font-size:13px; color:var(--ink-2)}
.ship-progress p.done{color:var(--moss); display:flex; align-items:center; gap:6px; font-weight:700}
.ship-progress .bar{height:7px; background:#e4dcc8; border-radius:999px; overflow:hidden}
.ship-progress .bar span{display:block; height:100%; background:linear-gradient(90deg,var(--moss),var(--forest)); transition:width .4s}
.drawer-items{flex:1; overflow-y:auto; padding:8px 22px}
.litem{display:flex; gap:13px; padding:16px 0; border-bottom:1px solid var(--line)}
.litem-img{width:66px; height:66px; border-radius:12px; flex:none; position:relative; overflow:hidden}
.litem-body{flex:1; display:flex; flex-direction:column; gap:9px}
.litem-top{display:flex; justify-content:space-between; gap:10px}
.litem-top strong{font-family:var(--font-head); font-size:14.5px; display:block}
.litem-var{font-size:12.5px; color:var(--muted)}
.litem-rm{color:var(--muted); width:26px; height:26px; border-radius:999px; display:grid; place-items:center; flex:none}
.litem-rm:hover{background:var(--cream-2); color:var(--ink)}
.litem-bot{display:flex; align-items:center; justify-content:space-between}
.litem-price{font-family:var(--font-head); font-weight:800; font-size:15px}
.drawer-ft{padding:18px 22px 22px; border-top:1px solid var(--line); background:var(--paper)}
.drawer-sub{display:flex; justify-content:space-between; font-size:16px; margin-bottom:4px}
.drawer-sub strong{font-family:var(--font-head); font-size:20px}
.drawer-note{font-size:12px; color:var(--muted); margin:0 0 14px}
.linklike{display:block; width:100%; text-align:center; margin-top:10px; font-size:13.5px; font-weight:700; color:var(--muted)}
.linklike:hover{color:var(--forest)}

/* ---------- checkout ---------- */
.checkout{padding:34px 0 50px}
.checkout>*{width:min(1140px,100% - 48px); margin-inline:auto}
.checkout-h{font-size:clamp(34px,5vw,48px); margin:4px 0 26px}
.checkout-grid{display:grid; grid-template-columns:1fr 400px; gap:34px; align-items:start}
.cform{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:24px 26px; margin-bottom:20px}
.cform h2{display:flex; align-items:center; gap:11px; font-size:20px; margin-bottom:20px}
.stepn{width:28px; height:28px; border-radius:999px; background:var(--forest); color:#fff; font-size:14px; font-weight:800; display:grid; place-items:center; font-family:var(--font-body)}
.frow{display:flex; gap:14px; flex-wrap:wrap}
.field{display:flex; flex-direction:column; gap:6px; margin-bottom:14px; flex:1; min-width:160px}
.field-wide{flex-basis:100%}
.field span{font-size:13px; font-weight:700; color:var(--ink-2)}
.field input,.cnote textarea{font-family:var(--font-body); font-size:15px; padding:12px 14px; border:1.5px solid var(--line-2); border-radius:12px; background:var(--paper); color:var(--ink); width:100%; transition:.15s}
.field input:focus,.cnote textarea:focus{outline:none; border-color:var(--forest); background:#fff}
.optlist{display:flex; flex-direction:column; gap:11px}
.opt{display:flex; align-items:center; gap:13px; padding:15px 17px; border:1.5px solid var(--line-2); border-radius:14px; background:var(--paper); cursor:pointer; transition:.15s}
.opt:hover{border-color:var(--forest)}
.opt.on{border-color:var(--forest); background:var(--cream)}
.opt input{display:none}
.opt-ic{width:38px; height:38px; border-radius:11px; background:#fff; color:var(--forest); display:grid; place-items:center; flex:none; border:1px solid var(--line)}
.opt-tx{display:flex; flex-direction:column; line-height:1.3}
.opt-tx strong{font-family:var(--font-head); font-size:15px}
.opt-tx em{font-style:normal; font-size:12.5px; color:var(--muted)}
.opt-price{margin-left:auto; font-family:var(--font-head); font-weight:800; font-size:15px}
.addr{margin-top:16px}
.freshpick{display:flex; gap:11px; align-items:center; margin-top:16px; background:var(--cream); border-radius:12px; padding:13px 15px; color:var(--forest)}
.freshpick p{margin:0; font-size:13px; color:var(--ink-2)}
.cnote{margin-top:16px; display:flex; flex-direction:column; gap:6px}
.cnote label{font-size:13px; font-weight:700; color:var(--ink-2)}
.cnote textarea{resize:vertical}

.summary{position:sticky; top:92px}
.summary-card{background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px}
.summary-card h3{font-size:18px; margin-bottom:16px}
.sum-items{display:flex; flex-direction:column; gap:13px; padding-bottom:16px; border-bottom:1px solid var(--line)}
.sum-it{display:flex; align-items:center; gap:12px}
.sum-img{width:46px; height:46px; border-radius:10px; position:relative; overflow:hidden; flex:none}
.sum-img b{position:absolute; top:-6px; right:-6px; background:var(--ink); color:#fff; font-size:11px; font-weight:800; width:19px; height:19px; border-radius:999px; display:grid; place-items:center; font-family:var(--font-body); box-shadow:0 0 0 2px #fff}
.sum-tx{flex:1; display:flex; flex-direction:column}
.sum-tx strong{font-size:13.5px; font-family:var(--font-head)}
.sum-tx em{font-style:normal; font-size:12px; color:var(--muted)}
.sum-pr{font-family:var(--font-head); font-weight:800; font-size:14px}
.sum-rows{display:flex; flex-direction:column; gap:9px; padding:16px 0; border-bottom:1px solid var(--line); font-size:14px; color:var(--ink-2)}
.sum-rows div{display:flex; justify-content:space-between}
.sum-total{display:flex; justify-content:space-between; align-items:baseline; padding:16px 0 18px}
.sum-total strong{font-family:var(--font-head); font-size:26px}
.sum-secure{display:flex; align-items:center; justify-content:center; gap:7px; font-size:12.5px; color:var(--muted); margin:14px 0 0}
.sum-badges{list-style:none; margin:16px 0 0; padding:14px 0 0; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:8px}
.sum-badges li{display:flex; align-items:center; gap:6px; font-size:11.5px; font-weight:600; color:var(--ink-2)}
.sum-badges svg{color:var(--moss); width:16px; height:16px}

/* ---------- confirmation ---------- */
.confirm{padding:48px 0 60px; display:flex; justify-content:center}
.confirm-card{width:min(620px,100% - 48px); background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:44px 40px; text-align:center}
.confirm-check{width:66px; height:66px; border-radius:999px; background:var(--moss); color:#fff; display:grid; place-items:center; margin:0 auto 22px}
.confirm-check svg{width:34px; height:34px}
.confirm-card h1{font-size:32px}
.confirm-lead{color:var(--ink-2); font-size:16px; margin:12px 0 28px}
.confirm-steps{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:28px}
.confirm-steps div{background:var(--cream); border-radius:14px; padding:16px 12px; display:flex; flex-direction:column; align-items:center; gap:5px}
.cs-ic{width:36px; height:36px; border-radius:999px; background:#fff; color:var(--forest); display:grid; place-items:center; margin-bottom:3px}
.confirm-steps strong{font-family:var(--font-head); font-size:14px}
.confirm-steps em{font-style:normal; font-size:12px; color:var(--muted)}
.confirm-info{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; text-align:left; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:20px 0; margin-bottom:22px}
.confirm-info h4{font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); margin-bottom:6px}
.confirm-info p{margin:0; font-size:14px; font-weight:600}
.confirm-meta{font-size:13.5px; color:var(--muted); margin-bottom:22px}
.confirm-meta a{color:var(--forest); font-weight:700}

/* ---------- footer ---------- */
.ft{background:var(--taupe); color:#F4EFE4; margin-top:auto}
.ft-in{width:min(1240px,100% - 48px); margin-inline:auto; padding:54px 0 34px; display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:34px}
.ft-brand .brand{margin-bottom:16px}
.ft-brand .brand-name{color:#fff}
.ft-brand .brand-crest{background:var(--yellow)}
.ft-brand p{font-size:14px; color:#EBE3D4; max-width:34ch}
.ft-social{display:flex; gap:10px; margin-top:18px}
.ft-social a{width:40px; height:40px; border-radius:999px; background:rgba(255,255,255,.14); display:grid; place-items:center; font-weight:800; transition:.15s}
.ft-social a:hover{background:#fff; color:var(--taupe)}
.ft-col h4{font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:#fff; margin-bottom:14px}
.ft-col a,.ft-col p{display:block; font-size:14px; color:#EBE3D4; margin-bottom:9px}
.ft-col a:hover{color:#fff}
.ft-contact a{font-weight:700}
.ft-bot{border-top:1px solid rgba(255,255,255,.18)}
.ft-bot{width:min(1240px,100% - 48px); margin:0 auto; padding:18px 0; display:flex; justify-content:space-between; font-size:13px; color:#E4DBCB}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .hd-nav{display:none}
  .pdp-top{grid-template-columns:1fr; gap:28px}
  .pdp-gallery{position:static}
  .checkout-grid{grid-template-columns:1fr}
  .summary{position:static}
  .wholesale-in{grid-template-columns:1fr}
  .pdp-farm{grid-template-columns:1fr}
  .ft-in{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .grid-image,.grid-info{grid-template-columns:1fr}
  .card-info{flex-direction:column}
  .card-info .card-media{width:100%}
  .trustbar{grid-template-columns:1fr 1fr}
  .shop-body.with-side{grid-template-columns:1fr}
  .shop-side{position:static}
  .sensors-row{grid-template-columns:1fr 1fr}
  .confirm-steps,.confirm-info{grid-template-columns:1fr}
  .ft-in{grid-template-columns:1fr}
  .ft-bot{flex-direction:column; gap:6px}
  .freshband{flex-wrap:wrap}
  .freshband-tag{margin-left:0}
}
