/* ════════════════════════════════════════════════════════════════
   HASAKI — HOMEPAGE  (scope: body.hasaki-home / #hasaki-home-root)
   Dark premium · japonská cinobrová červená · editorial.
   Samostatný soubor — žádné externí závislosti (vlastní --hk-* var).
   Struktura inspirovaná dellinger.cz (hero → USP → kategorie →
   příběh → spotlight → bestsellery → recenze → newsletter).
   ════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Inter:wght@400;500;600;700&family=Barlow+Condensed:wght@400;500;600&display=swap');

/* ---- lokální tokeny (nezávislé) ---- */
.hasaki-home{
  --hk-bg:#0B0A09; --hk-bg-2:#110E0C; --hk-surface:#16120F; --hk-surface-2:#1E1813;
  --hk-line:#2A231D; --hk-line-strong:#3A302A;
  --hk-ink:#F4F0EA; --hk-ink-2:#B6ADA2; --hk-ink-3:#847A6F;
  --hk-red:#D8453B; --hk-red-bright:#EA5A4E; --hk-red-press:#B5362A;
  --hk-red-soft:rgba(216,69,59,.14); --hk-red-glow:rgba(216,69,59,.40);
  --hk-success:#4FB286;
  --hk-serif:"Cormorant Garamond",Georgia,serif;
  --hk-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --hk-cond:"Barlow Condensed","Inter",sans-serif;
  --hk-ease:cubic-bezier(.2,.7,.3,1);
  --hk-ease-lux:cubic-bezier(.22,1,.36,1);
  --hk-container:1320px;
}

/* ════════════════ SHOPTET RESET — jen na homepage ════════════════ */
body.hasaki-home{ margin:0!important; background:var(--hk-bg)!important; }
.hasaki-home .overall-wrapper{ max-width:100%!important; margin:0!important; }

.hasaki-home #content-wrapper,
.hasaki-home .content-wrapper,
.hasaki-home #main-wrapper,
.hasaki-home .main-wrapper,
.hasaki-home #page-content,
.hasaki-home .page-content,
.hasaki-home #layout-main,
.hasaki-home #snippet-layout-main,
.hasaki-home .p-main,
.hasaki-home main.main,
.hasaki-home #main,
.hasaki-home .homepage-banner,
.hasaki-home .homepage-content,
.hasaki-home .homepage-slider,
.hasaki-home .banner,.hasaki-home .slider,.hasaki-home .carousel,
.hasaki-home .welcome,.hasaki-home .uvod,
.hasaki-home #layout-breadcrumbs,
.hasaki-home #snippet-layout-breadcrumbs,
.hasaki-home .p-breadcrumbs,
.hasaki-home .breadcrumbs{ display:none!important; }

/* header drží nad obsahem */
.hasaki-home #layout-header,
.hasaki-home #snippet-layout-header,
.hasaki-home .p-header,
.hasaki-home .header-wrapper{ position:relative!important; z-index:9990!important; }

/* footer ponecháme viditelný (řeší globální hasaki-theme) */
.hasaki-home #footer{ margin-top:0!important; }

/* ════════════════ ROOT / RESET ════════════════ */
#hasaki-home-root{
  font-family:var(--hk-sans);
  color:var(--hk-ink);
  background:var(--hk-bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:clip;
}
#hasaki-home-root *,#hasaki-home-root *::before,#hasaki-home-root *::after{ box-sizing:border-box; }
#hasaki-home-root img{ display:block; max-width:100%; }
#hasaki-home-root a{ color:inherit; text-decoration:none; }
#hasaki-home-root h1,#hasaki-home-root h2,#hasaki-home-root h3{ margin:0; font-family:var(--hk-serif); font-weight:500; }
#hasaki-home-root button{ font-family:inherit; }

.hk-wrap{ max-width:var(--hk-container); margin:0 auto; padding:0 24px; }

/* ---- sdílené primitivy ---- */
.hk-eyebrow{
  font-family:var(--hk-cond); font-size:13px; font-weight:600;
  letter-spacing:.3em; text-transform:uppercase; color:var(--hk-red);
  display:inline-flex; align-items:center; gap:14px;
}
.hk-eyebrow::before{ content:""; width:34px; height:1px; background:var(--hk-red); display:block; }
.hk-eyebrow--center{ justify-content:center; }
.hk-eyebrow--center::after{ content:""; width:34px; height:1px; background:var(--hk-red); display:block; }

