/* ============================================================
   HŘÍŠNĚ DOBRÉ — brand system
   Editorial × dark-luxury × pop mischief
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root{
  /* surfaces */
  --paper:      #F2E8D5;
  --paper-2:    #EADDC2;
  --paper-3:    #E2D2B2;
  --ink:        #1A130F;
  --ink-2:      #241A14;
  --ink-soft:   #5A4C42;
  --line:       #1A130F;

  /* brand */
  --chili:      #E5331B;
  --chili-deep: #B81E0C;
  --ember:      #F2913D;
  --toxic:      #D9F23B;
  --teal:       #16B7A6;

  /* product moods */
  --grapefruit: #F2698B;
  --malina:     #D81E5B;
  --mandarin:   #F2913D;
  --jahoda:     #E5331B;

  --gold:       #E8B33D;

  /* type */
  --display: 'Syne', system-ui, sans-serif;
  --ui: 'Space Grotesk', system-ui, sans-serif;

  /* shape */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 26px;
  --r-pill: 999px;
  --shadow-hard: 5px 5px 0 var(--ink);
  --shadow-hard-lg: 8px 8px 0 var(--ink);
  --maxw: 1280px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--ui);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:0.96; margin:0; letter-spacing:-0.02em; }
.display{ font-family:var(--display); }
.kicker{
  font-family:var(--ui); font-weight:700; font-size:13px;
  letter-spacing:0.18em; text-transform:uppercase;
}

/* layout helpers */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:88px 0; }
.section-sm{ padding:56px 0; }
.eyebrow-row{ display:flex; align-items:center; gap:14px; margin-bottom:22px; }
.horns{ width:30px; height:30px; flex:none; }
.stack-sm{ display:flex; flex-direction:column; gap:8px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--ui); font-weight:700; font-size:15px;
  letter-spacing:0.01em;
  padding:15px 26px; border-radius:var(--r-pill);
  border:2.5px solid var(--ink); background:var(--paper);
  color:var(--ink);
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease;
  box-shadow:var(--shadow-hard);
}
.btn:hover{ transform:translate(-2px,-2px); box-shadow:7px 7px 0 var(--ink); }
.btn:active{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--ink); }
.btn--chili{ background:var(--chili); color:#fff; }
.btn--toxic{ background:var(--toxic); color:var(--ink); }
.btn--ink{ background:var(--ink); color:var(--paper); }
.btn--ghost{ background:transparent; box-shadow:none; }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); box-shadow:none; transform:none; }
.btn--lg{ padding:18px 34px; font-size:17px; }
.btn--sm{ padding:10px 18px; font-size:13px; box-shadow:3px 3px 0 var(--ink); }
.btn--sm:hover{ box-shadow:5px 5px 0 var(--ink); }
.btn--block{ width:100%; }

