/* =========================================================
   VinnyDarcek.sk – Premium dizajnový systém
   Burgundy / Cream / Gold · serif display + sans UI · mobile-first
   ========================================================= */

/* Atribút [hidden] musí vždy skryť prvok aj pri display:flex/grid komponentoch */
[hidden]{display:none!important}

:root{
  --burgundy:#5E1B23;
  --burgundy-deep:#46141A;
  --cream:#F8F4EE;
  --cream-2:#F2EBE0;
  --gold:#D4AF37;
  --gold-soft:#E7D49B;
  --dark:#1E1E1E;
  --ink:#2A2422;
  --muted:#7A726C;
  --line:#E5DCCF;
  --white:#fff;
  --ok:#2f7d4f;
  --warn:#b54708;
  --shadow-sm:0 1px 2px rgba(40,20,15,.06), 0 2px 8px rgba(40,20,15,.05);
  --shadow:0 10px 30px rgba(70,20,26,.10);
  --shadow-lg:0 24px 60px rgba(70,20,26,.16);
  --radius:16px;
  --radius-lg:22px;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --script:"Dancing Script", cursive;
  --wrap:1180px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 20px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--burgundy-deep);margin:0 0 .4em}
h1{font-size:clamp(2.1rem,6vw,3.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.7rem,4vw,2.6rem)}
h3{font-size:1.35rem}
p{margin:0 0 1em}
.muted{color:var(--muted)}
.small{font-size:.86rem}
.center{text-align:center}
.eyebrow{font-family:var(--sans);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;color:var(--gold);margin-bottom:.6rem;display:block}
section{position:relative}
.section{padding:72px 0}
.section-tight{padding:48px 0}