.hk-section-head{ text-align:center; max-width:720px; margin:0 auto 56px; }
.hk-section-head .hk-eyebrow{ margin-bottom:18px; }
.hk-h2{
  font-size:clamp(2rem,3.6vw,3.1rem); line-height:1.08; color:var(--hk-ink);
  font-weight:500; letter-spacing:.005em;
}
.hk-h2 em{ font-style:italic; color:var(--hk-red); }
.hk-section-head p{ color:var(--hk-ink-2); font-size:15px; margin:18px auto 0; max-width:54ch; }

.hk-btn{
  font-family:var(--hk-cond); font-size:14px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  padding:16px 34px; border:1px solid transparent; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  transition:transform var(--hk-dur,.26s) var(--hk-ease), background .26s, box-shadow .26s, color .26s, border-color .26s;
  border-radius:2px; line-height:1; white-space:nowrap;
}
.hk-btn svg{ width:16px; height:16px; }
.hk-btn--primary{ background:var(--hk-red); color:#fff; box-shadow:0 12px 30px -12px var(--hk-red-glow); }
.hk-btn--primary:hover{ background:var(--hk-red-bright); color:#fff; transform:translateY(-2px); box-shadow:0 16px 40px -10px var(--hk-red-glow); }
.hk-btn--ghost{ background:transparent; color:var(--hk-ink); border-color:var(--hk-line-strong); }
.hk-btn--ghost:hover{ border-color:var(--hk-red); color:var(--hk-red); transform:translateY(-2px); }

/* reveal on scroll */
.hk-reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--hk-ease-lux), transform .9s var(--hk-ease-lux); }
.hk-reveal.is-in{ opacity:1; transform:none; }

/* ════════════════════════════════════════════════
   ANIMACE — premium (gated přes prefers-reduced-motion na konci souboru)
   ════════════════════════════════════════════════ */