/* ---------- sticker badge ---------- */
.sticker{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--ui); font-weight:700; font-size:12px;
  letter-spacing:0.08em; text-transform:uppercase;
  padding:7px 13px; border-radius:var(--r-pill);
  border:2px solid var(--ink); background:var(--toxic); color:var(--ink);
  box-shadow:2px 2px 0 var(--ink);
}
.sticker--chili{ background:var(--chili); color:#fff; }
.sticker--ink{ background:var(--ink); color:var(--paper); }
.sticker--paper{ background:var(--paper); }
.sticker--rot{ transform:rotate(-5deg); }

.tag{
  display:inline-flex; align-items:center; gap:6px;
  font-weight:600; font-size:12.5px; letter-spacing:0.04em;
  padding:5px 11px; border-radius:var(--r-pill);
  border:1.5px solid rgba(26,19,15,.28);
  color:var(--ink-soft); background:rgba(255,255,255,.35);
}

/* ---------- marquee ---------- */
.marquee{
  background:var(--ink); color:var(--paper);
  border-top:3px solid var(--ink); border-bottom:3px solid var(--ink);
  overflow:hidden; white-space:nowrap; padding:13px 0;
}
.marquee--toxic{ background:var(--toxic); color:var(--ink); }
.marquee--chili{ background:var(--chili); color:#fff; }
.marquee__track{ display:inline-flex; gap:34px; animation:marquee 26s linear infinite; will-change:transform; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__item{
  font-family:var(--display); font-weight:800; font-size:20px;
  letter-spacing:0.02em; display:inline-flex; align-items:center; gap:34px;
}
.marquee__item::after{ content:"✦"; font-size:15px; opacity:.6; }
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ---------- header ---------- */
.site-head{
  position:sticky; top:0; z-index:60;
  background:var(--paper);
  border-bottom:3px solid var(--ink);
}
.site-head__bar{ display:flex; align-items:center; gap:22px; height:74px; }
.brand-logo{ height:34px; width:auto; }
.brand-logo--link{ display:flex; align-items:center; flex:none; }
.nav{ display:flex; gap:4px; margin-left:8px; }
.nav a{
  font-weight:600; font-size:15px; padding:9px 14px; border-radius:var(--r-pill);
  transition:background .15s ease, color .15s ease;
}
.nav a:hover{ background:var(--ink); color:var(--paper); }
.nav a.is-active{ background:var(--chili); color:#fff; }
.head-actions{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.icon-btn{
  width:44px; height:44px; border-radius:var(--r-pill);
  border:2.5px solid var(--ink); background:var(--paper);
  display:flex; align-items:center; justify-content:center; position:relative;
  transition:background .15s ease,color .15s ease;
}
.icon-btn:hover{ background:var(--ink); color:var(--paper); }
.icon-btn svg{ width:20px; height:20px; }
.cart-count{
  position:absolute; top:-6px; right:-6px; min-width:21px; height:21px; padding:0 5px;
  background:var(--chili); color:#fff; border:2px solid var(--paper);
  border-radius:var(--r-pill); font-size:11px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.burger{ display:none; }

/* ---------- cards ---------- */
.card{
  background:var(--paper); border:3px solid var(--ink); border-radius:var(--r-lg);
  overflow:hidden; position:relative;
  transition:transform .15s ease, box-shadow .15s ease;
}
.card--lift{ box-shadow:var(--shadow-hard); }
.card--lift:hover{ transform:translate(-3px,-3px); box-shadow:9px 9px 0 var(--ink); }

/* product card */
.pcard__media{ position:relative; aspect-ratio:1/1; background:var(--paper-2); border-bottom:3px solid var(--ink); }
.pcard__media image-slot{ width:100%; height:100%; }
.pcard__badges{ position:absolute; top:12px; left:12px; display:flex; flex-direction:column; gap:7px; align-items:flex-start; z-index:2; }
.pcard__fav{ position:absolute; top:12px; right:12px; z-index:2; }
.pcard__body{ padding:18px 18px 20px; }
.pcard__name{ font-family:var(--display); font-weight:800; font-size:21px; line-height:1; }
.pcard__desc{ color:var(--ink-soft); font-size:14.5px; margin-top:7px; min-height:2.6em; }
.pcard__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:16px; gap:12px; }
.price{ font-family:var(--display); font-weight:800; font-size:22px; }
.price small{ font-family:var(--ui); font-weight:500; font-size:13px; color:var(--ink-soft); }

/* swatch dot */
.dot{ width:13px; height:13px; border-radius:50%; border:1.5px solid var(--ink); display:inline-block; }

/* ---------- flavor meter ---------- */
.meter{ display:flex; flex-direction:column; gap:14px; }
.meter__row{ display:grid; grid-template-columns:120px 1fr; align-items:center; gap:16px; }
.meter__label{ font-weight:600; font-size:14px; }
.meter__track{ height:14px; border:2px solid var(--ink); border-radius:var(--r-pill); background:var(--paper); overflow:hidden; }
.meter__fill{ height:100%; background:var(--chili); border-right:2px solid var(--ink); }

/* ---------- generic ---------- */
.grid{ display:grid; gap:24px; }
.cols-2{ grid-template-columns:repeat(2,minmax(0,1fr)); }
.cols-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.cols-4{ grid-template-columns:repeat(4,minmax(0,1fr)); }
.divider{ height:3px; background:var(--ink); border:0; }
.muted{ color:var(--ink-soft); }
.center{ text-align:center; }
.lead{ font-size:19px; line-height:1.55; color:var(--ink-soft); }

/* dark section */
.dark{ background:var(--ink); color:var(--paper); }
.dark h1,.dark h2,.dark h3{ color:var(--paper); }
.dark .btn{ border-color:var(--paper); box-shadow:5px 5px 0 var(--toxic); }
.dark .btn:hover{ box-shadow:7px 7px 0 var(--toxic); }
.dark .btn--toxic{ color:var(--ink); border-color:var(--ink); box-shadow:5px 5px 0 var(--paper); }
.dark .card{ background:var(--ink-2); border-color:var(--paper); }
.dark .muted{ color:#C7B7A4; }

/* logo invert util on dark */
.logo-invert{ filter:invert(1); }

/* stat box (used in dark B2B sections) */
.statbox{ border:3px solid var(--paper); border-radius:var(--r-md); padding:22px; }
.statbox b{ font-family:var(--display); font-weight:800; font-size:42px; display:block; color:var(--toxic); line-height:1; }
.statbox span{ font-size:14px; color:#C7B7A4; }

/* image-slot: must be shrinkable so it never blows out grid tracks */
image-slot{ display:block; max-width:100%; }
/* image-slot empty-state tint (mood color via --ph) */
image-slot::part(frame){ background:var(--ph, var(--paper-3)); }
image-slot::part(empty){ color:rgba(26,19,15,.55); font-family:var(--ui); font-weight:600; }

/* ---------- footer ---------- */
.site-foot{ background:var(--ink); color:var(--paper); padding:64px 0 36px; }
.site-foot a{ color:#D9CBB8; }
.site-foot a:hover{ color:var(--toxic); }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.foot-col h4{ font-family:var(--ui); font-size:13px; letter-spacing:0.16em; text-transform:uppercase; color:var(--toxic); margin-bottom:14px; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; font-size:15px; }
.foot-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.16); display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:13.5px; color:#A99884; }

/* ---------- cart drawer ---------- */
.scrim{ position:fixed; inset:0; background:rgba(26,19,15,.5); opacity:0; pointer-events:none; transition:opacity .25s ease; z-index:90; backdrop-filter:blur(2px); }
.scrim.open{ opacity:1; pointer-events:auto; }
.drawer{
  position:fixed; top:0; right:0; height:100%; width:min(420px,92vw);
  background:var(--paper); border-left:3px solid var(--ink);
  transform:translateX(105%); transition:transform .3s cubic-bezier(.22,1,.36,1);
  z-index:95; display:flex; flex-direction:column;
}
.drawer.open{ transform:translateX(0); }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; padding:22px 22px; border-bottom:3px solid var(--ink); }
.drawer__head h3{ font-size:24px; }
.drawer__body{ flex:1; overflow-y:auto; padding:18px 22px; display:flex; flex-direction:column; gap:14px; }
.drawer__foot{ padding:20px 22px; border-top:3px solid var(--ink); background:var(--paper-2); }
.citem{ display:grid; grid-template-columns:64px 1fr auto; gap:13px; align-items:center; }
.citem__img{ width:64px; height:64px; border:2px solid var(--ink); border-radius:12px; background:var(--paper-2); }
.citem__name{ font-family:var(--display); font-weight:700; font-size:16px; }
.qty{ display:inline-flex; align-items:center; border:2px solid var(--ink); border-radius:var(--r-pill); overflow:hidden; }
.qty button{ width:28px; height:28px; background:var(--paper); border:0; font-weight:700; font-size:16px; }
.qty span{ min-width:26px; text-align:center; font-weight:700; font-size:14px; }

/* ---------- mobile nav sheet ---------- */
.msheet{ position:fixed; inset:0; background:var(--paper); z-index:80; transform:translateY(-100%); transition:transform .3s ease; padding:90px 28px 40px; overflow-y:auto; }
.msheet.open{ transform:translateY(0); }
.msheet a{ display:block; font-family:var(--display); font-weight:800; font-size:30px; padding:14px 0; border-bottom:2px solid rgba(26,19,15,.12); }

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .cols-4{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:860px){
  .nav{ display:none; }
  .burger{ display:flex; }
  .head-actions .hide-mob{ display:none; }
  .section{ padding:60px 0; }
  .cols-3{ grid-template-columns:1fr; }
  .cols-2{ grid-template-columns:1fr; }
  .meter__row{ grid-template-columns:100px 1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:24px; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .wrap{ padding:0 18px; }
  .cols-4{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