/* ---------- Buttons ---------- */
.btn-primary,.btn-ghost,.btn-gold,.btn-dark{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:600;font-size:.98rem;cursor:pointer;
  border-radius:999px;padding:.85em 1.5em;border:1.5px solid transparent;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s;
  text-align:center;line-height:1;
}
.btn-primary{background:var(--burgundy);color:#fff}
.btn-primary:hover{background:var(--burgundy-deep);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-gold{background:linear-gradient(135deg,var(--gold),#c39a2c);color:#3a2a06}
.btn-gold:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-dark{background:var(--dark);color:#fff}
.btn-dark:hover{transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--burgundy);border-color:var(--burgundy)}
.btn-ghost:hover{background:var(--burgundy);color:#fff}
.btn-ghost.light{color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost.light:hover{background:#fff;color:var(--burgundy)}
.btn-primary.small,.btn-ghost.small,.btn-gold.small{padding:.6em 1.1em;font-size:.85rem}
.btn-block{display:flex;width:100%}
.btn-primary[disabled]{opacity:.45;cursor:not-allowed}

/* ---------- Announce + Header ---------- */
.announce{background:var(--burgundy-deep);color:var(--gold-soft);text-align:center;
  font-size:.82rem;padding:8px 16px;letter-spacing:.02em}
.site-header{position:sticky;top:0;z-index:60;background:rgba(248,244,238,.92);
  backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:18px;height:68px}
.brand{display:flex;align-items:center}
.brand-logo-img{max-height:40px}
.brand-mark{font-family:var(--serif);font-size:1.6rem;font-weight:700;color:var(--burgundy);letter-spacing:.01em}
.brand-mark em{font-style:normal;color:var(--gold);font-weight:600}
.brand-mark.light{color:#fff}.brand-mark.light em{color:var(--gold)}
.main-nav{display:flex;gap:26px;margin-left:8px;flex:1}
.main-nav a{font-size:.92rem;font-weight:500;color:var(--ink);padding:6px 0;position:relative}
.main-nav a:hover,.main-nav a.is-active{color:var(--burgundy)}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--gold);transition:width .2s}
.main-nav a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:14px;margin-left:auto}
.cart-link{position:relative;color:var(--burgundy);display:flex}
.cart-badge{position:absolute;top:-8px;right:-9px;background:var(--gold);color:#3a2a06;
  font-size:.68rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;padding:0 4px}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:var(--burgundy);border-radius:2px;transition:.25s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-overlay{position:fixed;inset:0;background:rgba(30,20,18,.45);z-index:55;opacity:0;visibility:hidden;transition:.25s}
.nav-overlay.open{opacity:1;visibility:visible}

/* ---------- Hero ---------- */
.hero{background:
   radial-gradient(120% 90% at 80% -10%, rgba(212,175,55,.18), transparent 55%),
   linear-gradient(180deg,#fbf8f2, #f4ecdf);
   overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  padding:64px 0 56px}
.hero-copy h1{margin-bottom:.3em}
.hero-copy .lead{font-size:1.16rem;color:var(--ink);max-width:34ch;margin-bottom:1.6em}
.hero-script{font-family:var(--script);color:var(--gold);font-size:1.8rem;display:block;margin-bottom:.2em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);padding:22px;transform:rotate(-1.5deg)}
.hero-bottle{aspect-ratio:3/4;border-radius:14px;background:
   linear-gradient(160deg,#6a1f29,#3c1116);display:flex;align-items:center;justify-content:center;
   position:relative;overflow:hidden}
.hero-label{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:62%;background:var(--cream);border:1px solid var(--gold-soft);border-radius:8px;
  padding:18px 14px;text-align:center;box-shadow:0 6px 18px rgba(0,0,0,.25)}
.hero-label .ll-eyebrow{font-size:.6rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase}
.hero-label .ll-name{font-family:var(--script);font-size:1.7rem;color:var(--burgundy);line-height:1}
.hero-label .ll-date{font-size:.7rem;color:var(--muted);margin-top:4px}
.hero-trust{display:flex;gap:18px;margin-top:22px;font-size:.82rem;color:var(--muted);flex-wrap:wrap}
.hero-trust b{color:var(--burgundy)}
.stars{color:var(--gold);letter-spacing:1px}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 24px;text-align:center;box-shadow:var(--shadow-sm)}
.step .num{width:46px;height:46px;border-radius:50%;background:var(--cream-2);color:var(--burgundy);
  font-family:var(--serif);font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;border:1px solid var(--gold-soft)}

/* ---------- Occasions ---------- */
.occasions{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.occasion{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 18px;text-align:center;transition:.2s;box-shadow:var(--shadow-sm)}
.occasion:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.occasion .emoji{font-size:1.7rem;display:block;margin-bottom:8px}
.occasion strong{font-family:var(--serif);font-size:1.12rem;color:var(--burgundy-deep);font-weight:600}

/* ---------- Product cards / grid ---------- */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:.2s}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pcard .pcard-img{aspect-ratio:4/5;background:var(--cream-2);position:relative;overflow:hidden}
.pcard .pcard-img img{width:100%;height:100%;object-fit:cover}
.pcard .badge{position:absolute;top:12px;left:12px;background:var(--gold);color:#3a2a06;
  font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.pcard .pcard-body{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:1.12rem;margin-bottom:.2em}
.pcard .pcard-sub{font-size:.84rem;color:var(--muted);margin-bottom:.7em;flex:1}
.pcard .price{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}
.pcard .price .now{font-weight:700;color:var(--burgundy);font-size:1.15rem}
.pcard .price .was{color:var(--muted);text-decoration:line-through;font-size:.9rem}
.pcard .pcard-rate{font-size:.78rem;color:var(--muted);margin-bottom:.4em}

/* ---------- Sections / bands ---------- */
.band-burgundy{background:linear-gradient(160deg,var(--burgundy),var(--burgundy-deep));color:#fff}
.band-burgundy h2,.band-burgundy h3{color:#fff}
.band-burgundy .eyebrow{color:var(--gold-soft)}
.band-cream{background:var(--cream-2)}

/* personalization teaser */
.teaser-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.chip-row{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 26px}
.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  padding:8px 14px;border-radius:999px;font-size:.85rem}
.band-cream .chip{background:#fff;border-color:var(--line);color:var(--ink)}

/* unboxing */
.unbox-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.unbox{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow-sm)}
.unbox .ic{font-size:1.6rem;margin-bottom:10px}

/* reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.review .stars{margin-bottom:10px}
.review .who{margin-top:14px;font-weight:600;color:var(--burgundy)}
.review .occ{font-size:.8rem;color:var(--muted)}

/* B2B teaser */
.b2b-teaser{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:0 20px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:600;padding:18px 0;list-style:none;color:var(--burgundy-deep);
  display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--gold)}
.faq details[open] summary::after{content:"–"}
.faq details p{padding-bottom:18px;margin:0;color:var(--ink)}

/* section head */
.section-head{text-align:center;max-width:640px;margin:0 auto 40px}
.section-head p{color:var(--muted)}

/* ---------- Breadcrumb ---------- */
.crumbs{font-size:.82rem;color:var(--muted);padding:18px 0}
.crumbs a:hover{color:var(--burgundy)}

/* ---------- Category page ---------- */
.cat-intro{padding:40px 0 10px}
.cat-tools{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:18px 0 28px}
.cat-tools select{padding:.6em 1em;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit}
.filter-chips{display:flex;gap:8px;flex-wrap:wrap}
.filter-chips button{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.45em 1em;cursor:pointer;font-size:.85rem}
.filter-chips button.active{background:var(--burgundy);color:#fff;border-color:var(--burgundy)}
.related-cats{display:flex;gap:10px;flex-wrap:wrap}
.related-cats a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5em 1.1em;font-size:.86rem}
.related-cats a:hover{border-color:var(--gold)}

/* ---------- Product detail ---------- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:24px 0 60px}
.pd-gallery .main-img{aspect-ratio:1/1;background:var(--cream-2);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line)}
.pd-gallery .main-img img{width:100%;height:100%;object-fit:cover}
.pd-thumbs{display:flex;gap:10px;margin-top:12px}
.pd-thumbs img{width:74px;height:74px;object-fit:cover;border-radius:10px;border:1px solid var(--line);cursor:pointer}
.pd-thumbs img.active{border-color:var(--gold);border-width:2px}
.pd-info h1{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:.15em}
.pd-rate{color:var(--muted);font-size:.88rem;margin-bottom:14px}
.pd-price{display:flex;align-items:baseline;gap:12px;margin:14px 0}
.pd-price .now{font-size:2rem;font-weight:700;color:var(--burgundy);font-family:var(--serif)}
.pd-price .was{text-decoration:line-through;color:var(--muted)}
.pd-lead{font-size:1.05rem;color:var(--ink);margin-bottom:20px}
.opt-group{margin:18px 0}
.opt-group > label{font-weight:600;display:block;margin-bottom:8px;font-size:.92rem}
.opt-pills{display:flex;gap:10px;flex-wrap:wrap}
.opt-pills label{border:1.5px solid var(--line);border-radius:12px;padding:.6em 1em;cursor:pointer;font-size:.9rem;background:#fff;transition:.15s}
.opt-pills input{position:absolute;opacity:0}
.opt-pills label:has(input:checked){border-color:var(--burgundy);background:#fbf3f1;color:var(--burgundy)}
.qty-row{display:flex;align-items:center;gap:14px;margin:20px 0}
.qty-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:12px;overflow:hidden}
.qty-stepper button{width:42px;height:44px;border:0;background:#fff;font-size:1.2rem;cursor:pointer;color:var(--burgundy)}
.qty-stepper input{width:48px;height:44px;border:0;text-align:center;font-size:1rem;font-family:inherit}
.pd-cta{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 18px}
.pd-cta .btn-primary,.pd-cta .btn-gold{flex:1;min-width:200px}
.pd-trust{display:flex;gap:18px;flex-wrap:wrap;font-size:.84rem;color:var(--muted);padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:14px 0}
.pd-tabs{margin-top:40px}
.pd-section{padding:26px 0;border-top:1px solid var(--line)}
.param-table{width:100%;border-collapse:collapse}
.param-table td{padding:9px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.param-table td:first-child{color:var(--muted);width:42%}
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;background:#fff;border-top:1px solid var(--line);
  box-shadow:0 -8px 24px rgba(0,0,0,.08);padding:10px 14px calc(10px + env(safe-area-inset-bottom));display:none;flex-direction:column;gap:8px}
.sticky-cta .sc-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.sticky-cta .sc-price{font-weight:700;color:var(--burgundy);font-size:1.2rem;font-family:var(--serif)}
.sticky-cta .sc-actions{display:flex;flex-direction:column;gap:8px}
.sticky-cta .sc-actions .btn-gold,.sticky-cta .sc-actions .btn-primary,.sticky-cta .sc-actions .btn-ghost{width:100%;justify-content:center}

/* ---------- Editor ---------- */
.editor-wrap{display:grid;grid-template-columns:1fr 380px;gap:30px;padding:24px 0 90px}
.canvas-stage{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:24px;display:flex;align-items:center;justify-content:center;min-height:480px}
.bottle-mock{position:relative;width:280px;aspect-ratio:3/4;border-radius:16px;
  background:linear-gradient(160deg,#6a1f29,#3c1116);box-shadow:inset 0 0 40px rgba(0,0,0,.4)}
.label-area{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:74%;aspect-ratio:3/4;background:var(--cream);border:1px solid var(--gold-soft);border-radius:8px;
  overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.3)}
#labelCanvas{display:block;width:100%;height:100%;touch-action:none}
.editor-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);align-self:start}
.editor-panel h3{font-size:1.1rem}
.tmpl-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}
.tmpl-row button{border:1.5px solid var(--line);border-radius:10px;padding:8px 4px;background:#fff;cursor:pointer;font-size:.72rem}
.tmpl-row button.active{border-color:var(--burgundy);background:#fbf3f1}
.field{margin-bottom:14px}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px;color:var(--ink)}
.field input[type=text],.field textarea,.field select{width:100%;padding:.6em .75em;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.92rem;background:#fff}
.field textarea{resize:vertical;min-height:64px}
.swatches{display:flex;gap:8px}
.swatches button{width:30px;height:30px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer}
.swatches button.active{box-shadow:0 0 0 2px var(--burgundy)}
.font-row{display:flex;gap:8px;flex-wrap:wrap}
.font-row button{border:1.5px solid var(--line);border-radius:10px;padding:.4em .8em;background:#fff;cursor:pointer;font-size:.85rem}
.font-row button.active{border-color:var(--burgundy);background:#fbf3f1}
.uploader{border:1.5px dashed var(--line);border-radius:10px;padding:14px;text-align:center;font-size:.84rem;color:var(--muted);cursor:pointer}
.confirm-box{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;background:var(--cream-2);border-radius:10px;padding:12px;margin:14px 0}

/* ---------- Cart ---------- */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:30px;padding:24px 0 60px}
.cart-item{display:grid;grid-template-columns:90px 1fr auto;gap:16px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.cart-item .ci-img{width:90px;height:110px;object-fit:cover;border-radius:10px;background:var(--cream-2)}
.cart-item .ci-meta{font-size:.84rem;color:var(--muted)}
.cart-item .ci-meta span{display:inline-block;margin-right:10px}
.ci-actions{display:flex;gap:14px;font-size:.82rem;margin-top:8px}
.ci-actions a{color:var(--burgundy);cursor:pointer;border-bottom:1px solid transparent}
.ci-actions a:hover{border-color:var(--burgundy)}
.summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);align-self:start;position:sticky;top:88px}
.sum-row{display:flex;justify-content:space-between;padding:7px 0;font-size:.95rem}
.sum-row.total{border-top:1px solid var(--line);margin-top:8px;padding-top:14px;font-size:1.2rem;font-weight:700;color:var(--burgundy)}
.coupon-row{display:flex;gap:8px;margin:14px 0}
.coupon-row input{flex:1;padding:.6em .7em;border:1px solid var(--line);border-radius:10px}
.upsell-list{margin:16px 0}
.upsell{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.upsell:last-child{border-bottom:0}
.upsell .up-price{margin-left:auto;font-weight:600;color:var(--burgundy)}
.empty-state{text-align:center;padding:80px 20px}
.empty-state .emoji{font-size:3rem}

/* ---------- Checkout ---------- */
.checkout-layout{display:grid;grid-template-columns:1fr 360px;gap:30px;padding:24px 0 60px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.form-card h3{font-size:1.2rem;margin-bottom:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-full{grid-column:1/-1}
input[type=text],input[type=email],input[type=tel],input[type=number],input[type=password],textarea,select{
  width:100%;padding:.7em .85em;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fff}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--burgundy);box-shadow:0 0 0 3px rgba(94,27,35,.1)}
label.flabel{font-size:.82rem;font-weight:600;display:block;margin-bottom:5px}
.radio-card{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:12px;padding:.85em 1em;margin-bottom:10px;cursor:pointer}
.radio-card:has(input:checked){border-color:var(--burgundy);background:#fbf3f1}
.radio-card .rc-price{margin-left:auto;font-weight:600}
.check-row{display:flex;gap:10px;align-items:flex-start;margin:10px 0;font-size:.88rem}
.check-row input{margin-top:3px}
.err{color:#b42318;font-size:.85rem;margin-top:6px}

/* ---------- Misc ---------- */
.footer-trust{background:#fff;border-top:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:34px 0}
.trust-grid strong{display:block;color:var(--burgundy);font-family:var(--serif);font-size:1.05rem}
.trust-grid span{font-size:.84rem;color:var(--muted)}
.site-footer{background:var(--burgundy-deep);color:#e9ddd0;padding:54px 0 20px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
.footer-grid h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.footer-grid a{display:block;color:#d8c7b8;font-size:.9rem;padding:5px 0}
.footer-grid a:hover{color:var(--gold)}
.footer-brand p{font-size:.92rem;color:#cdbcae}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;align-items:center}
.alcohol-notice{font-size:.82rem;color:var(--gold-soft);margin:0}

.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:80;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow-lg);padding:18px 20px;display:flex;gap:18px;align-items:center;flex-wrap:wrap;max-width:760px;margin:0 auto}
.cookie-banner p{margin:0;font-size:.88rem;flex:1;min-width:240px}
.cookie-actions{display:flex;gap:10px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--dark);color:#fff;padding:.8em 1.3em;border-radius:999px;z-index:120;opacity:0;
  transition:.3s;font-size:.9rem;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.notice{background:#fbf3f1;border:1px solid var(--gold-soft);border-radius:12px;padding:14px 16px;font-size:.9rem;margin:14px 0}
.tag{display:inline-block;background:var(--cream-2);border-radius:999px;padding:.2em .7em;font-size:.74rem;font-weight:600;color:var(--burgundy)}

/* price tier table (B2B) */
.tier-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.tier-table th,.tier-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
.tier-table th{background:var(--burgundy);color:#fff;font-family:var(--sans);font-size:.85rem;letter-spacing:.04em}
.tier-table tr:last-child td{border-bottom:0}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s}
.bcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.bcard .bimg{aspect-ratio:16/9;background:linear-gradient(135deg,#6a1f29,#3c1116)}
.bcard .bbody{padding:18px}
.bcard h3{font-size:1.15rem}
.article{max-width:760px;margin:0 auto;padding:30px 0 60px}
.article p{font-size:1.06rem}
.article h2{margin-top:1.4em}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-inner,.teaser-grid,.b2b-teaser,.pd,.editor-wrap,.cart-layout,.checkout-layout{grid-template-columns:1fr}
  .occasions,.unbox-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid,.reviews-grid,.blog-grid,.steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr 1fr}
  .summary{position:static}
  .editor-wrap{padding-bottom:30px}
}
@media (max-width:760px){
  .main-nav{position:fixed;top:0;left:0;bottom:0;width:78%;max-width:320px;background:var(--cream);
    flex-direction:column;gap:0;padding:80px 24px 24px;transform:translateX(-105%);transition:.28s;z-index:58;box-shadow:var(--shadow-lg)}
  .main-nav.open{transform:translateX(0)}
  .main-nav a{padding:14px 0;border-bottom:1px solid var(--line);width:100%}
  .hamburger{display:flex}
  .btn-create{display:none}
  .steps{grid-template-columns:1fr}
  .section{padding:48px 0}
  .footer-grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .sticky-cta{display:flex}
  .pd{padding-bottom:90px}
  body{padding-bottom:0}
}
@media (max-width:480px){
  .occasions,.product-grid,.reviews-grid,.blog-grid,.unbox-grid,.trust-grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
  .hero-cta .btn-primary,.hero-cta .btn-ghost{width:100%}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--gold);outline-offset:2px}

/* =========================================================
 *  SUPPLEMENTARY – stránky (home, kategória, produkt, košík,
 *  checkout, ďakujeme, editor, blog, B2B). Pridané pre v11+.
 * ========================================================= */

/* Sekcie / nadpisy */
.how,.bestsellers,.occasions-section,.unboxing,.reviews-band,.pers-teaser,.faq{padding:72px 0}
.section-title{font-family:var(--serif);font-size:clamp(1.7rem,4vw,2.4rem);text-align:center;margin-bottom:.2em}
.section-title.left{text-align:left}
.section-sub{text-align:center;color:var(--muted);max-width:50ch;margin:0 auto 36px}
.lead{font-size:1.1rem;color:var(--ink);line-height:1.6}
.narrow{max-width:760px}
.small{font-size:.84rem}
.center{text-align:center}
.block{display:block;width:100%;text-align:center;margin-top:10px}

/* Hero doplnky */
.hero-points{list-style:none;display:flex;gap:18px;flex-wrap:wrap;margin-top:22px;font-size:.86rem;color:var(--muted)}
.hero-points li{white-space:nowrap}
.hero-bottle{width:100%;max-width:360px;display:block;margin:0 auto}

/* Ako to funguje */
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.how-step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px;text-align:center;box-shadow:var(--shadow-sm)}
.how-num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--burgundy);color:#fff;font-family:var(--serif);font-size:1.2rem;margin-bottom:14px}
.how-step h3{margin-bottom:.3em}
.how-step p{color:var(--muted);font-size:.92rem}

/* Príležitosti */
.occasion-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.occasion-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-align:center;transition:.18s}
.occasion-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.occasion-card img{width:100%;aspect-ratio:1/1;object-fit:cover;background:var(--cream-2)}
.occasion-card span{display:block;padding:12px 8px;font-weight:600;color:var(--burgundy-deep);font-size:.92rem}

/* Personalizačný teaser */
.pers-teaser{background:var(--cream-2)}
.pers-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.pers-visual img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.check-list{list-style:none;margin:16px 0 22px}
.check-list li{padding-left:26px;position:relative;margin-bottom:8px;color:var(--ink)}
.check-list li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}

/* Unboxing */
.unbox-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.unbox-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.unbox-card h3{font-size:1.1rem;margin-bottom:.4em}
.unbox-card p{color:var(--muted);font-size:.9rem}

/* Recenzie */
.reviews-band{background:var(--burgundy);}
.reviews-band .section-title{color:#fff}
.review-card{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.review-card .stars{color:var(--gold);margin-bottom:10px}
.review-card blockquote{margin:0 0 12px;font-size:.96rem;line-height:1.55;color:var(--ink)}
.review-card figcaption{font-weight:600;color:var(--burgundy);font-size:.88rem}

/* B2B teaser inner */
.b2b-inner{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.b2b-visual img{width:100%;max-width:340px;display:block;margin:0 auto}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 18px;margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:600;padding:14px 0;color:var(--burgundy-deep);list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold);font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"−"}
.faq details p{padding-bottom:14px;color:var(--muted);margin:0}

/* Kategória */
.cat-head{padding:18px 0 0}
.cat-head h1{font-size:clamp(1.8rem,4vw,2.6rem)}
.cat-intro{color:var(--muted);max-width:70ch;margin-top:.4em}
.cat-tools{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.cat-count{color:var(--muted);font-size:.88rem}
.cat-sort label{font-size:.85rem;color:var(--muted)}
.cat-sort select{margin-left:6px}
.empty-note{color:var(--muted);padding:30px 0}
.related-cats{padding-top:0}
.related-row{display:flex;gap:10px;flex-wrap:wrap}
.related-chip{border:1.5px solid var(--line);border-radius:30px;padding:.5em 1.1em;font-size:.88rem;color:var(--burgundy);transition:.15s}
.related-chip:hover{border-color:var(--burgundy);background:#fbf3f1}

/* Produkt doplnky */
.pill-badge{display:inline-block;background:var(--gold);color:#3a2a06;font-size:.72rem;font-weight:700;letter-spacing:.04em;padding:.3em .8em;border-radius:30px;margin-bottom:10px;text-transform:uppercase}
.pers-note{background:var(--cream-2);border:1px dashed var(--gold-soft);border-radius:10px;padding:.7em 1em;font-size:.88rem;color:var(--burgundy-deep);margin:6px 0}
.param-table{width:100%;border-collapse:collapse}
.param-table th,.param-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:.92rem}
.param-table th{width:40%;color:var(--muted);font-weight:600}

/* Košík */
.cart-empty{text-align:center;padding:50px 0;display:flex;flex-direction:column;align-items:center;gap:12px}
.ci-body h3{font-size:1.05rem;margin-bottom:.3em}
.ci-qty{margin-top:8px}
.ci-edit{display:inline-block;margin-top:8px;font-size:.82rem;color:var(--burgundy);text-decoration:underline}
.ci-side{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;text-align:right}
.ci-price{font-weight:700;color:var(--burgundy);font-size:1.05rem}
.ci-breakdown{font-size:.74rem}
.ci-remove{font-size:.8rem;color:var(--muted);text-decoration:underline}
.ci-remove:hover{color:#b42318}
.continue-link{display:inline-block;margin-top:18px}
.sum-row{display:flex;justify-content:space-between;font-size:.92rem;margin:8px 0;color:var(--ink)}
.sum-row.discount{color:#1a7f4b}
.sum-total{display:flex;justify-content:space-between;font-weight:700;font-size:1.2rem;color:var(--burgundy);border-top:1px solid var(--line);margin-top:12px;padding-top:12px}
.ship-hint{font-size:.82rem;color:var(--gold-deep,#9a7b1e);background:var(--cream-2);border-radius:8px;padding:8px 10px;margin:8px 0}
.upsell-title{font-weight:600;font-size:.9rem;margin-bottom:6px}

/* Checkout */
.checkout-main{min-width:0}
.alert-error{background:#fdecea;border:1px solid #f5c6c2;color:#9b2c22;border-radius:10px;padding:14px 16px;margin-bottom:18px}
.alert-error ul{margin:8px 0 0 18px}
.company-toggle summary{cursor:pointer;color:var(--burgundy);font-size:.88rem;font-weight:600;margin-top:6px}
.co-line{display:flex;justify-content:space-between;font-size:.88rem;margin:7px 0;gap:12px}
.co-line + hr{border:0;border-top:1px solid var(--line);margin:12px 0}

/* Ďakujeme */
.thankyou{text-align:center;max-width:620px}
.ty-check{width:64px;height:64px;border-radius:50%;background:#1a7f4b;color:#fff;font-size:2rem;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.ty-box,.ty-summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin:20px 0;text-align:left;box-shadow:var(--shadow-sm)}
.ty-note{background:var(--cream-2);border-radius:10px;padding:12px;font-size:.9rem}
.ty-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}

/* Editor doplnky */
.uploader:hover{border-color:var(--burgundy);color:var(--burgundy)}

/* Blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.18s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.blog-card .bc-body{padding:18px}
.blog-card .bc-cat{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:600}
.blog-card h3{font-size:1.15rem;margin:.3em 0}
.blog-card p{color:var(--muted);font-size:.9rem}
.article{max-width:760px;margin:0 auto;padding:10px 0 40px}
.article .meta{color:var(--muted);font-size:.85rem;margin-bottom:20px}
.article p{margin-bottom:1.1em;line-height:1.7}
.article h2{margin-top:1.4em;font-size:1.5rem}

/* B2B stránka */
.b2b-hero{background:var(--burgundy);color:#fff;padding:60px 0}
.b2b-hero h1{color:#fff;max-width:18ch}
.b2b-hero .lead{color:#f0e3d6}
.b2b-feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:10px 0}
.b2b-feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.b2b-feature h3{font-size:1.05rem;margin-bottom:.3em}
.b2b-feature p{color:var(--muted);font-size:.88rem}
.alert-success{background:#e8f6ee;border:1px solid #bfe3cd;color:#1a7f4b;border-radius:10px;padding:14px 16px;margin-bottom:18px}

/* Responsive supplementary */
@media(max-width:900px){
  .how-steps,.unbox-grid,.b2b-feature-grid{grid-template-columns:repeat(2,1fr)}
  .occasion-grid{grid-template-columns:repeat(3,1fr)}
  .pers-inner,.b2b-inner{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .how-steps,.unbox-grid,.b2b-feature-grid,.blog-grid{grid-template-columns:1fr}
  .occasion-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
  .cart-item{grid-template-columns:70px 1fr}
  .ci-side{grid-column:1/-1;flex-direction:row;align-items:center;justify-content:space-between}
  .hero-points{gap:10px}
}

/* =========================================================
 *  BOTTLE PREVIEW + LABEL LAYOUTS (YourSurprise-style v12)
 * ========================================================= */
.bottle-preview{position:relative;display:inline-block;max-width:100%;line-height:0;filter:drop-shadow(0 18px 30px rgba(0,0,0,.18))}
.bottle-preview .bp-bottle{width:100%;height:auto;display:block;user-select:none;-webkit-user-drag:none}
.bp-label{position:absolute;overflow:hidden;border-radius:5px;line-height:1.1;
  box-shadow:0 1px 3px rgba(0,0,0,.25), inset 0 0 0 1px rgba(212,175,55,.35);
  container-type:size;background:#F8F4EE}
.bp-label .lbl{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center}
.bp-label .lbl-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:7cqh 6cqw;box-sizing:border-box;gap:2.5cqh;overflow:hidden}
.lbl-eyebrow{font-size:8cqh;letter-spacing:.12em;text-transform:uppercase;opacity:.85;font-weight:600}
.lbl-name{font-size:20cqh;font-weight:700;line-height:1;word-break:break-word}
.lbl-date{font-size:9cqh;letter-spacing:.05em;opacity:.9}
.lbl-ded{font-size:8.5cqh;line-height:1.25;opacity:.92;max-height:40cqh;overflow:hidden}
.lbl-photo{width:62cqw;height:42cqh;border-radius:3px;overflow:hidden;flex:0 0 auto;background:#e9e2d6;display:flex;align-items:center;justify-content:center}
.lbl-photo img{width:100%;height:100%;object-fit:cover}
.lbl-photo-empty{border:1px dashed rgba(94,27,35,.4)}
.lbl-photo-empty span{font-size:8cqh;color:rgba(94,27,35,.6)}
.lbl-logo{max-width:55cqw;max-height:22cqh;flex:0 0 auto}
.lbl-logo img{max-width:100%;max-height:22cqh;object-fit:contain}

/* Accent rule under eyebrow */
.lbl-eyebrow::after{content:"";display:block;width:30cqw;height:1px;background:var(--lbl-accent,#5E1B23);opacity:.6;margin:2cqh auto 0}

/* Layout: frame (gold double border on dark) */
.lbl-frame .lbl-inner{border:1.5px solid var(--lbl-accent,#D4AF37);outline:1px solid var(--lbl-accent,#D4AF37);outline-offset:2.5cqw;margin:3cqw}
.lbl-frame .lbl-name{font-size:22cqh}

/* Layout: wedding */
.lbl-wedding .lbl-name{font-size:24cqh}
.lbl-wedding .lbl-eyebrow{font-size:7cqh;text-transform:none;letter-spacing:.04em;font-style:italic}

/* Layout: birthday */
.lbl-birthday .lbl-name{font-size:23cqh}
.lbl-birthday .lbl-date{font-weight:700;color:var(--lbl-accent)}

/* Layout: corporate */
.lbl-corporate .lbl-inner{justify-content:flex-start;padding-top:10cqh}
.lbl-corporate .lbl-name{font-size:13cqh;font-weight:600}
.lbl-corporate .lbl-ded{font-size:8cqh}

/* Layout: photo */
.lbl-photo-layout .lbl-inner,.lbl-photo .lbl-inner{justify-content:flex-start;gap:3cqh;padding-top:6cqh}
.lbl-photo .lbl-name{font-size:13cqh}

/* Make label text not overflow tiny previews */
.bottle-preview.bp-sm .bp-label{box-shadow:0 1px 2px rgba(0,0,0,.2), inset 0 0 0 1px rgba(212,175,55,.3)}

/* =========================================================
 *  FULLSCREEN EDITOR (mobile-first) v12
 * ========================================================= */
.ed-body{margin:0;background:var(--cream-2,#f1ece3);color:var(--ink);-webkit-font-smoothing:antialiased;overscroll-behavior:none}
.ed{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:560px;margin:0 auto;background:var(--cream,#F8F4EE);position:relative}
.ed-top{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.ed-top-title{flex:1;font-family:var(--serif);font-size:1rem;color:var(--burgundy-deep);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ed-top-actions{display:flex;align-items:center;gap:8px}
.ed-icon{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--burgundy);font-size:1.05rem;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;text-decoration:none;padding:0;flex:0 0 auto}
.ed-icon:hover{background:var(--cream-2)}
.ed-icon:disabled{opacity:.35;cursor:not-allowed}
.ed-continue{border:0;background:var(--burgundy);color:#fff;border-radius:30px;padding:.55em 1.1em;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap}

.ed-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;padding:18px 12px;min-height:46vh;
  background:radial-gradient(circle at 50% 38%, #fff 0%, var(--cream) 60%, var(--cream-2) 100%)}
.ed-sidetools{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:5}
.ed-preview-wrap{text-align:center}
.ed-preview-wrap .bottle-preview{width:clamp(180px,52vw,300px)}
.ed-hint{font-size:.8rem;color:var(--muted);margin-top:12px}

.ed-panel{background:#fff;border-top:1px solid var(--line);padding:16px 14px 8px;max-height:34vh;overflow-y:auto}
.ed-cards{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.ed-card{flex:0 0 auto;width:92px;border:2px solid var(--line);border-radius:12px;background:#fff;padding:6px;cursor:pointer;text-align:center}
.ed-card.active{border-color:var(--burgundy);box-shadow:0 0 0 3px rgba(94,27,35,.1)}
.ed-card-thumb{display:block;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:var(--cream-2)}
.ed-card-thumb img{width:100%;height:100%;object-fit:cover}
.ed-card-name{display:block;font-size:.72rem;margin-top:6px;color:var(--ink);line-height:1.2}

.ed-photo-zone{text-align:center}
.ed-uploader{display:flex;flex-direction:column;align-items:center;gap:8px;border:1.5px dashed var(--line);border-radius:14px;padding:22px;cursor:pointer;color:var(--burgundy);background:var(--cream-2)}
.ed-uploader:hover{border-color:var(--burgundy)}
.ed-up-ic{font-size:1.6rem}
.ed-photo-warn{color:#a4720d;font-size:.82rem;margin-top:10px}
.ed-photo-actions{margin-top:10px}
.ed-mini{font-size:.76rem;margin-top:8px}

.ed-field{margin-bottom:12px}
.ed-lbl{display:block;font-size:.8rem;font-weight:600;margin-bottom:5px;color:var(--ink)}
.ed-counter{float:right;color:var(--muted);font-weight:400;font-size:.72rem}
.ed-field input[type=text],.ed-field textarea{width:100%;padding:.6em .7em;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fff}
.ed-field textarea{min-height:64px;resize:vertical}
.ed-text-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}

.ed-style-group{margin-bottom:16px}
.ed-fonts{display:flex;gap:8px;flex-wrap:wrap}
.ed-fonts button{border:1.5px solid var(--line);border-radius:10px;padding:.5em 1em;background:#fff;cursor:pointer;font-size:.95rem}
.ed-fonts button.active{border-color:var(--burgundy);background:#fbf3f1}
.ed-swatches{display:flex;gap:10px}
.ed-swatches button{width:34px;height:34px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer}
.ed-swatches button.active{box-shadow:0 0 0 2px var(--burgundy)}
.ed-align{display:flex;gap:8px}
.ed-align button{flex:1;border:1.5px solid var(--line);border-radius:10px;padding:.5em;background:#fff;cursor:pointer;font-size:1rem}
.ed-align button.active{border-color:var(--burgundy);background:#fbf3f1}

.ed-tabs{display:flex;background:#fff;border-top:1px solid var(--line)}
.ed-tabs button{flex:1;border:0;background:none;padding:9px 4px;font-family:inherit;font-size:.72rem;color:var(--muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;border-top:2px solid transparent}
.ed-tabs button span{font-size:1.1rem;line-height:1}
.ed-tabs button.active{color:var(--burgundy);border-top-color:var(--burgundy);font-weight:600}

.ed-ctabar{display:flex;align-items:center;gap:12px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--line);position:sticky;bottom:0;z-index:20}
.ed-ctaprice{font-size:.82rem;color:var(--muted);flex:1}
.ed-ctabar .btn-primary{flex:0 0 auto;padding:.8em 1.6em}

.ed-modal{position:fixed;inset:0;background:rgba(30,16,18,.55);display:flex;align-items:flex-end;justify-content:center;z-index:60;padding:0}
.ed-modal-card{background:#fff;width:100%;max-width:560px;border-radius:18px 18px 0 0;padding:22px 18px calc(22px + env(safe-area-inset-bottom));max-height:92vh;overflow-y:auto}
.ed-modal-card h3{font-size:1.3rem;text-align:center;margin-bottom:14px}
.ed-modal-preview{display:flex;justify-content:center;margin-bottom:16px}
.ed-check{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;background:var(--cream-2);border-radius:10px;padding:12px;margin-bottom:8px}
.ed-modal-actions{display:flex;gap:10px;margin-top:8px}
.ed-modal-actions .btn-ghost,.ed-modal-actions .btn-primary{flex:1}

.ed-toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(16px);background:var(--dark);color:#fff;padding:.7em 1.2em;border-radius:30px;font-size:.85rem;opacity:0;pointer-events:none;transition:.25s;z-index:70}
.ed-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(min-width:561px){
  .ed{box-shadow:0 0 60px rgba(0,0,0,.12);min-height:100vh}
  .ed-stage{min-height:50vh}
}

/* =========================================================
 *  v12 UPGRADE – produkt mockup, košík, enclosed checkout
 * ========================================================= */

/* Produkt – reálna fľaša + strip šablón */
.pd-bottle-hero{display:flex;justify-content:center;padding:10px 0 6px}
.bp-product{width:min(340px,82vw)!important}
.tpl-strip{margin-top:18px}
.tpl-strip-label{font-size:.84rem;color:var(--muted);margin-bottom:10px;text-align:center}
.tpl-strip-row{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.tpl-chip{flex:0 0 auto;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:6px;width:96px;text-align:center}
.tpl-chip .bottle-preview{transition:transform .15s;border-radius:8px}
.tpl-chip:hover .bottle-preview{transform:translateY(-3px)}
.tpl-chip span{font-size:.74rem;color:var(--burgundy-deep);line-height:1.2}

/* Košík – preview + odkazy */
.ci-preview{display:flex;align-items:flex-start;justify-content:center}
.ci-preview .bottle-preview{width:92px!important}
.cart-item .ci-img{width:90px;height:auto;border-radius:8px}
.ci-delivery{font-size:.8rem;color:var(--muted);margin:6px 0}
.ci-pers{color:var(--gold-deep,#9a7b1e);font-weight:600}
.ci-links{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.ci-edit{font-size:.82rem;color:var(--burgundy);text-decoration:underline}
.ci-edit.alt{color:var(--muted);text-decoration:none}
.ci-edit.alt:hover{color:var(--burgundy);text-decoration:underline}
.upsell{cursor:pointer;border-radius:10px;padding:10px 8px}
.upsell.on{background:#f6efe6}
.upsell .up-name{flex:1}
.upsell.on .up-price{color:#1a7f4b}

/* ---------- ENCLOSED CHECKOUT ---------- */
.ck-body{background:var(--cream-2);min-height:100vh}
.ck-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:#fff;border-bottom:1px solid var(--line);padding:14px 22px}
.ck-brand{font-family:var(--serif);font-size:1.3rem;color:var(--burgundy-deep)}
.ck-brand em{color:var(--gold);font-style:normal}
.ck-secure{font-size:.82rem;color:var(--muted)}
.ck-back{font-size:.85rem;color:var(--burgundy)}
.ck-wrap{max-width:1080px;margin:0 auto;padding:24px 20px 60px}
.ck-steps{display:flex;gap:8px;list-style:none;padding:0;margin:0 0 24px;counter-reset:s}
.ck-steps li{flex:1;display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--muted);
  padding:10px 12px;border-radius:12px;background:#fff;border:1px solid var(--line);cursor:default}
.ck-steps li span{width:24px;height:24px;border-radius:50%;background:var(--cream-2);color:var(--muted);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex:0 0 auto}
.ck-steps li.active{color:var(--burgundy-deep);border-color:var(--burgundy);background:#fff;cursor:pointer}
.ck-steps li.active span{background:var(--burgundy);color:#fff}
.ck-steps li.done{cursor:pointer;color:var(--burgundy)}
.ck-steps li.done span{background:var(--gold);color:#3a2a06}
.ck-grid{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
.ck-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm)}
.ck-h{font-size:1.45rem;margin-bottom:18px}
.ck-toggle{display:flex;gap:10px;margin:0 0 16px}
.ck-toggle-opt{flex:1;position:relative}
.ck-toggle-opt input{position:absolute;opacity:0}
.ck-toggle-opt span{display:block;text-align:center;padding:.7em 1em;border:1.5px solid var(--line);border-radius:12px;cursor:pointer;font-size:.9rem;font-weight:500}
.ck-toggle-opt input:checked + span{border-color:var(--burgundy);background:#fbf3f1;color:var(--burgundy);font-weight:600}
.ck-company{margin-bottom:6px}
.ck-est{font-size:.86rem;color:var(--burgundy-deep);background:#f6efe6;border-radius:10px;padding:8px 12px;margin-bottom:12px}
.ck-pickup-note{font-size:.86rem;color:var(--muted);background:var(--cream-2);border-radius:10px;padding:12px}
.ck-giftbox{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.ck-discount{margin-bottom:14px}
.ck-discount summary{cursor:pointer;color:var(--burgundy);font-weight:600;font-size:.9rem}
.ck-pay{margin:6px 0 14px}
.radio-card.disabled{opacity:.6;cursor:not-allowed;background:var(--cream-2)}
.rc-soon{margin-left:auto;font-size:.74rem;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:20px;padding:.15em .7em}
.ck-confirms{margin:12px 0}
.ck-nav{display:flex;gap:12px;justify-content:space-between;margin-top:22px}
.ck-nav .ck-next,.ck-nav button[type=submit]{margin-left:auto}
.inp-err{border-color:#d9534f!important;box-shadow:0 0 0 3px rgba(217,83,79,.12)!important}

.ck-summary{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm);position:sticky;top:88px}
.ck-summary h2{font-size:1.2rem;margin-bottom:14px}
.ck-sum-items{margin-bottom:14px}
.ck-sum-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}
.ck-sum-thumb{flex:0 0 auto;width:56px;display:flex;justify-content:center}
.ck-sum-thumb .bottle-preview{width:56px!important;filter:none}
.ck-sum-info{flex:1;font-size:.85rem;line-height:1.3}
.ck-sum-q{color:var(--muted);font-weight:600}
.ck-sum-price{font-weight:600;color:var(--burgundy);font-size:.88rem}
.ck-foot{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:30px;padding-top:20px;border-top:1px solid var(--line);font-size:.8rem}
.ck-foot a{color:var(--muted)}
.ck-foot a:hover{color:var(--burgundy)}

@media(max-width:860px){
  .ck-grid{grid-template-columns:1fr}
  .ck-summary{position:static;order:-1}
  .ck-steps li span{margin:0}
  .ck-steps li{font-size:0;padding:10px}
  .ck-steps li span{font-size:.8rem}
  .ck-steps li.active{font-size:.78rem}
}

/* ---------- Cookie modal + kategórie (v13) ---------- */
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
.cookie-modal{position:fixed;inset:0;z-index:90;background:rgba(30,16,18,.55);display:flex;align-items:flex-end;justify-content:center;padding:0}
.cookie-modal-card{background:#fff;width:100%;max-width:520px;border-radius:18px 18px 0 0;padding:22px 20px calc(22px + env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto;box-shadow:0 -10px 40px rgba(0,0,0,.25)}
.cookie-modal-card h3{font-size:1.3rem;margin-bottom:6px}
.cookie-cat{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.cookie-cat span{flex:1}
.cookie-cat input[type=checkbox]{width:22px;height:22px;accent-color:var(--burgundy);flex:0 0 auto}
.cookie-modal-actions{display:flex;gap:10px;margin-top:18px}
.cookie-modal-actions .btn-ghost,.cookie-modal-actions .btn-primary{flex:1}
@media(min-width:560px){
  .cookie-modal{align-items:center;padding:20px}
  .cookie-modal-card{border-radius:18px}
}
@media(max-width:560px){
  .cookie-banner{flex-direction:column;align-items:stretch;left:10px;right:10px;bottom:10px;padding:16px}
  .cookie-banner .cookie-actions{width:100%}
  .cookie-banner .cookie-actions button{flex:1}
}

/* ---------- Mobile product detail fixes (v13) ---------- */
@media(max-width:760px){
  html,body{overflow-x:hidden}
  .pd{display:block;padding:8px 0 30px}
  .pd .pd-bottle-hero{padding:6px 0 2px}
  .pd .bp-product{width:min(280px,70vw)!important}
  .pd-info{margin-top:10px}
  .pd-info h1{font-size:1.55rem;line-height:1.15}
  .pd-price .now{font-size:1.7rem}
  .pd-lead{font-size:.96rem}
  .crumbs{font-size:.72rem;padding:10px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  /* full-width touch-friendly option pills */
  .opt-pills label{padding:.7em 1em;font-size:.95rem}
  .pd-cta{flex-direction:column;gap:10px}
  .pd-cta .btn-gold,.pd-cta .btn-primary,.pd-cta .btn-ghost{width:100%;justify-content:center;padding:.95em 1em}
  /* template strip becomes edge-to-edge scroll */
  .tpl-strip-row{margin:0 -4px;padding:4px 4px 12px}
  /* leave room for sticky CTA (two stacked buttons) */
  .pd-tabs,.section{padding-left:0;padding-right:0}
  main.site-main{padding-bottom:150px}
  .pd-trust{gap:10px;font-size:.78rem}
}
@media(max-width:760px){
  .wrap{padding:0 16px}
}

/* ===== premium mobile product v13 ===== */
.pers-note.free{background:#fff8df;border:1px solid rgba(212,175,55,.55);color:#5E1B23;font-weight:800;border-radius:16px;padding:12px 14px;margin:14px 0;box-shadow:0 10px 28px rgba(94,27,35,.06)}
.pd-trust.premium{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:18px}.pd-trust.premium span{display:block;background:#fff;border:1px solid #eadfce;border-radius:16px;padding:13px 13px;box-shadow:0 8px 22px rgba(94,27,35,.05)}.pd-trust.premium b{display:block;color:#5E1B23;font-size:.9rem}.pd-trust.premium small{display:block;color:#766b60;font-size:.76rem;margin-top:3px;line-height:1.25}.btn-gold,.btn-primary{min-height:48px;border-radius:999px}.opt-pills label{border-radius:14px;min-height:42px;display:inline-flex;align-items:center}.tpl-strip-row{scroll-snap-type:x mandatory}.tpl-chip{scroll-snap-align:start}
@media(max-width:760px){.pd{display:block}.pd-gallery{margin:0 -16px 18px}.pd-bottle-hero{background:linear-gradient(180deg,#fbf8f1,#f0ebe3);padding:24px 8px}.pd-info{padding:0 0 120px}.pd h1{font-size:2.15rem;line-height:1.05}.pd-price .now{font-size:2.2rem}.pd-trust.premium{grid-template-columns:1fr}.tpl-strip{overflow:hidden}.tpl-strip-row{display:flex;overflow-x:auto;gap:12px;padding:0 8px 12px}.tpl-chip{min-width:112px}.sticky-cta{box-shadow:0 -14px 34px rgba(0,0,0,.13);border-top-left-radius:22px;border-top-right-radius:22px}.sticky-cta .sc-actions{gap:8px}.sticky-cta .btn-gold,.sticky-cta .btn-ghost,.sticky-cta .btn-primary{font-size:.86rem;padding:.72rem .8rem}}


/* ===== V4 HOTFIX: mobile menu + premium homepage + chat ===== */
@media(max-width:760px){
  .site-header{z-index:1000!important}.header-inner{height:64px!important}.brand-mark{font-size:1.35rem!important}.announce{font-size:.82rem;line-height:1.35;padding:10px 14px}
  .main-nav{display:flex!important;position:fixed!important;top:0!important;left:0!important;bottom:0!important;width:84vw!important;max-width:360px!important;background:#fffaf2!important;z-index:1002!important;transform:translateX(-105%)!important;transition:.24s ease!important;box-shadow:20px 0 55px rgba(0,0,0,.24)!important;padding:86px 22px 26px!important;gap:0!important;flex-direction:column!important;margin:0!important;border-right:1px solid var(--line)!important;overflow:auto!important;visibility:visible!important;opacity:1!important}
  .main-nav.open{transform:translateX(0)!important}.main-nav a{display:flex!important;align-items:center!important;min-height:50px!important;width:100%!important;padding:14px 4px!important;border-bottom:1px solid #eee3d6!important;background:transparent!important;color:#351519!important;font-size:1rem!important;line-height:1.2!important;position:relative!important;z-index:1!important}.main-nav a:after{display:none!important}
  .nav-overlay.open{z-index:1001!important}.hamburger{display:flex!important;z-index:1003!important}.header-actions{margin-left:auto!important}.hero-inner{padding:38px 0 34px!important;gap:20px!important}.hero-copy h1{font-size:2.65rem!important;line-height:.92!important}.hero-copy .lead{font-size:1.02rem!important}.hero-points{padding-left:0;list-style:none;font-size:.95rem}.hero-visual{display:flex;justify-content:center}.hero-bottle{max-width:280px;margin:auto}.section-title{font-size:2rem!important}.occasion-grid{grid-template-columns:repeat(2,1fr)!important}.occasion-card{min-height:128px}.product-grid{grid-template-columns:1fr!important}.footer-trust .trust-grid{grid-template-columns:1fr!important}.cookie-banner{left:14px!important;right:14px!important;bottom:14px!important;width:auto!important}
}
.vd-chat{position:fixed;right:22px;bottom:22px;z-index:1100}.vd-chat-btn{border:0;border-radius:999px;background:var(--burgundy);color:#fff;padding:14px 22px;font-weight:800;font-size:1rem;box-shadow:0 14px 38px rgba(70,20,26,.28)}.vd-chat-box{position:absolute;right:0;bottom:62px;width:min(360px,calc(100vw - 28px));background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.22);overflow:hidden}.vd-chat-head{display:flex;justify-content:space-between;align-items:center;background:var(--burgundy);color:#fff;padding:13px 15px}.vd-chat-head button{background:transparent;border:0;color:#fff;font-size:1.5rem}.vd-chat-body{padding:14px}.vd-chat-body p{font-size:.9rem}.vd-chat-body button{display:block;width:100%;text-align:left;margin:7px 0;border:1px solid var(--line);background:#fbf7f1;border-radius:12px;padding:10px;color:var(--burgundy);font-weight:700}.vd-chat-form{display:flex;gap:6px;padding:12px;border-top:1px solid var(--line)}.vd-chat-form input{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px}.vd-chat-form button{border:0;border-radius:10px;background:var(--burgundy);color:#fff;padding:0 12px}.vd-chat-note{font-size:.75rem;color:var(--muted);padding:0 14px 14px;margin:0}.chat-msg{background:#f6efe6;border-radius:12px;padding:9px 10px;margin:8px 0;font-size:.88rem}.chat-msg.me{background:#5e1b23;color:#fff;margin-left:30px}.chat-msg.bot{margin-right:20px}
@media(max-width:760px){.vd-chat{right:14px;bottom:82px}.vd-chat-btn{padding:13px 18px}.vd-chat-box{right:-6px;bottom:58px}}
.ed-product-switch{padding:10px 14px;background:#fff;border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:center}.ed-product-switch label{font-size:.78rem;font-weight:800;color:var(--burgundy);text-transform:uppercase;letter-spacing:.05em}.ed-product-switch select{flex:1;border:1px solid var(--line);border-radius:12px;padding:9px;background:#fff;font-family:inherit}.ed-share-link{font-size:.8rem;background:#f6efe6;border:1px solid var(--line);border-radius:10px;padding:8px;margin-top:8px;word-break:break-all;color:var(--burgundy)}
.home-values{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}.home-value{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-sm)}.home-value b{display:block;color:var(--burgundy);margin-bottom:3px}.home-value span{font-size:.9rem;color:var(--muted)}@media(max-width:900px){.home-values{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.home-values{grid-template-columns:1fr}}


/* ===== V5 FINAL HOTFIX: real mobile drawer + clean homepage/editor cache ===== */
@media (max-width: 760px){
  body.nav-open{overflow:hidden!important;touch-action:none!important;}
  .site-header{position:sticky!important;top:0!important;z-index:3000!important;}
  .header-inner{position:relative!important;height:64px!important;}
  .hamburger{display:flex!important;position:relative!important;z-index:3205!important;width:44px!important;height:44px!important;align-items:center!important;justify-content:center!important;border-radius:999px!important;background:rgba(255,255,255,.72)!important;}
  .brand{position:relative!important;z-index:3201!important;min-width:0!important;}
  .brand-mark{font-size:1.38rem!important;white-space:nowrap!important;}
  .header-actions{margin-left:auto!important;position:relative!important;z-index:3201!important;}
  .btn-create{display:none!important;}

  #mainNav.main-nav{
    display:flex!important;flex:0 0 auto!important;flex-direction:column!important;gap:0!important;
    position:fixed!important;top:0!important;left:0!important;bottom:0!important;
    width:min(86vw,360px)!important;height:100dvh!important;max-height:100dvh!important;
    margin:0!important;padding:calc(88px + env(safe-area-inset-top)) 20px calc(22px + env(safe-area-inset-bottom))!important;
    background:linear-gradient(180deg,#fffaf3 0%,#f7efe5 100%)!important;border-right:1px solid #e8dccb!important;
    box-shadow:24px 0 70px rgba(22,12,10,.34)!important;transform:translate3d(-110%,0,0)!important;
    transition:transform .24s ease!important;z-index:3200!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;
    opacity:1!important;visibility:visible!important;pointer-events:auto!important;
  }
  #mainNav.main-nav.open{transform:translate3d(0,0,0)!important;}
  #mainNav.main-nav:before{content:'Menu';position:absolute;left:20px;top:calc(52px + env(safe-area-inset-top));font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;font-weight:800;color:#b08b2e;}
  #mainNav.main-nav a{display:flex!important;align-items:center!important;justify-content:space-between!important;width:100%!important;min-height:52px!important;margin:0!important;padding:14px 4px!important;color:#321317!important;background:transparent!important;border-bottom:1px solid #eadfce!important;font-size:1.04rem!important;font-weight:750!important;line-height:1.15!important;text-align:left!important;position:relative!important;z-index:3202!important;white-space:normal!important;text-shadow:none!important;}
  #mainNav.main-nav a::after{content:'›'!important;display:block!important;position:static!important;width:auto!important;height:auto!important;background:transparent!important;color:#c9a331!important;font-size:1.45rem!important;line-height:1!important;}
  #navOverlay.nav-overlay{position:fixed!important;inset:0!important;background:rgba(20,12,10,.58)!important;z-index:3100!important;opacity:0!important;visibility:hidden!important;pointer-events:none!important;transition:.2s!important;}
  #navOverlay.nav-overlay.open{opacity:1!important;visibility:visible!important;pointer-events:auto!important;}

  .hero{overflow:hidden!important;background:linear-gradient(180deg,#fbf8f1 0%,#f3ecdf 100%)!important;}
  .hero-inner{display:grid!important;grid-template-columns:1fr!important;padding:34px 0 28px!important;gap:22px!important;}
  .hero-copy h1{font-size:clamp(2.25rem,13vw,3.35rem)!important;line-height:.96!important;letter-spacing:-.03em!important;margin:0 0 14px!important;max-width:9.5ch!important;}
  .hero-copy .lead{font-size:1.03rem!important;line-height:1.55!important;max-width:34ch!important;margin-bottom:18px!important;}
  .hero-cta{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;}
  .hero-cta a{min-height:52px!important;width:100%!important;}
  .home-values{grid-template-columns:1fr!important;gap:10px!important;margin-top:18px!important;}
  .home-value{display:block!important;padding:14px 15px!important;border-radius:16px!important;}
  .home-value b{display:block!important;margin-bottom:2px!important;font-size:1rem!important;}
  .home-value span{display:block!important;font-size:.9rem!important;line-height:1.35!important;}
  .hero-visual{justify-content:center!important;}
  .hero-bottle{max-width:280px!important;width:78vw!important;margin:0 auto!important;}
  .occasions{grid-template-columns:repeat(2,1fr)!important;gap:10px!important;}
  .occasion{padding:16px 10px!important;}
  .product-grid,.reviews-grid,.blog-grid,.unbox-grid{grid-template-columns:1fr!important;}
}

/* ===== V6 CRITICAL FIX: mobile drawer must stay ABOVE dark overlay =====
   iOS/Safari stacking fix: nav is inside sticky header, so header stacking context
   must be higher than overlay. Otherwise overlay covers menu and blocks taps. */
@media (max-width:760px){
  body.nav-open{overflow:hidden!important;}
  body.nav-open .site-header{z-index:9000!important;}
  body.nav-open #mainNav.main-nav{z-index:9300!important;pointer-events:auto!important;}
  body.nav-open #hamburger{z-index:9400!important;pointer-events:auto!important;}
  body.nav-open .brand{z-index:9350!important;}
  body.nav-open .header-actions{z-index:9350!important;}
  body.nav-open #navOverlay.nav-overlay{z-index:8000!important;pointer-events:auto!important;}
  #mainNav.main-nav.open{box-shadow:28px 0 80px rgba(20,12,10,.30)!important;}
  #mainNav.main-nav a{pointer-events:auto!important;}
  .nav-overlay.open{cursor:pointer!important;}
}

/* ===== V7 FINAL MENU FIX: overlay cannot cover drawer links ===== */
@media (max-width:760px){
  body.nav-open #mainNav.main-nav,
  body.nav-open #mainNav.main-nav *{
    pointer-events:auto!important;
    touch-action:manipulation!important;
  }
  body.nav-open #mainNav.main-nav{
    position:fixed!important;
    left:0!important;
    top:0!important;
    bottom:0!important;
    transform:translate3d(0,0,0)!important;
    z-index:2147483646!important;
    isolation:isolate!important;
  }
  body.nav-open #navOverlay.nav-overlay{
    position:fixed!important;
    top:0!important;
    right:0!important;
    bottom:0!important;
    left:min(86vw,360px)!important;
    width:auto!important;
    height:auto!important;
    z-index:2147483600!important;
    pointer-events:auto!important;
    background:rgba(20,12,10,.48)!important;
  }
  #navOverlay.nav-overlay:not(.open){
    pointer-events:none!important;
  }
  body.nav-open .site-header,
  body.nav-open .header-inner{
    overflow:visible!important;
  }
}

/* ===== V8 FIX: remove dark mobile menu scrim and unblock taps =====
   The previous overlay was rendered above the drawer on iOS/Safari and made
   the menu look dark/disabled. Keep the drawer, disable the scrim completely. */
@media (max-width:760px){
  body.nav-open{overflow:hidden!important;}
  #navOverlay.nav-overlay,
  #navOverlay.nav-overlay.open,
  body.nav-open #navOverlay.nav-overlay{
    display:none!important;
    opacity:0!important;
    visibility:hidden!important;
    background:transparent!important;
    pointer-events:none!important;
    z-index:-1!important;
  }
  body.nav-open .site-header{z-index:2147483640!important;}
  body.nav-open #mainNav.main-nav{
    z-index:2147483647!important;
    opacity:1!important;
    filter:none!important;
    background:#fffaf3!important;
    pointer-events:auto!important;
  }
  body.nav-open #mainNav.main-nav a,
  body.nav-open #mainNav.main-nav button{
    pointer-events:auto!important;
    filter:none!important;
    opacity:1!important;
  }
  body.nav-open .brand,
  body.nav-open #hamburger,
  body.nav-open .header-actions{filter:none!important;opacity:1!important;}
}

/* ===== v9: variant pills, addon cards, stock ===== */
.pd-stock{font-size:.9rem;margin:6px 0 10px;font-weight:600}
.pd-stock .stock-ok{color:#1c7a3f}
.pd-stock .stock-low{color:#b9770e}
.pd-stock .stock-out{color:#c0392b}
.variant-pills label.opt-disabled{opacity:.45;text-decoration:line-through;cursor:not-allowed}
.addon-cards{display:flex;flex-wrap:wrap;gap:10px}
.addon-card{display:flex;align-items:center;gap:8px;border:1.5px solid var(--line,#e7e1d8);border-radius:12px;padding:10px 14px;cursor:pointer;transition:.15s;font-size:.92rem;background:#fff}
.addon-card:has(input:checked){border-color:var(--gold,#D4AF37);background:#fbf6e8;box-shadow:0 0 0 2px rgba(212,175,55,.18)}
.addon-card .ac-price{font-weight:700;color:var(--burgundy,#5E1B23)}
.ci-addons{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}
.ci-addon{font-size:.78rem;background:#f6efe6;border-radius:20px;padding:2px 10px;color:#6b4f1d}
body.nav-open{overflow:hidden}

/* =========================================================
 *  CRO — DOPLNKY / UPSELL (v10) — YourSurprise + Alza inspirované
 * ========================================================= */
.addon-block{margin-top:1rem}
.addon-block-label{display:block;font-weight:700;margin-bottom:.5rem;color:var(--burgundy-deep)}
.addon-group{margin-bottom:.9rem}
.addon-group.addon-hidden{display:none}
.addon-group-title{font-size:.82rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--gold);margin:.2rem 0 .45rem}
.addon-options{display:grid;gap:.5rem}
.addon-opt{position:relative;display:flex;flex-direction:column;gap:.15rem;border:1.5px solid #e7ddd2;border-radius:14px;padding:.7rem .85rem;cursor:pointer;background:#fff;transition:border-color .15s,background .15s,box-shadow .15s}
.addon-opt:hover{border-color:var(--gold-soft)}
.addon-opt input{position:absolute;opacity:0;pointer-events:none}
.addon-opt.is-active{border-color:var(--burgundy);background:#fbf6f1;box-shadow:0 3px 14px rgba(94,27,35,.08)}
.addon-opt.is-free{opacity:.92}
.addon-opt .ao-main{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.ao-name{font-weight:600;display:flex;align-items:center;gap:.4rem}
.ao-price{font-weight:700;color:var(--burgundy);white-space:nowrap}
.ao-price .ao-was{color:#a99;font-weight:500;margin-right:.25rem}
.ao-save{align-self:flex-start;font-size:.74rem;font-weight:700;color:#2e7d32;background:#e8f5e9;border-radius:999px;padding:.08rem .5rem;margin-top:.2rem}
.addon-opt.is-active::after{content:"✓";position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--burgundy);color:#fff;font-size:.78rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.ao-info{width:18px;height:18px;border-radius:50%;border:1px solid var(--gold);background:#fff;color:var(--gold);font-size:.7rem;font-weight:700;line-height:1;cursor:pointer;padding:0;font-style:italic}
.ao-info.open::after{content:attr(data-tip);position:absolute;left:0;right:0;bottom:calc(100% + 6px);background:var(--burgundy-deep);color:#fff;font-weight:400;font-style:normal;font-size:.78rem;line-height:1.35;padding:.55rem .7rem;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);z-index:20}
.addon-toggle-more{background:none;border:0;color:var(--burgundy);font-weight:700;cursor:pointer;padding:.4rem 0;text-decoration:underline}

/* Cart — prepojené doplnkové položky */
.ci-addons-linked{margin:.4rem 0 .2rem;display:flex;flex-direction:column;gap:.25rem}
.ci-addon-line{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem;font-size:.88rem;padding-left:.4rem;border-left:2px solid var(--gold-soft)}
.cal-name{color:#5a4d44;font-weight:600}
.cal-price{color:var(--burgundy);font-weight:700}
.cal-price s{color:#b1a59a;font-weight:400;margin-right:.2rem}
.cal-save{font-size:.72rem;font-weight:700;color:#2e7d32;background:#e8f5e9;border-radius:999px;padding:.05rem .45rem}
.sum-row.save-row span:last-child{color:#2e7d32;font-weight:700}

/* Free-shipping progress bar */
.ship-progress{height:7px;border-radius:999px;background:#eee3d6;overflow:hidden;margin:.5rem 0 .35rem}
.ship-bar{height:100%;background:linear-gradient(90deg,var(--gold),#c39a2c);transition:width .4s}
.ship-hint.ok{color:#2e7d32;font-weight:600}

/* Cart cross-sell */
.cart-recommend{margin-top:2.2rem}
.cart-recommend .section-title{margin-bottom:1rem}

/* Sticky mobile checkout bar (cart) */
.cart-sticky{display:none}
@media(max-width:860px){
  .cart-sticky{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#fff;border-top:1px solid #ece2d6;padding:.7rem 1rem;box-shadow:0 -6px 20px rgba(0,0,0,.08)}
  .cart-sticky .cs-info{display:flex;flex-direction:column;line-height:1.1}
  .cart-sticky .cs-total{font-size:1.2rem;font-weight:800;color:var(--burgundy)}
  .cart-sticky .btn-primary{flex:0 0 auto;padding:.7rem 1.2rem}
  .cart-layout{padding-bottom:5rem}
}