/* HERO — postupný (stagger) nástup obsahu */
.hk-hero__inner > *{ opacity:0; transform:translateY(30px); transition:opacity .9s var(--hk-ease-lux), transform .9s var(--hk-ease-lux); }
.hk-hero.is-in .hk-hero__inner > *{ opacity:1; transform:none; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(1){ transition-delay:.10s; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(2){ transition-delay:.20s; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(3){ transition-delay:.30s; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(4){ transition-delay:.40s; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(5){ transition-delay:.50s; }
.hk-hero.is-in .hk-hero__inner > *:nth-child(6){ transition-delay:.60s; }
/* HERO — kanji vodoznak: nástup + parallax řídí JS (translateY var) */
.hk-hero__kanji{ opacity:0; transition:opacity 1.5s var(--hk-ease-lux); will-change:transform; }
.hk-hero.is-in .hk-hero__kanji{ opacity:1; }
/* HERO — pomalý „ken-burns" pohyb fotky */
.hk-hero__media{ transform:scale(1.04); }
.hk-hero.is-in .hk-hero__media{ animation:hk-kenburns 22s ease-out forwards; }
@keyframes hk-kenburns{ from{ transform:scale(1.12); } to{ transform:scale(1); } }
/* HERO — scroll-cue plynule zmizí po odscrollování (řídí JS) */
.hk-hero__scrolled .hk-scrollcue{ opacity:0; transition:opacity .4s; }

/* GRID stagger — kategorie, bestsellery, recenze (spouští .is-in z IntersectionObserveru) */
.hk-cats__grid .hk-cat,
.hk-grid .hk-card,
.hk-reviews__grid .hk-review,
.hk-usp__grid .hk-usp__item{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--hk-ease-lux), transform .7s var(--hk-ease-lux); }
.hk-cats.is-in .hk-cat,
.hk-best.is-in .hk-card,
.hk-reviews.is-in .hk-review,
.hk-usp.is-in .hk-usp__item{ opacity:1; transform:none; }
.hk-cats.is-in .hk-cat:nth-child(1),.hk-best.is-in .hk-card:nth-child(1),.hk-reviews.is-in .hk-review:nth-child(1),.hk-usp.is-in .hk-usp__item:nth-child(1){ transition-delay:.04s; }
.hk-cats.is-in .hk-cat:nth-child(2),.hk-best.is-in .hk-card:nth-child(2),.hk-reviews.is-in .hk-review:nth-child(2),.hk-usp.is-in .hk-usp__item:nth-child(2){ transition-delay:.12s; }
.hk-cats.is-in .hk-cat:nth-child(3),.hk-best.is-in .hk-card:nth-child(3),.hk-reviews.is-in .hk-review:nth-child(3),.hk-usp.is-in .hk-usp__item:nth-child(3){ transition-delay:.20s; }
.hk-cats.is-in .hk-cat:nth-child(4),.hk-best.is-in .hk-card:nth-child(4),.hk-usp.is-in .hk-usp__item:nth-child(4){ transition-delay:.28s; }
.hk-cats.is-in .hk-cat:nth-child(5),.hk-best.is-in .hk-card:nth-child(5){ transition-delay:.36s; }
.hk-best.is-in .hk-card:nth-child(6){ transition-delay:.44s; }
.hk-best.is-in .hk-card:nth-child(7){ transition-delay:.52s; }
.hk-best.is-in .hk-card:nth-child(8){ transition-delay:.60s; }

/* Section nadpis — jemný posun akcentové linky */
.hk-section-head .hk-eyebrow::before{ transition:width .6s var(--hk-ease-lux) .2s; }

/* Plynulé chování + respekt k uživatelům s omezeným pohybem (home.css je samostatný) */
@media (prefers-reduced-motion: reduce){
  .hk-hero__inner > *, .hk-hero__kanji, .hk-hero__media,
  .hk-cats__grid .hk-cat, .hk-grid .hk-card, .hk-reviews__grid .hk-review, .hk-usp__grid .hk-usp__item,
  .hk-reveal{ opacity:1 !important; transform:none !important; transition:none !important; animation:none !important; }
}

/* ════════════════════════════════════════════════
   1) HERO
   ════════════════════════════════════════════════ */
.hk-hero{
  position:relative; min-height:92vh; display:flex; align-items:center;
  background:var(--hk-bg); overflow:hidden;
  padding:140px 0 110px;
}
.hk-hero__media{
  position:absolute; inset:0; z-index:0;
  background-image:url('/user/documents/obrazek1.png');
  background-size:cover; background-position:60% center;
}
.hk-hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, var(--hk-bg) 0%, rgba(11,10,9,.86) 34%, rgba(11,10,9,.30) 66%, rgba(11,10,9,.55) 100%),
    radial-gradient(120% 80% at 78% 42%, rgba(216,69,59,.12) 0%, transparent 60%),
    linear-gradient(0deg, var(--hk-bg) 2%, transparent 30%);
}
/* velký japonský znak „čepel" jako vodoznak */
.hk-hero__kanji{
  position:absolute; right:3vw; top:50%; transform:translateY(-50%);
  font-family:var(--hk-serif); font-size:46vh; line-height:.8; font-weight:600;
  color:rgba(244,240,234,.04); z-index:1; pointer-events:none; user-select:none;
}
/* Hero obsah ukotvený VLEVO (ne na střed): wrap vyplní kontejner (jinak se jako
   flex-item smrští na šířku obsahu a margin:auto ho vycentruje doprostřed). */
.hk-hero .hk-wrap{ width:100%; }
.hk-hero__inner{ position:relative; z-index:2; max-width:600px; margin-right:auto; }
.hk-hero .hk-eyebrow{ margin-bottom:28px; }
.hk-hero__title{
  font-size:clamp(3rem,6.2vw,5.4rem); line-height:.98; color:var(--hk-ink);
  font-weight:400; letter-spacing:.004em; margin-bottom:0;
}
.hk-hero__title em{ font-style:italic; font-weight:500; color:var(--hk-red); }
.hk-hero__title b{ display:block; font-weight:600; letter-spacing:.02em; }
.hk-hero__rule{ width:64px; height:2px; background:linear-gradient(90deg,var(--hk-red),transparent); margin:30px 0 26px; }
.hk-hero__desc{ font-size:16px; line-height:1.85; color:var(--hk-ink-2); max-width:440px; margin:0 0 42px; font-weight:400; }
.hk-hero__cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-bottom:64px; }
.hk-hero__stats{ display:flex; gap:0; max-width:540px; border-top:1px solid var(--hk-line); }
.hk-hero__stat{ flex:1; padding:24px 26px 0 0; }
.hk-hero__stat + .hk-hero__stat{ padding-left:30px; border-left:1px solid var(--hk-line); }
.hk-hero__stat-n{ font-family:var(--hk-serif); font-size:40px; font-weight:500; color:var(--hk-ink); line-height:1; }
.hk-hero__stat-n span{ color:var(--hk-red); }
.hk-hero__stat-l{ font-family:var(--hk-cond); font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--hk-ink-3); margin-top:10px; }
.hk-scrollcue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:var(--hk-cond); font-size:11px; letter-spacing:.25em; text-transform:uppercase; color:var(--hk-ink-3);
}
.hk-scrollcue::after{ content:""; width:1px; height:46px; background:linear-gradient(180deg,var(--hk-red),transparent); animation:hk-cue 2.2s var(--hk-ease) infinite; }
@keyframes hk-cue{ 0%{opacity:0;transform:scaleY(0);transform-origin:top} 40%{opacity:1;transform:scaleY(1)} 100%{opacity:0;transform:scaleY(1);transform-origin:bottom} }

/* ════════════════════════════════════════════════
   2) MARQUEE (tenký pruh)
   ════════════════════════════════════════════════ */
.hk-marquee{ background:#060504; border-top:1px solid var(--hk-line); border-bottom:1px solid var(--hk-line); overflow:hidden; }
.hk-marquee__row{ display:flex; width:max-content; animation:hk-marq 38s linear infinite; }
@keyframes hk-marq{ to{ transform:translateX(-50%); } }
.hk-marquee__group{ display:flex; align-items:center; padding:15px 0; }
.hk-marquee__item{
  font-family:var(--hk-cond); font-size:13px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--hk-ink-2); padding:0 30px; display:inline-flex; align-items:center; gap:30px; white-space:nowrap;
}
.hk-marquee__item b{ color:var(--hk-ink); font-weight:500; }
.hk-marquee__dot{ width:5px; height:5px; background:var(--hk-red); border-radius:50%; }

/* ════════════════════════════════════════════════
   3) USP / TRUST BAR
   ════════════════════════════════════════════════ */
.hk-usp{ background:var(--hk-bg); padding:54px 0; border-bottom:1px solid var(--hk-line); }
.hk-usp__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.hk-usp__item{ display:flex; align-items:center; gap:16px; padding:6px 28px; }
.hk-usp__item + .hk-usp__item{ border-left:1px solid var(--hk-line); }
.hk-usp__ico{ width:42px; height:42px; flex-shrink:0; display:grid; place-items:center; color:var(--hk-red); border:1px solid var(--hk-red-line,rgba(216,69,59,.35)); border-radius:50%; }
.hk-usp__ico svg{ width:21px; height:21px; stroke:currentColor; fill:none; stroke-width:1.6; }
.hk-usp__t{ font-size:14px; font-weight:600; color:var(--hk-ink); letter-spacing:.01em; }
.hk-usp__s{ font-size:12.5px; color:var(--hk-ink-3); margin-top:3px; }

/* ════════════════════════════════════════════════
   4) KATEGORIE — editorial mřížka
   ════════════════════════════════════════════════ */
.hk-cats{ padding:104px 0; background:var(--hk-bg); }
.hk-cats__grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr; grid-auto-rows:230px; gap:14px;
}
.hk-cat{ position:relative; overflow:hidden; border:1px solid var(--hk-line); border-radius:4px; cursor:pointer; isolation:isolate; }
.hk-cat--xl{ grid-row:span 2; }
.hk-cat__bg{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform 1s var(--hk-ease-lux); z-index:0; }
.hk-cat:hover .hk-cat__bg{ transform:scale(1.07); }
.hk-cat__overlay{ position:absolute; inset:0; z-index:1; background:linear-gradient(0deg, rgba(6,5,4,.92) 0%, rgba(6,5,4,.35) 55%, rgba(6,5,4,.08) 100%); transition:background .4s; }
.hk-cat:hover .hk-cat__overlay{ background:linear-gradient(0deg, rgba(6,5,4,.95) 0%, rgba(6,5,4,.5) 60%, rgba(6,5,4,.15) 100%); }
.hk-cat__line{ position:absolute; top:0; left:0; right:0; height:2px; z-index:2; background:linear-gradient(90deg,transparent,var(--hk-red),transparent); opacity:0; transition:opacity .4s; }
.hk-cat:hover .hk-cat__line{ opacity:1; }
.hk-cat__body{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:28px; transition:transform .4s var(--hk-ease); }
.hk-cat:hover .hk-cat__body{ transform:translateY(-4px); }
.hk-cat__tag{ font-family:var(--hk-cond); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--hk-red); margin-bottom:9px; }
.hk-cat__name{ font-family:var(--hk-serif); font-size:26px; line-height:1.08; color:#fff; font-weight:500; }
.hk-cat--xl .hk-cat__name{ font-size:40px; }
.hk-cat__count{ font-size:12.5px; color:var(--hk-ink-2); letter-spacing:.04em; margin-top:8px; }
.hk-cat__arrow{ position:absolute; top:24px; right:24px; z-index:2; width:42px; height:42px; border:1px solid rgba(244,240,234,.2); border-radius:50%; display:grid; place-items:center; color:var(--hk-red); opacity:0; transform:translateX(10px); transition:all .4s var(--hk-ease); }
.hk-cat:hover .hk-cat__arrow{ opacity:1; transform:none; border-color:var(--hk-red); }
.hk-cat__arrow svg{ width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.8; }

/* ════════════════════════════════════════════════
   5) PRŮVODCE VÝBĚREM NOŽE (interaktivní)
   ════════════════════════════════════════════════ */
.hk-guide{ padding:104px 0; background:var(--hk-bg-2); border-top:1px solid var(--hk-line); border-bottom:1px solid var(--hk-line); }
.hk-guide__panel{ display:grid; grid-template-columns:316px 1fr; background:var(--hk-surface); border:1px solid var(--hk-line); border-radius:6px; overflow:hidden; box-shadow:0 30px 70px -30px rgba(0,0,0,.7); }
/* Levý sloupec — use-case taby */
.hk-guide__tabs{ display:flex; flex-direction:column; gap:4px; padding:14px; background:var(--hk-bg); border-right:1px solid var(--hk-line); }
.hk-guide__tab{ display:flex; align-items:center; gap:14px; width:100%; text-align:left; padding:15px 16px; border:0; background:transparent; color:var(--hk-ink-2); font-family:var(--hk-sans); cursor:pointer; border-radius:5px; border-left:3px solid transparent; transition:background .3s var(--hk-ease), color .3s var(--hk-ease), border-color .3s var(--hk-ease); }
.hk-guide__tab:hover{ background:var(--hk-surface-2); color:var(--hk-ink); }
.hk-guide__tab.is-on{ background:var(--hk-red-soft); color:var(--hk-red); border-left-color:var(--hk-red); }
.hk-guide__tab-ico{ width:26px; height:26px; flex-shrink:0; display:grid; place-items:center; color:currentColor; }
.hk-guide__tab-ico svg{ width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.hk-guide__tab-l{ display:flex; flex-direction:column; line-height:1.25; flex:1; min-width:0; }
.hk-guide__tab-l b{ font-size:15px; font-weight:600; color:inherit; }
.hk-guide__tab-l i{ font-style:normal; font-size:12px; letter-spacing:.04em; color:var(--hk-ink-3); }
.hk-guide__tab.is-on .hk-guide__tab-l i{ color:var(--hk-red); opacity:.8; }
.hk-guide__tab-chev{ width:16px; height:16px; flex-shrink:0; color:var(--hk-ink-3); opacity:0; transform:translateX(-6px); transition:opacity .3s, transform .3s; }
.hk-guide__tab-chev svg{ width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2; }
.hk-guide__tab.is-on .hk-guide__tab-chev{ opacity:1; transform:none; color:var(--hk-red); }
/* Pravá scéna — doporučení */
.hk-guide__stage{ display:grid; grid-template-columns:1fr 1fr; min-height:440px; }
.hk-guide__media{ position:relative; background:#0E0B09; overflow:hidden; }
.hk-guide__media img{ width:100%; height:100%; object-fit:cover; display:block; }
.hk-guide__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,transparent 50%,var(--hk-surface) 100%),radial-gradient(75% 60% at 38% 50%,rgba(216,69,59,.16),transparent 72%); }
.hk-guide__badge{ position:absolute; left:18px; top:18px; z-index:2; font-family:var(--hk-cond); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:#fff; background:rgba(6,5,4,.55); border:1px solid var(--hk-line-strong); backdrop-filter:blur(6px); padding:7px 13px; }
.hk-guide__info{ padding:clamp(36px,3.4vw,52px); display:flex; flex-direction:column; }
.hk-guide__type{ font-family:var(--hk-cond); font-size:12px; letter-spacing:.26em; text-transform:uppercase; color:var(--hk-red); margin-bottom:10px; }
.hk-guide__name{ font-family:var(--hk-serif); font-size:clamp(1.7rem,2.4vw,2.2rem); line-height:1.08; color:var(--hk-ink); font-weight:500; margin-bottom:14px; }
.hk-guide__desc{ color:var(--hk-ink-2); font-size:15px; line-height:1.8; margin-bottom:26px; }
.hk-guide__specs{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--hk-line); border:1px solid var(--hk-line); margin-bottom:30px; }
.hk-guide__spec{ background:var(--hk-surface); padding:14px 16px; }
.hk-guide__spec dt{ font-family:var(--hk-cond); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--hk-ink-3); margin-bottom:5px; }
.hk-guide__spec dd{ font-size:14.5px; color:var(--hk-ink); margin:0; font-weight:500; }
.hk-guide__cta{ margin-top:auto; align-self:flex-start; }
.hk-guide__fade{ animation:hk-guide-fade .45s var(--hk-ease-lux); }
@keyframes hk-guide-fade{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }

/* ════════════════════════════════════════════════
   6) SPOTLIGHT — vlajkový produkt (carousel)
   ════════════════════════════════════════════════ */
.hk-spot{ padding:104px 0; background:var(--hk-bg); }
.hk-spot__stage{ display:grid; grid-template-columns:1.05fr .95fr; gap:72px; align-items:center; }
.hk-spot__visual{ position:relative; min-height:480px; display:grid; place-items:center; }
.hk-spot__glow{ position:absolute; width:78%; height:78%; border-radius:50%; background:radial-gradient(circle, rgba(216,69,59,.18) 0%, transparent 68%); filter:blur(8px); animation:hk-pulse 5s ease-in-out infinite; }
@keyframes hk-pulse{ 0%,100%{opacity:.55;transform:scale(.97)} 50%{opacity:1;transform:scale(1.03)} }
.hk-spot__img{ position:relative; z-index:2; max-height:460px; width:auto; object-fit:contain; filter:drop-shadow(0 28px 50px rgba(0,0,0,.6)); transition:opacity .3s, transform .45s var(--hk-ease-lux); }
.hk-spot__badge{ position:absolute; top:8px; right:8px; z-index:3; background:var(--hk-red); color:#fff; font-family:var(--hk-cond); font-size:11px; letter-spacing:.22em; text-transform:uppercase; padding:9px 18px; }
.hk-spot__arrow{ position:absolute; top:50%; transform:translateY(-50%); z-index:4; width:48px; height:48px; border-radius:50%; background:rgba(6,5,4,.6); border:1px solid var(--hk-line-strong); color:var(--hk-ink); display:grid; place-items:center; cursor:pointer; backdrop-filter:blur(4px); transition:background .2s, border-color .2s; }
.hk-spot__arrow:hover{ background:var(--hk-red-soft); border-color:var(--hk-red); color:var(--hk-red); }
.hk-spot__arrow svg{ width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.8; }
.hk-spot__prev{ left:0; } .hk-spot__next{ right:0; }
.hk-spot__dots{ position:absolute; bottom:6px; left:50%; transform:translateX(-50%); z-index:4; display:flex; gap:8px; }
.hk-spot__dot{ width:8px; height:8px; border-radius:50%; background:var(--hk-line-strong); border:none; cursor:pointer; padding:0; transition:background .2s, transform .2s; }
.hk-spot__dot.is-on{ background:var(--hk-red); transform:scale(1.3); }
.hk-spot__info .hk-eyebrow{ margin-bottom:18px; }
.hk-spot__title{ font-family:var(--hk-serif); font-size:clamp(2.2rem,3.4vw,3.1rem); line-height:1.04; color:var(--hk-ink); font-weight:500; }
.hk-spot__sub{ font-family:var(--hk-serif); font-style:italic; font-size:21px; color:var(--hk-ink-2); margin-top:8px; }
.hk-spot__specs{ display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--hk-line); margin:30px 0; }
.hk-spot__spec{ padding:16px 22px 16px 0; border-bottom:1px solid var(--hk-line); }
.hk-spot__spec:nth-child(odd){ border-right:1px solid var(--hk-line); }
.hk-spot__spec:nth-child(even){ padding-left:22px; }
.hk-spot__spec dt{ font-family:var(--hk-cond); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--hk-ink-3); }
.hk-spot__spec dd{ font-family:var(--hk-serif); font-size:19px; color:var(--hk-ink); margin:5px 0 0; }
.hk-spot__price-row{ display:flex; align-items:baseline; gap:16px; margin-bottom:30px; }
.hk-spot__price{ font-family:var(--hk-serif); font-size:40px; font-weight:500; color:var(--hk-ink); line-height:1; }
.hk-spot__price small{ font-size:20px; color:var(--hk-ink-2); }
.hk-spot__price-old{ font-size:20px; color:var(--hk-ink-3); text-decoration:line-through; font-family:var(--hk-serif); }
.hk-spot__save{ font-family:var(--hk-cond); font-size:12px; letter-spacing:.06em; color:#fff; background:var(--hk-red); padding:5px 11px; }
.hk-spot__actions{ display:flex; gap:14px; flex-wrap:wrap; }

/* ════════════════════════════════════════════════
   7) BESTSELLERY — taby + mřížka karet
   ════════════════════════════════════════════════ */
.hk-best{ padding:104px 0; background:var(--hk-bg-2); border-top:1px solid var(--hk-line); }
.hk-tabs{ display:flex; flex-wrap:wrap; gap:6px; justify-content:center; margin:0 auto 48px; border-bottom:1px solid var(--hk-line); }
.hk-tab{ font-family:var(--hk-cond); font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:var(--hk-ink-3); padding:14px 22px; background:none; border:none; cursor:pointer; position:relative; transition:color .25s; }
.hk-tab:hover{ color:var(--hk-ink); }
.hk-tab.is-on{ color:var(--hk-red); }
.hk-tab.is-on::after{ content:""; position:absolute; left:18%; right:18%; bottom:-1px; height:2px; background:var(--hk-red); }
.hk-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }

.hk-card{ position:relative; background:var(--hk-surface); border:1px solid var(--hk-line); border-radius:4px; overflow:hidden; display:flex; flex-direction:column; cursor:pointer; transition:transform .45s var(--hk-ease-lux), box-shadow .45s, border-color .3s; }
.hk-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:2px; z-index:4; background:linear-gradient(90deg,transparent,var(--hk-red),transparent); opacity:0; transition:opacity .4s; }
.hk-card:hover{ transform:translateY(-6px); border-color:var(--hk-red-line,rgba(216,69,59,.35)); box-shadow:0 24px 50px rgba(0,0,0,.5); }
.hk-card:hover::before{ opacity:1; }
.hk-card__media{ position:relative; aspect-ratio:1/1; overflow:hidden; background:#0E0B09; display:grid; place-items:center; }
.hk-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--hk-ease-lux); }
.hk-card:hover .hk-card__media img{ transform:scale(1.06); }
.hk-card__badge{ position:absolute; top:14px; left:14px; z-index:3; font-family:var(--hk-cond); font-size:10px; letter-spacing:.18em; text-transform:uppercase; font-weight:600; padding:5px 11px; }
.hk-card__badge--new{ background:var(--hk-ink); color:var(--hk-bg); }
.hk-card__badge--sale{ background:var(--hk-red); color:#fff; }
.hk-card__fav{ position:absolute; top:10px; right:10px; z-index:3; width:36px; height:36px; border-radius:50%; background:rgba(6,5,4,.55); border:1px solid var(--hk-line-strong); display:grid; place-items:center; cursor:pointer; transition:.2s; backdrop-filter:blur(4px); }
.hk-card__fav svg{ width:16px; height:16px; stroke:var(--hk-ink-2); fill:none; stroke-width:1.7; }
.hk-card__fav:hover{ border-color:var(--hk-red); } .hk-card__fav:hover svg{ stroke:var(--hk-red); }
.hk-card__add{ position:absolute; left:16px; right:16px; bottom:16px; z-index:3; background:#fff; color:var(--hk-bg); font-family:var(--hk-cond); font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:600; padding:12px; text-align:center; opacity:0; transform:translateY(12px); transition:.4s var(--hk-ease); }
.hk-card__add:hover{ background:var(--hk-red); color:#fff; }
.hk-card:hover .hk-card__add{ opacity:1; transform:none; }
.hk-card__body{ padding:20px; display:flex; flex-direction:column; flex:1; }
.hk-card__brand{ font-family:var(--hk-cond); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--hk-red); margin-bottom:6px; }
.hk-card__name{ font-family:var(--hk-serif); font-size:20px; line-height:1.22; color:var(--hk-ink); font-weight:500; transition:color .3s; }
.hk-card:hover .hk-card__name{ color:var(--hk-red-bright); }
.hk-card__var{ font-size:12.5px; color:var(--hk-ink-3); margin-top:6px; }
.hk-card__price-row{ display:flex; align-items:baseline; gap:11px; margin-top:auto; padding-top:16px; border-top:1px solid var(--hk-line); }
.hk-card__price{ font-family:var(--hk-serif); font-size:23px; font-weight:500; color:var(--hk-ink); line-height:1; }
.hk-card__price-old{ font-size:14px; color:var(--hk-ink-3); text-decoration:line-through; }
.hk-best__foot{ text-align:center; margin-top:56px; }

/* ════════════════════════════════════════════════
   8) RECENZE
   ════════════════════════════════════════════════ */
.hk-reviews{ padding:104px 0; background:var(--hk-bg); }
.hk-reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.hk-review{ position:relative; background:var(--hk-surface); border:1px solid var(--hk-line); border-radius:4px; padding:40px 34px; transition:transform .4s var(--hk-ease), border-color .3s; }
.hk-review:hover{ transform:translateY(-4px); border-color:var(--hk-line-strong); }
.hk-review__q{ position:absolute; top:18px; right:28px; font-family:var(--hk-serif); font-size:80px; line-height:1; color:var(--hk-red-soft); }
.hk-review__stars{ color:var(--hk-red); letter-spacing:3px; font-size:15px; margin-bottom:20px; }
.hk-review__text{ font-family:var(--hk-serif); font-style:italic; font-size:19px; line-height:1.6; color:var(--hk-ink); margin:0 0 28px; }
.hk-review__by{ display:flex; align-items:center; gap:14px; border-top:1px solid var(--hk-line); padding-top:22px; }
.hk-review__av{ width:46px; height:46px; border-radius:50%; background:var(--hk-surface-2); border:1px solid var(--hk-red-line,rgba(216,69,59,.35)); display:grid; place-items:center; font-family:var(--hk-serif); font-style:italic; font-size:18px; color:var(--hk-red); }
.hk-review__name{ font-size:14px; font-weight:600; color:var(--hk-ink); letter-spacing:.01em; }
.hk-review__role{ font-size:12px; color:var(--hk-ink-3); margin-top:2px; }

/* ════════════════════════════════════════════════
   9) NEWSLETTER
   ════════════════════════════════════════════════ */
.hk-news{ position:relative; background:#060504; border-top:1px solid var(--hk-line); padding:96px 0; overflow:hidden; }
.hk-news::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 120% at 50% 0%, rgba(216,69,59,.14), transparent 60%); }
.hk-news__inner{ position:relative; z-index:2; max-width:620px; margin:0 auto; text-align:center; }
.hk-news h2{ font-family:var(--hk-serif); font-size:clamp(2rem,3.4vw,2.8rem); color:var(--hk-ink); font-weight:500; margin:18px 0 14px; }
.hk-news h2 em{ font-style:italic; color:var(--hk-red); }
.hk-news p{ color:var(--hk-ink-2); font-size:15px; margin:0 0 32px; }
.hk-news__form{ display:flex; gap:10px; max-width:480px; margin:0 auto; }
.hk-news__form input{ flex:1; background:var(--hk-surface); border:1px solid var(--hk-line-strong); color:var(--hk-ink); font-family:var(--hk-sans); font-size:15px; padding:0 20px; height:54px; border-radius:2px; outline:none; transition:border-color .2s; }
.hk-news__form input::placeholder{ color:var(--hk-ink-3); }
.hk-news__form input:focus{ border-color:var(--hk-red); }
.hk-news__note{ font-size:12px; color:var(--hk-ink-3); margin-top:16px; }

/* ════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════ */
@media (max-width:1100px){
  .hk-cats__grid{ grid-template-columns:1fr 1fr; }
  .hk-cat--xl{ grid-column:span 2; grid-row:auto; min-height:300px; }
  .hk-grid{ grid-template-columns:repeat(3,1fr); }
  .hk-spot__stage{ gap:48px; }
}
@media (max-width:960px){
  .hk-usp__grid{ grid-template-columns:1fr 1fr; gap:24px 0; }
  .hk-usp__item:nth-child(3){ border-left:none; }
  .hk-guide__panel{ grid-template-columns:1fr; }
  .hk-guide__tabs{ flex-direction:row; overflow-x:auto; gap:6px; border-right:0; border-bottom:1px solid var(--hk-line); padding:10px; -webkit-overflow-scrolling:touch; }
  .hk-guide__tab{ flex:0 0 auto; border-left:0; border-bottom:3px solid transparent; border-radius:4px 4px 0 0; padding:12px 14px; }
  .hk-guide__tab.is-on{ border-left:0; border-bottom-color:var(--hk-red); }
  .hk-guide__tab-chev{ display:none; }
  .hk-guide__stage{ grid-template-columns:1fr; }
  .hk-guide__media{ min-height:300px; }
  .hk-spot__stage{ grid-template-columns:1fr; }
  .hk-spot__visual{ min-height:380px; }
  .hk-reviews__grid{ grid-template-columns:1fr; max-width:560px; margin:0 auto; }
  .hk-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  .hk-hero{ min-height:auto; padding:120px 0 80px; }
  .hk-hero__media{ background-position:65% center; }
  .hk-hero__media::after{ background:linear-gradient(0deg, var(--hk-bg) 8%, rgba(11,10,9,.7) 50%, rgba(11,10,9,.55) 100%); }
  .hk-hero__kanji{ display:none; }
  .hk-hero__cta .hk-btn{ flex:1; }
  .hk-cats{ padding:72px 0; }
  .hk-cats__grid{ grid-template-columns:1fr; grid-auto-rows:220px; }
  .hk-cat--xl{ grid-column:auto; min-height:280px; }
  .hk-spot,.hk-best,.hk-reviews{ padding:72px 0; }
  .hk-section-head{ margin-bottom:40px; }
}
@media (max-width:560px){
  .hk-usp__grid{ grid-template-columns:1fr; }
  .hk-usp__item{ border-left:none!important; padding:6px 0; }
  .hk-hero__stats{ flex-wrap:wrap; }
  .hk-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .hk-card__name{ font-size:18px; }
  .hk-guide__specs,.hk-spot__specs{ grid-template-columns:1fr; }
  .hk-news__form{ flex-direction:column; }
  .hk-news__form .hk-btn{ width:100%; }
  .hk-tabs{ flex-wrap:nowrap; overflow-x:auto; justify-content:flex-start; }
}
