/* ============================================================================
   HawaiiCards · Startseite V3 — Stylesheet (Produktion, konsolidiert)
   ----------------------------------------------------------------------------
   Eine Datei statt sechs Patch-Dateien. Kaskaden-Reihenfolge unveraendert
   (= abgenommener Look). Alle Bild-Slots sind echte <img> (.hc-img); die frueh.
   <image-slot>-Selektoren wurden auf img umgestellt.

   Inhalt:
     1  Schriften          5  Hero-Feinschliff
     2  Basis/Tokens/Theme 6  A11y-Politur
     3  Startseite-Module  7  Design-Verfeinerung
   ============================================================================ */


/* === 1 · Schriften (self-hosted, DSGVO) ===================================================== */
/* Self-hosted brand fonts (OFL) — DSGVO-konform, kein externer Aufruf */
@font-face{font-family:'Epilogue';font-style:normal;font-weight:400;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/epilogue-400.woff2') format('woff2');}
@font-face{font-family:'Epilogue';font-style:normal;font-weight:600;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/epilogue-600.woff2') format('woff2');}
@font-face{font-family:'Epilogue';font-style:normal;font-weight:700;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/epilogue-700.woff2') format('woff2');}
@font-face{font-family:'Epilogue';font-style:normal;font-weight:800;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/epilogue-800.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/spacegrotesk-400.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/spacegrotesk-500.woff2') format('woff2');}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/templates/HawaiiCards/startseite/startseite/assets/fonts/spacegrotesk-700.woff2') format('woff2');}


/* === 2 · Basis: Tokens, Themes, Grund-Layout ===================================================== */
/* ============================================================
   HAWAII CARDS — Design System (shared)
   Fonts: Epilogue (display) · Space Grotesk (body)
          → self-hosted via base64 in /templates/HawaiiCards/themes/hawaiicards/hawaiicards.css (LIVE)
          → NO @font-face / @import here (DSGVO: 0 calls to googleapis.com)
   Themes: midnight (default) · sunset · reef
   Palette: Brand-Book-Stand (Orange/Purple/Teal/Cream/Navy) — nicht zu verwechseln
            mit den Reef-Cyan-Werten aus dem Inventar-Dokument; maßgeblich ist das Brand-Book.
   ============================================================ */

:root{
  --font-display:'Epilogue', system-ui, sans-serif;
  --font-body:'Space Grotesk', system-ui, sans-serif;

  /* ---------- Brand-Inks · Single Source of Truth (siehe brand-book.html §Farben) ---------- */
  --brand-teal:#19c7b6;     /* Ozean-Teal */
  --brand-mint:#8fe9da;     /* Highlight-Mint */
  --brand-purple:#7b6cf0;   /* Sammler-Purple */
  --brand-orange:#ff8a1e;   /* Sonnenuntergangs-Orange */
  --brand-cream:#f7f0dc;    /* Sand-Cream */
  --brand-navy:#0c1e2a;     /* Tiefsee-Navy */

  /* radii / shadow / layout */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px; --r-pill:999px;
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- THEME: MIDNIGHT REEF (dark & premium) ---------- */
:root[data-theme="midnight"]{
  --bg:#070d14;
  --bg-grad: radial-gradient(120% 90% at 80% -10%, #103042 0%, rgba(16,48,66,0) 55%),
             radial-gradient(90% 70% at 5% 0%, #1a1340 0%, rgba(26,19,64,0) 50%),
             #070d14;
  --surface:#0e1a24;
  --surface-2:#13242f;
  --card:#101e29;
  --card-hi:#16293a;
  --border:rgba(255,255,255,.10);
  --border-soft:rgba(255,255,255,.06);
  --text:#eaf3f6;
  --muted:#9fb4c0;
  --dim:#6d8492;
  --primary:#ef820e;
  --primary-ink:#2a1100;
  --accent:#7b6cf0;
  --hot:#ff8a1e;
  --hot-2:#ff5d7a;
  --hero-grad: radial-gradient(85% 120% at 75% 0%, rgba(123,108,240,.45), rgba(123,108,240,0) 55%),
               radial-gradient(75% 110% at 10% 100%, rgba(30,199,182,.40), rgba(30,199,182,0) 55%),
               radial-gradient(60% 90% at 95% 95%, rgba(255,138,30,.32), rgba(255,138,30,0) 50%),
               linear-gradient(180deg,#080f17,#0a1622);
  --glow:0 0 0 1px rgba(239,130,14,.3), 0 22px 60px -20px rgba(239,130,14,.5);
  --hot-glow:0 18px 50px -16px rgba(255,138,30,.6);
  --ribbon: linear-gradient(90deg,#ef820e,#ff5d7a);
  --foil: conic-gradient(from 210deg at 50% 50%, #1ec7b6,#7b6cf0,#ff8a1e,#ff5d7a,#1ec7b6);
  --scheme:dark;
}

/* ---------- THEME: SUNSET ALOHA (tropical / vibrant) ---------- */
:root[data-theme="sunset"]{
  --bg:#120a1f;
  --bg-grad: radial-gradient(120% 95% at 85% -10%, #5a1d4e 0%, rgba(90,29,78,0) 55%),
             radial-gradient(95% 80% at 0% 0%, #3a1336 0%, rgba(58,19,54,0) 55%),
             #120a1f;
  --surface:#1d1130;
  --surface-2:#271542;
  --card:#1e1233;
  --card-hi:#2a1747;
  --border:rgba(255,255,255,.12);
  --border-soft:rgba(255,255,255,.07);
  --text:#fdeef2;
  --muted:#d2a8c4;
  --dim:#9a6f93;
  --primary:#ff8a1e;
  --primary-ink:#2a1100;
  --accent:#ff4d8d;
  --hot:#19c9b8;
  --hot-2:#ffd23f;
  --hero-grad: radial-gradient(80% 120% at 78% 0%, rgba(255,77,141,.5), rgba(255,77,141,0) 55%),
               radial-gradient(85% 120% at 12% 100%, rgba(25,201,184,.42), rgba(25,201,184,0) 52%),
               radial-gradient(70% 90% at 95% 92%, rgba(255,138,30,.55), rgba(255,138,30,0) 55%),
               linear-gradient(180deg,#15091f,#1d0c2a);
  --glow:0 0 0 1px rgba(255,138,30,.3), 0 22px 60px -18px rgba(255,77,141,.55);
  --hot-glow:0 18px 50px -16px rgba(25,201,184,.55);
  --ribbon: linear-gradient(90deg,#ff8a1e,#ff4d8d);
  --foil: conic-gradient(from 200deg at 50% 50%, #ff8a1e,#ff4d8d,#19c9b8,#ffd23f,#ff8a1e);
  --scheme:dark;
}

/* ---------- THEME: REEF LIGHT (clean / bright) ---------- */
:root[data-theme="reef"]{
  --bg:#f4f1e8;
  --bg-grad: radial-gradient(110% 80% at 85% -10%, #e4f6f2 0%, rgba(228,246,242,0) 55%),
             radial-gradient(80% 70% at 0% 0%, #eee7f7 0%, rgba(238,231,247,0) 55%),
             #f5f2ea;
  --surface:#ffffff;
  --surface-2:#fbf8f0;
  --card:#ffffff;
  --card-hi:#fbf8ef;
  --border:rgba(12,30,42,.12);
  --border-soft:rgba(12,30,42,.07);
  --text:#0c1e2a;
  --muted:#4d6470;
  --dim:#7d949f;
  --primary:#ef820e;
  --primary-ink:#2a1100;
  --accent:#6e5ce0;
  --hot:#ef820e;
  --hot-2:#ff5d7a;
  --hero-grad: radial-gradient(80% 120% at 78% 0%, rgba(110,92,224,.20), rgba(110,92,224,0) 55%),
               radial-gradient(85% 120% at 10% 100%, rgba(15,165,151,.22), rgba(15,165,151,0) 52%),
               radial-gradient(65% 90% at 96% 92%, rgba(239,130,14,.22), rgba(239,130,14,0) 55%),
               linear-gradient(180deg,#f3efe5,#ece6da);
  --glow:0 0 0 1px rgba(239,130,14,.25), 0 24px 60px -22px rgba(239,130,14,.3);
  --hot-glow:0 18px 50px -18px rgba(239,130,14,.45);
  --ribbon: linear-gradient(90deg,#ef820e,#ff5d7a);
  --foil: conic-gradient(from 210deg at 50% 50%, #0fa597,#6e5ce0,#ef820e,#ff5d7a,#0fa597);
  --scheme:light;
}

/* ============================================================
   BASE
   ============================================================ */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  background-image:var(--bg-grad);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.02;margin:0;letter-spacing:-.02em;}
p{margin:0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
section{position:relative;}

/* grain overlay */
.grain::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
:root[data-theme="reef"] .grain::before{mix-blend-mode:multiply;opacity:.35;}

/* ============================================================
   ATOMS
   ============================================================ */
.eyebrow{
  font-family:var(--font-body);font-weight:600;font-size:12px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--primary);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--primary);border-radius:2px;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-body);font-weight:700;font-size:15px;letter-spacing:.01em;
  padding:14px 26px;border-radius:var(--r-pill);transition:transform .2s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{background:var(--primary);color:var(--primary-ink);box-shadow:var(--glow);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px var(--primary), 0 26px 64px -18px var(--primary);}
.btn-hot{background:var(--hot);color:#1a0a00;box-shadow:var(--hot-glow);}
.btn-hot:hover{transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--text);box-shadow:inset 0 0 0 1.5px var(--border);}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--primary);color:var(--primary);}
.btn-block{width:100%;}
.btn-lg{padding:17px 32px;font-size:16px;}
.btn-sm{padding:10px 18px;font-size:13.5px;}

.chip{
  display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;
  padding:7px 13px;border-radius:var(--r-pill);background:var(--surface);
  box-shadow:inset 0 0 0 1px var(--border-soft);color:var(--muted);
}
.tag{
  font-family:var(--font-body);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 11px;border-radius:8px;color:#fff;
}
.tag-new{background:var(--primary);color:var(--primary-ink);}
.tag-sale{background:var(--hot);color:#1a0a00;}
.tag-pre{background:var(--accent);color:#fff;}

.kicker-pill{
  display:inline-flex;align-items:center;gap:9px;padding:8px 16px 8px 8px;border-radius:var(--r-pill);
  background:var(--surface);box-shadow:inset 0 0 0 1px var(--border);font-size:13px;font-weight:600;color:var(--muted);
  white-space:nowrap;max-width:100%;
}
.kicker-pill b{color:var(--text);}
.kicker-dot{width:9px;height:9px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px color-mix(in srgb, var(--primary) 25%, transparent);}

/* section heading block */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-bottom:38px;flex-wrap:wrap;}
.sec-head h2{font-size:clamp(28px,3.6vw,46px);}
.sec-head .lead{color:var(--muted);max-width:46ch;margin-top:14px;font-size:16px;}
.sec-link{font-weight:700;color:var(--primary);display:inline-flex;align-items:center;gap:8px;font-size:14.5px;white-space:nowrap;}
.sec-link svg{transition:transform .2s var(--ease);}
.sec-link:hover svg{transform:translateX(4px);}

/* card / product */
.card{
  background:var(--card);border-radius:var(--r-lg);box-shadow:inset 0 0 0 1px var(--border-soft);
  overflow:hidden;position:relative;transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}

/* holographic trading-card visual (placeholder art) */
.holo{
  position:relative;border-radius:18px;aspect-ratio:63/88;overflow:hidden;
  background:
    linear-gradient(150deg, rgba(255,255,255,.16), rgba(255,255,255,0) 40%),
    var(--foil);
  background-size:200% 200%;
  box-shadow:0 24px 60px -22px rgba(0,0,0,.7), inset 0 0 0 2px rgba(255,255,255,.25), inset 0 0 70px rgba(255,255,255,.12);
  animation:foilshift 9s linear infinite;
}
.holo::after{
  content:"";position:absolute;inset:8px;border-radius:12px;border:1.5px solid rgba(255,255,255,.35);
  background:radial-gradient(circle at 50% 35%, rgba(255,255,255,.35), rgba(255,255,255,0) 60%);
  mix-blend-mode:overlay;
}
@keyframes foilshift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* ===== product-tile hover: holographic "second image" crossfade (quick + premium) ===== */
.holo .holo-label{z-index:4;}
.prod .pim .holo{transition:transform .32s var(--ease);}
.prod:hover .pim .holo{transform:scale(1.05);}
.prod .pim .holo::before{
  content:"";position:absolute;inset:0;z-index:2;border-radius:inherit;pointer-events:none;
  opacity:0;transition:opacity .2s var(--ease);
  background:
    radial-gradient(130% 95% at 28% 16%, rgba(255,255,255,.6), rgba(255,255,255,0) 52%),
    repeating-linear-gradient(118deg, rgba(255,255,255,0) 0 6px, rgba(255,255,255,.18) 6px 9px),
    conic-gradient(from 210deg at 50% 50%, #ff5d7a, #ffd23f, #54e0ff, #b78bff, #ff8a3d, #ff5d7a);
  mix-blend-mode:screen;
}
.prod:hover .pim .holo::before{opacity:.9;}
@media (prefers-reduced-motion:reduce){
  .prod:hover .pim .holo{transform:none;}
  .prod .pim .holo::before{transition:none;}
}

/* utility */
.mono{font-family:var(--font-body);font-feature-settings:"tnum";}
.muted{color:var(--muted);}
.center{text-align:center;}
.divider{height:1px;background:var(--border-soft);width:100%;}
.glass{background:color-mix(in srgb, var(--surface) 72%, transparent);backdrop-filter:blur(14px) saturate(1.3);}

/* reveal: visible by default (bulletproof); subtle entrance only when JS confirms it's safe */
.reveal{opacity:1;transform:none;}
.anim-on .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);}
.anim-on .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.anim-on .reveal{opacity:1;transform:none;transition:none;} .holo{animation:none;}}

::selection{background:var(--primary);color:var(--primary-ink);}

/* instant theme switch — avoid transitions freezing at old color in this renderer */
html.theme-switching *{transition:none !important;}


/* === 3 · Startseite: Sektionen & Komponenten ===================================================== */
/* ============================================================
   index-v3.css — HawaiiCards Startseite V3 (Conversion-Funnel)
   ------------------------------------------------------------
   Token-basiert (var(--token, fallback)) — globale Tokens aus
   styles.css werden NICHT neu definiert. Reef-DNA bleibt.
   Mobile-first · Breakpoints 480 / 768 / 1024 / 1280.
   Interaktion CSS-only (Such-Panel via :focus-within, Swipe via
   scroll-snap). Bilder = <img>. Orange NUR für Kauf-CTAs.
   ============================================================ */

/* ---------- Basis / Reset für die V3-Seite ---------- */
.hc3{ background:var(--bg,#f4f1e8); background-image:var(--bg-grad); color:var(--text,#0c1e2a);
  font-family:var(--font-body,'Space Grotesk',system-ui,sans-serif); line-height:1.55;
  -webkit-font-smoothing:antialiased; overflow-x:clip; -webkit-tap-highlight-color:transparent; }
.hc3 *{ box-sizing:border-box; min-width:0; }
.hc3 img,.hc3 svg,.hc3 video{ max-width:100%; }
.hc3 img,.hc3 video{ height:auto; }
.hc3 h1,.hc3 h2,.hc3 h3,.hc3 h4{ font-family:var(--font-display,'Epilogue',sans-serif); font-weight:800;
  line-height:1.04; letter-spacing:-.02em; margin:0; }
.hc3 p{ margin:0; }
.hc3 a{ color:inherit; text-decoration:none; }
.hc3 button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
.hc3 input{ font-size:16px; } /* ≥16px → kein iOS-Zoom */
.hc3 .wrap{ width:100%; max-width:var(--maxw,1280px); margin:0 auto;
  padding-left:max(16px,env(safe-area-inset-left)); padding-right:max(16px,env(safe-area-inset-right)); }
@media(min-width:768px){ .hc3 .wrap{ padding-left:28px; padding-right:28px; } }

/* gemeinsame Sektions-Köpfe */
.hc3 .sec{ padding:46px 0; }
@media(min-width:768px){ .hc3 .sec{ padding:64px 0; } }
@media(min-width:1024px){ .hc3 .sec{ padding:80px 0; } }
.hc3 .sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px;
  flex-wrap:wrap; margin-bottom:26px; }
.hc3 .eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--primary,#ef820e); }
.hc3 .eyebrow::before{ content:""; width:7px; height:7px; border-radius:50%; background:currentColor; }
.hc3 .sec-head h2{ font-size:clamp(24px,4vw,40px); margin-top:12px; }
.hc3 .sec-head .lead{ color:var(--muted,#4d6470); font-size:clamp(14px,1.6vw,16px); max-width:52ch; margin-top:10px; }
.hc3 .sec-link{ font-weight:700; color:var(--primary,#ef820e); display:inline-flex; align-items:center;
  gap:7px; font-size:14px; white-space:nowrap; min-height:44px; }
.hc3 .sec-link svg{ transition:transform .2s var(--ease); }
.hc3 .sec-link:hover svg{ transform:translateX(4px); }

/* Buttons (Kauf = Orange, sekundär = Outline) */
.hc3 .btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  min-height:48px; padding:0 22px; border-radius:var(--r-pill,999px); font-weight:700; font-size:15px;
  transition:transform .18s var(--ease), box-shadow .2s; }
.hc3 .btn-buy{ background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100); box-shadow:var(--glow); }
.hc3 .btn-buy:hover{ transform:translateY(-2px); }
.hc3 .btn-ghost{ background:var(--surface,#fff); color:var(--text); box-shadow:inset 0 0 0 1.5px var(--border,rgba(12,30,42,.12)); }
.hc3 .btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--primary,#ef820e); color:var(--primary,#ef820e); }
.hc3 .btn-lg{ min-height:54px; padding:0 28px; font-size:16px; }

/* ============================================================
   HEADER  #hc-hd
   ============================================================ */
#hc-hd{ position:sticky; top:0; z-index:60; background:var(--bg,#f4f1e8); box-shadow:0 1px 0 var(--border-soft,rgba(12,30,42,.07)); }
#hc-hd .util{ background:var(--surface,#fff); box-shadow:inset 0 -1px 0 var(--border-soft); font-size:12.5px; font-weight:600; }
#hc-hd .util .wrap{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:12px; min-height:40px; }
#hc-hd .util a{ color:var(--muted); }
#hc-hd .util a:hover{ color:var(--primary,#ef820e); }
#hc-hd .util .u-ship{ color:var(--muted); justify-self:center; text-align:center; white-space:nowrap; }
#hc-hd .util .u-ship b{ color:var(--text); }
#hc-hd .util .u-left{ display:flex; gap:16px; justify-self:start; }
#hc-hd .util .u-right{ justify-self:end; display:flex; align-items:center; }
/* Hell/Dunkel-Umschalter */
#hc-hd .theme-tg{ display:inline-flex; align-items:center; gap:7px; min-height:30px; padding:5px 13px;
  border-radius:var(--r-pill,999px); background:var(--card-hi,#fbf8ef); box-shadow:inset 0 0 0 1px var(--border-soft);
  color:var(--text); font-family:var(--font-body); font-weight:700; font-size:12px; }
#hc-hd .theme-tg:hover{ box-shadow:inset 0 0 0 1.5px var(--primary,#ef820e); color:var(--primary,#ef820e); }
#hc-hd .theme-tg svg{ display:block; }
#hc-hd .theme-tg .ic-sun,#hc-hd .theme-tg .tg-light{ display:none; }
html[data-theme="midnight"] #hc-hd .theme-tg .ic-sun,
html[data-theme="midnight"] #hc-hd .theme-tg .tg-light,
html[data-theme="sunset"] #hc-hd .theme-tg .ic-sun,
html[data-theme="sunset"] #hc-hd .theme-tg .tg-light{ display:inline-flex; }
html[data-theme="midnight"] #hc-hd .theme-tg .ic-moon,
html[data-theme="midnight"] #hc-hd .theme-tg .tg-dark,
html[data-theme="sunset"] #hc-hd .theme-tg .ic-moon,
html[data-theme="sunset"] #hc-hd .theme-tg .tg-dark{ display:none; }
@media(max-width:767px){
  #hc-hd .util .wrap{ grid-template-columns:1fr auto; }
  #hc-hd .util .u-left{ display:none; }
  #hc-hd .util .u-ship{ justify-self:start; font-size:11.5px; }
  #hc-hd .theme-tg .tg-l{ display:none !important; }
  #hc-hd .theme-tg{ padding:6px 9px; }
}
/* sanfter Hell/Dunkel-Fade (nutzt theme-fade-v2.js → .hc-theme-anim) */
html.hc-theme-anim,
html.hc-theme-anim body,
html.hc-theme-anim .hc3 *{ transition:background-color .45s ease, color .35s ease,
  border-color .45s ease, box-shadow .45s ease, fill .45s ease !important; }
#hc-hd .bar{ display:grid; grid-template-columns:1fr minmax(0,540px) 1fr; grid-template-areas:"brand search acts"; align-items:center; gap:14px; padding:12px 0; }
#hc-hd .brand{ display:flex; align-items:center; gap:11px; flex:none; grid-area:brand; justify-self:start; }
#hc-hd .brand .logo{ height:42px; width:auto; flex:none; object-fit:contain; }
#hc-hd .brand .wm{ font-family:var(--font-display); font-weight:800; font-size:20px; line-height:.95; letter-spacing:-.02em; }
#hc-hd .brand .wm .c{ color:var(--hot,#ef820e); }
#hc-hd .brand .wm small{ display:block; font-family:var(--font-body); font-weight:600; font-size:9px; letter-spacing:.18em; color:var(--muted); margin-top:3px; }
@media(max-width:767px){ #hc-hd .brand .wm small{ display:none; } #hc-hd .brand .logo{ height:36px; width:auto; } }

/* starke Suche + CSS-Autocomplete (focus-within) */
#hc-hd .search{ position:relative; min-width:0; width:100%; max-width:540px; grid-area:search; justify-self:center; }
#hc-hd .search-pill{ display:flex; align-items:center; gap:10px; height:48px; padding:0 6px 0 18px;
  background:var(--surface,#fff); border-radius:var(--r-pill,999px); box-shadow:inset 0 0 0 1px var(--border-soft); }
#hc-hd .search-pill:focus-within{ box-shadow:inset 0 0 0 1.5px var(--primary,#ef820e); }
#hc-hd .search-pill input{ flex:1; min-width:0; background:none; border:none; outline:none; color:var(--text); }
#hc-hd .search-pill .go{ width:38px; height:38px; flex:none; border-radius:50%; background:var(--primary,#ef820e);
  color:var(--primary-ink,#2a1100); display:grid; place-items:center; }
#hc-hd .suggest{ position:absolute; left:0; right:0; top:calc(100% + 8px); z-index:30;
  background:var(--surface,#fff); border-radius:var(--r-lg,24px); box-shadow:0 30px 70px -30px rgba(0,0,0,.5), inset 0 0 0 1px var(--border-soft);
  padding:14px; opacity:0; visibility:hidden; transform:translateY(6px); transition:.18s var(--ease); }
#hc-hd .search:focus-within .suggest{ opacity:1; visibility:visible; transform:none; }
#hc-hd .suggest h5{ font-family:var(--font-body); font-weight:700; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--dim); margin:10px 8px 6px; }
#hc-hd .suggest h5:first-child{ margin-top:2px; }
#hc-hd .sug{ display:flex; align-items:center; gap:11px; padding:9px 10px; border-radius:10px; font-size:14px; font-weight:600; }
#hc-hd .sug:hover{ background:var(--card-hi,#fbf8ef); color:var(--primary,#ef820e); }
#hc-hd .sug .dot{ width:8px; height:8px; border-radius:50%; background:var(--brand-teal,#19c7b6); flex:none; }
#hc-hd .sug .tag{ margin-left:auto; font-size:11px; color:var(--dim); font-weight:600; }
@media(max-width:767px){
  #hc-hd .bar{ grid-template-columns:1fr auto; grid-template-areas:"brand acts" "search search"; row-gap:10px; }
  #hc-hd .search{ max-width:none; justify-self:stretch; }
}

#hc-hd .acts{ display:flex; align-items:center; gap:6px; flex:none; grid-area:acts; justify-self:end; }
#hc-hd .act{ display:flex; flex-direction:column; align-items:center; gap:3px; min-width:48px; min-height:48px;
  justify-content:center; padding:5px 8px; border-radius:12px; color:var(--text); position:relative; }
#hc-hd .act:hover{ color:var(--primary,#ef820e); background:var(--surface); }
#hc-hd .act .lbl{ font-size:10px; font-weight:600; }
#hc-hd .act .count{ position:absolute; top:0; right:4px; min-width:17px; height:17px; border-radius:9px;
  background:var(--hot,#ef820e); color:#fff; font-size:10px; font-weight:800; display:grid; place-items:center; padding:0 4px; }
#hc-hd .act-cart{ background:var(--primary,#ef820e); color:var(--primary-ink); flex-direction:row; gap:8px; padding:0 16px; border-radius:14px; box-shadow:var(--glow); }
#hc-hd .act-cart .lbl{ font-size:13px; font-weight:800; }
@media(max-width:1023px){ #hc-hd .act-konto,#hc-hd .act-merk .lbl,#hc-hd .act .lbl{ } }
@media(max-width:479px){ #hc-hd .act .lbl{ display:none; } }

/* Kategorie-Navleiste (Desktop) + Mega-Menü (CSS-only, hover/focus) */
#hc-hd .catnav{ background:#faf8f4; box-shadow:inset 0 1px 0 var(--border-soft), inset 0 -1px 0 var(--border-soft); }
html[data-theme="midnight"] #hc-hd .catnav,
html[data-theme="sunset"] #hc-hd .catnav{ background:color-mix(in srgb, var(--muted) 13%, var(--surface)); }
#hc-hd .catnav .wrap{ display:flex; gap:4px; min-height:50px; align-items:center; overflow-x:auto; overflow-y:visible; scrollbar-width:none; }
#hc-hd .catnav .wrap::-webkit-scrollbar{ display:none; }
#hc-hd .catnav .cn-left,#hc-hd .catnav .cn-right{ display:flex; align-items:center; gap:4px; }
#hc-hd .catnav .cn-right{ margin-left:auto; padding-left:10px; }
#hc-hd .catnav a{ white-space:nowrap; padding:0 11px; font-weight:600; font-size:13.5px; color:var(--text); min-height:44px; display:inline-flex; align-items:center; gap:4px; }
#hc-hd .catnav a:hover{ color:var(--primary,#ef820e); }
#hc-hd .catnav a.hot{ color:var(--hot-2,#ff5d7a); font-weight:700; }
#hc-hd .catnav .cn-right a{ color:var(--muted); font-weight:600; }
#hc-hd .catnav .cn-right a:hover{ color:var(--primary,#ef820e); }
#hc-hd .catnav .cn-right{ position:relative; }
#hc-hd .catnav .cn-right::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:1px; height:22px; background:var(--border-soft); }

/* Mega-Menü */
#hc-hd .catnav .cn-item{ position:relative; display:inline-flex; align-items:center; }
#hc-hd .catnav .cn-item .chev{ opacity:.55; transition:transform .2s var(--ease); }
#hc-hd .catnav .cn-mega{ position:absolute; left:0; top:100%; z-index:40; width:max-content; min-width:660px; max-width:840px;
  display:grid; grid-template-columns:auto 1fr; gap:20px; padding:18px;
  background:var(--surface,#fff); border-radius:var(--r-lg,24px);
  box-shadow:0 36px 80px -34px rgba(0,0,0,.55), inset 0 0 0 1px var(--border-soft);
  opacity:0; visibility:hidden; transform:translateY(8px); transition:.18s var(--ease); }
#hc-hd .catnav .cn-item:hover .cn-mega,
#hc-hd .catnav .cn-item:focus-within .cn-mega{ opacity:1; visibility:visible; transform:translateY(4px); }
#hc-hd .catnav .cn-item:hover .chev,
#hc-hd .catnav .cn-item:focus-within .chev{ transform:rotate(180deg); color:var(--primary,#ef820e); }
/* zwei QUADRATISCHE Set-Kacheln: links nächstes Set, rechts aktuelles Set → Landingpage */
#hc-hd .catnav .cn-sets{ display:grid; grid-template-columns:repeat(2,132px); gap:12px; align-content:start; }
#hc-hd .catnav .cn-set{ position:relative; aspect-ratio:1/1; display:block; border-radius:var(--r-md,16px);
  overflow:hidden; background:var(--hero-grad); box-shadow:inset 0 0 0 1px var(--border-soft); transition:.16s var(--ease); }
#hc-hd .catnav .cn-set:hover{ box-shadow:inset 0 0 0 1.6px var(--primary,#ef820e); transform:translateY(-2px); }
#hc-hd .catnav .cn-set img,#hc-hd .catnav .cn-set img{ position:absolute; inset:0; width:100%; height:100%; }
#hc-hd .catnav .cn-set::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg,rgba(8,14,22,.02),rgba(8,14,22,.52)); }
#hc-hd .catnav .cn-set .cn-set-cap{ position:absolute; left:9px; right:9px; bottom:8px; z-index:2;
  font-family:var(--font-display); font-weight:800; font-size:12px; line-height:1.1; color:#fff; text-shadow:0 2px 9px rgba(8,14,22,.75); }
#hc-hd .catnav .cn-set .cn-set-tag{ position:absolute; left:8px; top:8px; z-index:2; font-size:8.5px; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase; color:#fff; padding:3px 7px; border-radius:var(--r-pill,999px); }
#hc-hd .catnav .cn-set .cn-set-tag.pre{ background:var(--hot-2,#ff5d7a); }
#hc-hd .catnav .cn-set .cn-set-tag.now{ background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100); }
/* Kategorie-Block (Live-Filter) */
#hc-hd .catnav .cn-body{ min-width:0; display:flex; flex-direction:column; }
#hc-hd .catnav .cn-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
  padding:2px 4px 12px; border-bottom:1px solid var(--border-soft); margin-bottom:10px; }
#hc-hd .catnav .cn-head h4{ font-family:var(--font-display); font-weight:800; font-size:16px; color:var(--text); }
#hc-hd .catnav .cn-head p{ font-size:11.5px; color:var(--muted); margin-top:3px; }
#hc-hd .catnav .cn-all{ white-space:nowrap; padding:0; min-height:0; font-weight:800; font-size:12.5px; color:var(--primary,#ef820e); gap:5px; }
#hc-hd .catnav .cn-links2{ display:grid; grid-template-columns:repeat(var(--mc,2),minmax(120px,1fr)); gap:1px 12px; }
#hc-hd .catnav .cn-links2[data-cols="3"]{ --mc:3; }
#hc-hd .catnav .cn-links2 a{ display:flex; align-items:center; gap:8px; padding:7px 9px; min-height:34px;
  border-radius:9px; font-size:13px; font-weight:600; color:var(--text); }
#hc-hd .catnav .cn-links2 a:hover{ background:var(--card-hi,#fbf8ef); color:var(--primary,#ef820e); }
#hc-hd .catnav .cn-links2 .mdot{ width:6px; height:6px; border-radius:50%; background:var(--primary,#ef820e); opacity:.55; flex:0 0 auto; }

/* Touch / kleine Viewports: kein Hover-Menü, Leiste scrollt; Service-Trenner aus */
@media (max-width:1023px){
  #hc-hd .catnav .cn-mega{ display:none; }
  #hc-hd .catnav .cn-item .chev{ display:none; }
  #hc-hd .catnav .cn-right{ margin-left:0; }
  #hc-hd .catnav .cn-right::before{ display:none; }
}
/* Desktop: Leiste darf nicht clippen (Mega-Menü ragt heraus) UND alles in EINER Reihe */
@media (min-width:1024px){
  #hc-hd .catnav .wrap{ overflow:visible; flex-wrap:nowrap; }
  #hc-hd .catnav .cn-left{ flex-wrap:nowrap; }
}

/* (Alt-Hero entfernt 27.06. — durch 4-Slide-Slider ersetzt; nur Keyframes bleiben, da von .tm-art genutzt) */
@keyframes holo-sheen{ 0%{ background-position:16% 0%; } 50%{ background-position:84% 100%; } 100%{ background-position:16% 0%; } }

/* ============================================================
   USP-STRIP  #hc-usp  (wiederverwendbarer Badge)
   ============================================================ */
#hc-usp{ background:var(--surface,#fff); box-shadow:inset 0 1px 0 var(--border-soft), inset 0 -1px 0 var(--border-soft); }
#hc-usp .row{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px 16px; padding:18px 0; }
@media(min-width:768px){ #hc-usp .row{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:1024px){ #hc-usp .row{ grid-template-columns:repeat(5,1fr); } }
.hc-usp-item{ display:flex; align-items:center; gap:11px; padding:10px 8px; }
.hc-usp-item .ic{ width:38px; height:38px; flex:none; border-radius:11px; display:grid; place-items:center;
  background:color-mix(in srgb,var(--brand-teal,#19c7b6) 16%, transparent); color:var(--brand-teal,#19c7b6); }
.hc-usp-item b{ font-size:13.5px; display:block; }
.hc-usp-item span{ font-size:11.5px; color:var(--muted); }

/* ============================================================
   KATEGORIE-SCHNELLEINSTIEG  #hc-cats
   ============================================================ */
#hc-cats .cgrid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
@media(min-width:480px){ #hc-cats .cgrid{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:768px){ #hc-cats .cgrid{ grid-template-columns:repeat(4,1fr); } }
@media(min-width:1024px){ #hc-cats .cgrid{ grid-template-columns:repeat(6,1fr); } }
.hc-cat{ position:relative; display:flex; flex-direction:column; gap:10px; padding:16px; border-radius:var(--r-lg,24px);
  background:var(--surface,#fff); box-shadow:inset 0 0 0 1px var(--border-soft); transition:transform .25s var(--ease), box-shadow .25s; overflow:hidden; }
.hc-cat:hover{ transform:translateY(-4px); box-shadow:inset 0 0 0 1.5px var(--primary,#ef820e), 0 22px 44px -26px rgba(0,0,0,.4); }
.hc-cat .ic{ width:100%; aspect-ratio:1/1; border-radius:var(--r-md,16px); overflow:hidden; background:var(--surface-2,#fbf8f0); display:grid; place-items:center; }
.hc-cat .ic img{ width:100%; height:100%; display:block; }
.hc-cat b{ font-family:var(--font-display); font-weight:800; font-size:14px; }
.hc-cat span{ font-size:11.5px; color:var(--muted); }
.hc-cat.world{ background:linear-gradient(160deg, color-mix(in srgb,var(--c,#19c7b6) 16%, var(--surface)), var(--surface)); }
.hc-cat.world .ic{ background:color-mix(in srgb,var(--c,#19c7b6) 12%, var(--surface-2)); }
.hc-cat .pill{ position:absolute; top:12px; right:12px; font-size:9.5px; font-weight:800; letter-spacing:.06em; text-transform:uppercase;
  padding:4px 8px; border-radius:var(--r-pill,999px); background:var(--card-hi,#fbf8ef); color:var(--muted); box-shadow:inset 0 0 0 1px var(--border-soft); }
.hc-cat .pill.sale{ background:var(--hot-2,#ff5d7a); color:#fff; }
.hc-cat .pill.new{ background:var(--brand-teal,#19c7b6); color:#06201d; }

/* ============================================================
   TOP-MARKEN  #hc-cats .tmk  (3 Spalten · Hover-Center · zentrierte Logo-Tabs)
   ============================================================ */
#hc-cats .tmk{ display:grid; grid-template-columns:1fr; gap:16px; }
@media(min-width:1024px){ #hc-cats .tmk{ grid-template-columns:minmax(196px,.8fr) minmax(0,2.1fr) minmax(196px,.8fr); align-items:start; } }
#hc-cats .tmk-tabs{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(min-width:1024px){ #hc-cats .tmk-tabs{ grid-template-columns:1fr; justify-content:space-between; } }

.brand-tab{ position:relative; display:flex; flex-direction:column; align-items:center; text-align:center; gap:9px; padding:14px 12px; border-radius:18px;
  background:var(--surface,#fff); box-shadow:inset 0 0 0 1px var(--border-soft); transition:transform .2s var(--ease), box-shadow .2s; overflow:hidden; }
.brand-tab::before{ content:""; position:absolute; left:0; right:0; top:0; height:4px; background:var(--c,var(--primary,#ef820e)); opacity:0; transition:opacity .2s; }
.brand-tab:hover{ transform:translateY(-3px); box-shadow:inset 0 0 0 1.6px color-mix(in srgb, var(--c,var(--primary)) 72%, transparent), 0 18px 36px -24px rgba(0,0,0,.4); }
.brand-tab:hover::before{ opacity:1; }
.brand-tab .bt-logo{ width:56px; height:56px; flex:none; border-radius:15px; background:#fff; padding:9px; box-shadow:inset 0 0 0 1px var(--border-soft); }
.brand-tab .bt-logo img{ display:block; width:100%; height:100%; }
.brand-tab .bt-meta{ display:flex; flex-direction:column; gap:2px; }
.brand-tab b{ font-family:var(--font-display); font-weight:800; font-size:14.5px; line-height:1.1; }
.brand-tab .bt-meta span{ font-size:11px; color:var(--muted); }
@media(min-width:1024px){
  #hc-cats .tmk:not(:has(.brand-tab:hover)) .t-pkm{ box-shadow:inset 0 0 0 1.6px color-mix(in srgb,var(--c) 72%, transparent), 0 18px 36px -24px rgba(0,0,0,.4); transform:translateY(-3px); }
  #hc-cats .tmk:not(:has(.brand-tab:hover)) .t-pkm::before{ opacity:1; }
}

.tmk-panel{ display:none; background:var(--surface,#fff); border-radius:24px; padding:22px;
  box-shadow:inset 0 4px 0 var(--c,var(--primary,#ef820e)), inset 0 0 0 1px var(--border-soft); }
@media(min-width:1024px){
  #hc-cats .tmk-center{ position:relative; min-height:730px; }
  .tmk-panel{ display:flex; flex-direction:column; position:absolute; inset:0; opacity:0; visibility:hidden; transform:translateY(10px) scale(.99);
    transition:opacity .38s var(--ease), transform .38s var(--ease); }
  #hc-cats .tmk:not(:has(.brand-tab:hover)) .p-pkm,
  #hc-cats .tmk:has(.t-pkm:hover) .p-pkm,
  #hc-cats .tmk:has(.t-gd:hover) .p-gd,
  #hc-cats .tmk:has(.t-op:hover) .p-op,
  #hc-cats .tmk:has(.t-lor:hover) .p-lor,
  #hc-cats .tmk:has(.t-gp:hover) .p-gp,
  #hc-cats .tmk:has(.t-snaa:hover) .p-snaa,
  #hc-cats .tmk:has(.t-hobby:hover) .p-hobby,
  #hc-cats .tmk:has(.t-magic:hover) .p-magic,
  #hc-cats .tmk:has(.t-ygo:hover) .p-ygo,
  #hc-cats .tmk:has(.t-r2r:hover) .p-r2r{ opacity:1; visibility:visible; transform:none; }
}
@media(max-width:1023px){
  #hc-cats .tmk-tabs{ display:none; }
  #hc-cats .tmk-center{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding:2px 2px 8px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
  #hc-cats .tmk-center::-webkit-scrollbar{ display:none; }
  .tmk-panel{ display:block; flex:0 0 88%; scroll-snap-align:center; }
  @media(min-width:560px){ .tmk-panel{ flex-basis:62%; } }
}

.tmk-phead{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.tmk-phead .ph-logo{ width:58px; height:58px; flex:none; border-radius:14px; overflow:hidden; padding:9px; background:#fff; box-shadow:inset 0 0 0 1px var(--border-soft); }
.tmk-phead .ph-logo img{ display:block; width:100%; height:100%; }
.tmk-phead .ph-k{ font-size:10.5px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--c,var(--primary,#ef820e)); }
.tmk-phead h3{ font-family:var(--font-display); font-weight:800; font-size:21px; line-height:1.05; margin:3px 0; }
.tmk-phead .ph-sub{ font-size:12px; color:var(--muted); }
.tmk-phead .ph-all{ margin-left:auto; align-self:center; display:inline-flex; align-items:center; gap:7px; white-space:nowrap;
  font-weight:800; font-size:13px; color:#fff; background:var(--c,var(--primary,#ef820e)); padding:10px 16px; border-radius:var(--r-pill,999px);
  box-shadow:0 14px 28px -16px color-mix(in srgb,var(--c) 80%, #000); transition:transform .18s var(--ease); }
.tmk-phead .ph-all:hover{ transform:translateY(-2px); }
@media(max-width:479px){ .tmk-phead .ph-all .alltxt{ display:none; } .tmk-phead .ph-all{ padding:9px; } }

.tmk-prods{ display:grid; grid-template-columns:repeat(2,1fr); gap:11px; }
@media(min-width:1024px){ .tmk-prods{ grid-template-columns:repeat(4,1fr); flex:1; grid-auto-rows:1fr; } }
.tm-prod{ display:flex; flex-direction:column; background:var(--card,#fff); border-radius:16px; overflow:hidden;
  box-shadow:inset 0 0 0 1px var(--border-soft); transition:transform .22s var(--ease), box-shadow .22s; }
.tm-prod:hover{ transform:translateY(-5px); box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--c,var(--primary)) 65%, transparent), 0 26px 48px -28px rgba(0,0,0,.55); }
.tm-art{ position:relative; aspect-ratio:1/1; overflow:hidden;
  background:radial-gradient(120% 80% at 50% 12%, rgba(255,255,255,.5), transparent 55%), conic-gradient(from 215deg at 50% 42%, #ffd23f,#ff7a6b,#7b6cf0,#19c7b6,#ffd23f); }
.tm-art img{ position:absolute; inset:0; width:100%; height:100%; display:block; opacity:0; transition:opacity .45s var(--ease); }
.tm-art img:first-of-type{ opacity:1; }
.tm-art::after{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(115deg, transparent 35%, rgba(255,255,255,.55) 48%, transparent 62%); background-size:250% 250%; opacity:0; }
@media (prefers-reduced-motion: no-preference){ .tm-prod:hover .tm-art::after{ opacity:1; animation:holo-sheen 1.5s ease; } }
.tm-art .tm-fl{ position:absolute; left:0; right:0; bottom:0; z-index:3; padding:18px 12px 9px; color:#fff; font-family:var(--font-display); font-weight:800; font-size:14px; text-shadow:0 2px 8px rgba(0,0,0,.45); background:linear-gradient(0deg, rgba(0,0,0,.38), transparent); }
.tm-art .tm-badge{ position:absolute; top:9px; left:9px; z-index:3; font-size:10px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; padding:4px 8px; border-radius:7px; background:var(--navy,#0c1e2a); color:#fff; box-shadow:0 4px 10px -4px rgba(0,0,0,.5); }
.tm-art .tm-badge.sale{ background:var(--hot,#ef820e); }
.tm-art .tm-wish{ position:absolute; top:9px; right:9px; z-index:3; width:31px; height:31px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.85); color:var(--navy,#0c1e2a); box-shadow:0 4px 10px -4px rgba(0,0,0,.4); transition:.18s; }
.tm-art .tm-wish:hover{ background:#fff; color:var(--hot-2,#ff5d7a); transform:scale(1.1); }
.tm-pb{ padding:9px 10px 11px; display:flex; flex-direction:column; gap:4px; flex:1; }
.tm-cat{ font-size:9px; font-weight:800; letter-spacing:.07em; text-transform:uppercase; color:var(--c,var(--primary,#ef820e)); }
.tm-nm{ font-size:11.5px; font-weight:600; line-height:1.22; color:var(--text); }
.tm-row{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:8px; padding-top:5px; }
.tm-pr{ font-family:var(--font-display); font-weight:800; font-size:14px; }
.tm-pr .was{ font-size:10px; color:var(--dim); text-decoration:line-through; margin-left:3px; font-family:var(--font-body); font-weight:600; }
.tm-add{ width:33px; height:33px; flex:none; border-radius:10px; background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100); display:grid; place-items:center; box-shadow:var(--glow); transition:transform .18s; }
.tm-add:hover{ transform:scale(1.1) rotate(-6deg); }

/* ============================================================
   RELEASE / KAMPAGNE  #hc-release
   ============================================================ */
#hc-release .panel{ position:relative; overflow:hidden; border-radius:var(--r-xl,34px); padding:30px;
  display:grid; grid-template-columns:1fr; gap:24px; align-items:center;
  background:linear-gradient(135deg, color-mix(in srgb,var(--accent,#6e5ce0) 22%, var(--surface)), var(--surface)); box-shadow:inset 0 0 0 1px var(--border-soft); }
@media(min-width:768px){ #hc-release .panel{ grid-template-columns:1.1fr .9fr; padding:44px; } }
#hc-release .live{ display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--hot-2,#ff5d7a); }
#hc-release .live i{ width:9px; height:9px; border-radius:50%; background:var(--hot-2,#ff5d7a); box-shadow:0 0 0 0 color-mix(in srgb,var(--hot-2,#ff5d7a) 60%,transparent); animation:hc3pulse 1.6s infinite; }
@keyframes hc3pulse{ 0%{ box-shadow:0 0 0 0 color-mix(in srgb,var(--hot-2,#ff5d7a) 60%,transparent);} 70%{ box-shadow:0 0 0 12px transparent;} 100%{ box-shadow:0 0 0 0 transparent;} }
@media(prefers-reduced-motion:reduce){ #hc-release .live i{ animation:none; } }
#hc-release h2{ font-size:clamp(26px,3.6vw,40px); margin:14px 0 12px; }
#hc-release p{ color:var(--muted); font-size:16px; max-width:46ch; margin-bottom:20px; line-height:1.6; }
#hc-release .cta{ display:flex; gap:12px; flex-wrap:wrap; }
#hc-release .art{ position:relative; aspect-ratio:1/1; border-radius:var(--r-lg,24px); overflow:hidden; background:var(--surface-2,#fbf8f0); box-shadow:inset 0 0 0 1px var(--border-soft); }
#hc-release .art img{ width:100%; height:100%; display:block; }
#hc-release .preteaser{ margin-top:14px; display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:var(--r-md,16px);
  background:var(--card-hi,#fbf8ef); box-shadow:inset 0 0 0 1px var(--border-soft); font-size:13.5px; }
#hc-release .preteaser b{ color:var(--accent,#6e5ce0); }
#hc-release .preteaser a{ margin-left:auto; color:var(--primary,#ef820e); font-weight:700; white-space:nowrap; }

/* ============================================================
   PRODUKT-REIHEN (Bestseller/Neu/Sale/Für dich)  — Swipe via scroll-snap
   ============================================================ */
.hc-rail{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding:4px 2px 14px;
  scrollbar-width:none; -ms-overflow-style:none; -webkit-overflow-scrolling:touch; }
.hc-rail::-webkit-scrollbar{ display:none; }
.hc-rail > *{ scroll-snap-align:start; flex:0 0 78%; }
@media(min-width:480px){ .hc-rail > *{ flex:0 0 52%; } }
@media(min-width:768px){ .hc-rail > *{ flex:0 0 33%; } }
@media(min-width:1024px){ .hc-rail{ display:grid; grid-template-columns:repeat(4,1fr); overflow:visible; } .hc-rail > *{ flex:none; } }

/* Reihen-Navigation mit Pfeilen (z.B. #hc-new) */
.rail-nav{ position:relative; }
.head-right{ display:flex; align-items:center; gap:16px; flex:none; }
.rail-foot{ display:flex; justify-content:space-between; margin-top:16px; }
.rail-arrow{ width:44px; height:44px; flex:none; border-radius:50%; padding:0;
  background:var(--card,#fff); color:var(--text); cursor:pointer;
  display:grid; place-items:center;
  box-shadow:0 10px 26px -14px rgba(0,0,0,.5), inset 0 0 0 1px var(--border-soft);
  transition:transform .2s var(--ease), color .2s, opacity .2s, background .2s; }
.rail-arrow:hover{ transform:scale(1.08); color:var(--primary,#ef820e); border-color:var(--primary,#ef820e); }
.rail-arrow[disabled]{ opacity:.32; pointer-events:none; }
/* #hc-new bleibt auch auf Desktop eine scrollbare Reihe (genau 4 Karten sichtbar, Rest scrollt) */
#hc-new .hc-rail{ display:flex; flex-wrap:nowrap; grid-template-columns:none; overflow-x:auto; scroll-snap-type:x mandatory; }
#hc-new .hc-rail > *{ flex:0 0 calc((100% - 42px) / 4); scroll-snap-align:start; }
@media(max-width:1023px){
  #hc-new .hc-rail > *{ flex:0 0 calc((100% - 28px) / 2.2); }
}
@media(max-width:560px){
  #hc-new .hc-rail > *{ flex:0 0 80%; }
}

/* Produktkarte (wiederverwendbar) */
.hc-pcard{ display:flex; flex-direction:column; background:var(--card,#fff); border-radius:var(--r-lg,24px);
  box-shadow:inset 0 0 0 1px var(--border-soft); overflow:hidden; transition:transform .28s var(--ease), box-shadow .28s; }
.hc-pcard:hover{ transform:translateY(-5px); box-shadow:inset 0 0 0 1px var(--primary,#ef820e), 0 28px 56px -30px rgba(0,0,0,.6); }
.hc-pcard .pim{ position:relative; aspect-ratio:1/1; background:var(--surface-2,#fbf8f0); }
.hc-pcard .pim img{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.hc-pcard .badges{ position:absolute; top:10px; left:10px; display:flex; gap:6px; z-index:2; }
.hc-pcard .tag{ font-size:10px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; padding:4px 8px; border-radius:7px; }
.hc-pcard .tag.new{ background:var(--brand-teal,#19c7b6); color:#06201d; }
.hc-pcard .tag.sale{ background:var(--hot-2,#ff5d7a); color:#fff; }
.hc-pcard .tag.pre{ background:var(--accent,#6e5ce0); color:#fff; }
.hc-pcard .wish{ position:absolute; top:10px; right:10px; width:36px; height:36px; border-radius:50%; z-index:2;
  background:color-mix(in srgb,var(--bg,#fff) 70%,transparent); backdrop-filter:blur(6px); display:grid; place-items:center;
  color:var(--text); box-shadow:inset 0 0 0 1px var(--border-soft); }
.hc-pcard .wish:hover{ color:var(--hot-2,#ff5d7a); }
.hc-pcard .pb{ padding:14px; display:flex; flex-direction:column; gap:7px; flex:1; }
.hc-pcard .cat{ font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--primary,#ef820e); }
.hc-pcard .nm{ font-size:14px; font-weight:600; line-height:1.35; color:var(--text); overflow-wrap:break-word; }
.hc-pcard .rowend{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:6px; }
.hc-pcard .price{ font-family:var(--font-display); font-weight:800; font-size:19px; }
.hc-pcard .was{ font-size:12px; color:var(--dim); text-decoration:line-through; margin-left:5px; }
.hc-pcard .add{ width:44px; height:44px; flex:none; border-radius:12px; background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100);
  display:grid; place-items:center; box-shadow:var(--glow); transition:transform .2s; }
.hc-pcard .add:hover{ transform:scale(1.08) rotate(-6deg); }

/* Bewertungs-Stern (wiederverwendbar) */
.hc-stars{ display:inline-flex; gap:1px; color:var(--hot,#ef820e); font-size:12px; }
.hc-stars + .rv{ font-size:11.5px; color:var(--dim); font-weight:600; margin-left:6px; }

/* ============================================================
   MARKEN-RONDELL  #hc-brands
   ============================================================ */
/* Vertikales Marken-Akkordeon: hochkante Kacheln, inaktiv gedimmt, aktive schiebt auf */
#hc-brands .bacc{ display:flex; gap:12px; height:clamp(280px,40vw,360px); }
#hc-brands .bacc{ display:flex; gap:0; height:clamp(280px,40vw,360px); --sl:26px; border-radius:var(--r-lg,24px); overflow:hidden; }
.bpanel{ position:relative; flex:1 1 0; min-width:0; color:#fff; text-decoration:none;
  display:flex; flex-direction:column; justify-content:flex-end; padding:18px 18px 18px 26px;
  clip-path:polygon(var(--sl) 0, 100% 0, calc(100% - var(--sl)) 100%, 0 100%);
  transition:flex-grow .55s cubic-bezier(.55,.05,.1,1); }
.bpanel + .bpanel{ margin-left:calc(var(--sl) * -1); }
.bpanel:first-child{ clip-path:polygon(0 0, 100% 0, calc(100% - var(--sl)) 100%, 0 100%); }
.bpanel:last-child{ clip-path:polygon(var(--sl) 0, 100% 0, 100% 100%, 0 100%); }
/* Hintergrund-Ebene: Gradient = Platzhalter; später per --img:url(...) durch ein Bild ersetzbar. Nur diese Ebene dimmt. */
.bpanel .bg{ position:absolute; inset:0; z-index:-2; background-image:var(--img,var(--bg));
  background-size:cover; background-position:center;
  filter:saturate(.42) brightness(.52); transition:filter .45s ease; }
.bpanel::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(8,14,22,.02),rgba(8,14,22,.42)); transition:opacity .45s ease; }
.bpanel.is-active{ flex-grow:5; z-index:2; filter:drop-shadow(0 12px 26px rgba(8,14,22,.45)); }
.bpanel.is-active .bg{ filter:none; }
.bpanel.is-active::after{ opacity:.85; }

.bpanel .sw{ position:absolute; top:14px; left:var(--sl); width:40px; height:40px; flex:none; border-radius:12px;
  display:grid; place-items:center; color:#fff; font-family:var(--font-display); font-weight:800; font-size:15px; letter-spacing:-.3px;
  background:rgba(12,18,26,.42); backdrop-filter:blur(3px); box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.45), 0 4px 14px -4px rgba(0,0,0,.6);
  transition:left .45s ease; }
.bpanel:first-child .sw{ left:16px; }
.bpanel .vlabel{ position:absolute; left:50%; bottom:18px; transform:translateX(-50%) rotate(180deg);
  writing-mode:vertical-rl; white-space:nowrap; font-family:var(--font-display); font-weight:800;
  font-size:18px; letter-spacing:.4px; color:#fff; text-shadow:0 1px 10px rgba(8,14,22,.7), 0 0 2px rgba(8,14,22,.55); transition:opacity .3s ease; }
.bpanel .reveal{ display:flex; flex-direction:column; gap:5px; max-width:380px; color:#fff;
  text-shadow:0 1px 12px rgba(8,14,22,.65), 0 0 2px rgba(8,14,22,.5);
  opacity:0; transform:translateY(12px); pointer-events:none;
  transition:opacity .4s ease .08s, transform .45s ease .08s; }
.bpanel .reveal b{ font-family:var(--font-display); font-weight:800; font-size:clamp(22px,2.4vw,30px); line-height:1.04; }
.bpanel .reveal .pub{ font-size:11px; text-transform:uppercase; letter-spacing:.13em; opacity:.85; }
.bpanel .reveal .desc{ font-size:14px; line-height:1.4; opacity:.95; max-width:34ch; margin-top:5px; }
.bpanel .reveal .go{ display:inline-flex; align-items:center; gap:7px; align-self:flex-start; margin-top:12px;
  font-family:var(--font-display); font-weight:700; font-size:13.5px; padding:9px 16px; border-radius:999px;
  background:rgba(255,255,255,.18); box-shadow:inset 0 0 0 1px rgba(255,255,255,.3); }
.bpanel.is-active .vlabel{ opacity:0; }
.bpanel.is-active .reveal{ opacity:1; transform:none; }

@media(prefers-reduced-motion:reduce){ .bpanel{ transition:flex-grow .2s; } .bpanel .bg{ transition:none; } }
@media(max-width:560px){
  #hc-brands .bacc{ flex-direction:column; height:auto; gap:6px; overflow:visible; }
  .bpanel{ flex:0 0 auto; height:74px; justify-content:center; padding:14px 14px 14px 70px;
    clip-path:none; margin-left:0; border-radius:16px;
    transition:height .5s cubic-bezier(.55,.05,.1,1); }
  .bpanel.is-active{ height:210px; flex-grow:0; filter:none; }
  .bpanel .sw{ top:50%; left:14px; transform:translateY(-50%); }
  .bpanel.is-active .sw{ top:14px; left:14px; transform:none; }
  .bpanel .vlabel{ writing-mode:horizontal-tb; transform:none; left:76px; bottom:auto; top:50%;
    transform:translateY(-50%); }
  .bpanel.is-active .reveal{ padding-left:0; }
}

/* ============================================================
   THEMENWELTEN / BERATUNG  #hc-themen
   ============================================================ */
#hc-themen .tgrid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:768px){ #hc-themen .tgrid{ grid-template-columns:repeat(3,1fr); } }
.hc-theme{ position:relative; overflow:hidden; border-radius:var(--r-lg,24px); padding:24px; min-height:200px;
  display:flex; flex-direction:column; justify-content:flex-end; color:#fff; isolation:isolate;
  box-shadow:0 20px 50px -28px rgba(0,0,0,.6); }
.hc-theme::before{ content:""; position:absolute; inset:0; z-index:-2; background:var(--g,linear-gradient(150deg,#19c7b6,#0c1e2a)); }
.hc-theme::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(0,0,0,0) 34%, rgba(0,0,0,.32)); }
.hc-theme .k{ font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; opacity:.9; }
.hc-theme h3{ font-size:22px; margin:6px 0 6px; text-shadow:0 2px 10px rgba(0,0,0,.4); }
.hc-theme p{ font-size:13px; opacity:.96; margin-bottom:14px; text-shadow:0 1px 8px rgba(0,0,0,.35); }
.hc-theme .go{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:14px; min-height:44px; }
#hc-themen .finder{ margin-top:30px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; padding:20px 22px;
  border-radius:var(--r-lg,24px); background:var(--surface,#fff); box-shadow:inset 0 0 0 1px var(--border-soft); }
#hc-themen .finder b{ font-family:var(--font-display); font-size:17px; }
#hc-themen .finder p{ font-size:13.5px; color:var(--muted); flex:1; min-width:200px; }

/* ============================================================
   SALE / TOP DEALS  #hc-sale  (kompakt, wertig)
   ============================================================ */
#hc-sale .panel{ border-radius:var(--r-xl,34px); padding:24px; background:var(--surface,#fff); box-shadow:inset 0 0 0 1px var(--border-soft); }
@media(min-width:768px){ #hc-sale .panel{ padding:32px; } }
#hc-sale .top{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:20px; }
#hc-sale .top .eyebrow{ color:var(--hot-2,#ff5d7a); }
#hc-sale .top h2{ font-size:clamp(22px,3vw,32px); margin-top:8px; }

/* ============================================================
   COMMUNITY  #hc-community  (Community-Card wiederverwendbar)
   ============================================================ */
#hc-community .cgrid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:480px){ #hc-community .cgrid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ #hc-community .cgrid{ grid-template-columns:repeat(4,1fr); } }
.hc-ccard{ position:relative; overflow:hidden; border-radius:var(--r-lg,24px); padding:22px; color:#fff; min-height:180px;
  display:flex; flex-direction:column; justify-content:space-between; isolation:isolate; box-shadow:0 20px 50px -28px rgba(0,0,0,.6); }
.hc-ccard::before{ content:""; position:absolute; inset:0; z-index:-1; background:var(--g,linear-gradient(150deg,#5865F2,#23272A)); }
.hc-ccard .ic{ width:44px; height:44px; border-radius:13px; background:rgba(255,255,255,.16); display:grid; place-items:center; backdrop-filter:blur(4px); }
.hc-ccard h3{ font-size:19px; margin:14px 0 4px; }
.hc-ccard p{ font-size:12.5px; opacity:.9; }
.hc-ccard .go{ margin-top:12px; display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:13.5px; min-height:44px; }

/* ============================================================
   SOCIAL PROOF / REVIEWS  #hc-proof  (Struktur, KEINE Fake-Bewertungen)
   ============================================================ */
#hc-proof .top{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-bottom:22px; }
#hc-proof .score{ display:flex; align-items:center; gap:12px; }
#hc-proof .score .big{ font-family:var(--font-display); font-weight:800; font-size:40px; line-height:1; }
#hc-proof .score small{ color:var(--muted); font-size:13px; }
#hc-proof .rgrid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:768px){ #hc-proof .rgrid{ grid-template-columns:repeat(3,1fr); } }
.hc-review{ background:var(--surface,#fff); border-radius:var(--r-lg,24px); padding:22px; box-shadow:inset 0 0 0 1px var(--border-soft); }
.hc-review .ph{ color:var(--dim); font-size:13.5px; line-height:1.6; font-style:italic; }
.hc-review .who{ display:flex; align-items:center; gap:11px; margin-top:16px; }
.hc-review .av{ width:38px; height:38px; border-radius:50%; background:var(--card-hi,#fbf8ef); box-shadow:inset 0 0 0 1px var(--border-soft); display:grid; place-items:center; color:var(--dim); font-weight:800; }
.hc-review .who b{ font-size:13.5px; }
.hc-review .who span{ font-size:11.5px; color:var(--dim); }
#hc-proof .note{ margin-top:14px; font-size:12px; color:var(--dim); }

/* ============================================================
   CONTENT / BLOG  #hc-content
   ============================================================ */
#hc-content .bgrid{ display:grid; grid-template-columns:1fr; gap:16px; }
@media(min-width:768px){ #hc-content .bgrid{ grid-template-columns:repeat(3,1fr); } }
.hc-post{ display:flex; flex-direction:column; background:var(--card,#fff); border-radius:var(--r-lg,24px); overflow:hidden; box-shadow:inset 0 0 0 1px var(--border-soft); transition:transform .25s var(--ease); }
.hc-post:hover{ transform:translateY(-4px); }
.hc-post .im{ aspect-ratio:16/10; background:var(--surface-2,#fbf8f0); position:relative; }
.hc-post .im img{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.hc-post .pb{ padding:18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.hc-post .k{ font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--brand-teal,#19c7b6); }
.hc-post h3{ font-size:17px; line-height:1.25; }
.hc-post p{ font-size:13px; color:var(--muted); line-height:1.55; }
.hc-post .more{ margin-top:auto; padding-top:8px; color:var(--primary,#ef820e); font-weight:700; font-size:13.5px; }

/* ============================================================
   NEWSLETTER  #hc-nl
   ============================================================ */
#hc-nl .panel{ border-radius:var(--r-xl,34px); padding:36px 24px; text-align:center; background:var(--hero-grad); box-shadow:inset 0 0 0 1px var(--border-soft); }
@media(min-width:768px){ #hc-nl .panel{ padding:54px; } }
#hc-nl h2{ font-size:clamp(26px,3.6vw,42px); }
#hc-nl p{ color:var(--muted); max-width:48ch; margin:12px auto 24px; font-size:15px; }
#hc-nl form{ display:flex; gap:10px; max-width:480px; margin:0 auto; flex-wrap:wrap; }
#hc-nl input{ flex:1; min-width:200px; height:54px; border-radius:var(--r-pill,999px); border:none; background:var(--surface,#fff);
  box-shadow:inset 0 0 0 1px var(--border); padding:0 22px; color:var(--text); outline:none; }
#hc-nl input:focus{ box-shadow:inset 0 0 0 1.5px var(--primary,#ef820e); }
@media(max-width:479px){ #hc-nl form .btn{ width:100%; } }
#hc-nl .fine{ font-size:12px; color:var(--dim); margin-top:14px; }

/* ============================================================
   FOOTER  #hc-footer
   ============================================================ */
#hc-footer{ border-top:1px solid var(--border-soft); padding:50px 0 28px; }
#hc-footer .fgrid{ display:grid; grid-template-columns:1fr; gap:28px; }
@media(min-width:480px){ #hc-footer .fgrid{ grid-template-columns:1fr 1fr; } }
@media(min-width:1024px){ #hc-footer .fgrid{ grid-template-columns:1.6fr 1fr 1fr 1fr; } }
#hc-footer .fbrand p{ color:var(--muted); font-size:13.5px; max-width:34ch; line-height:1.6; margin:14px 0 16px; }
#hc-footer h5{ font-family:var(--font-body); font-weight:700; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); margin:0 0 14px; }
#hc-footer .fcol a{ display:block; color:var(--muted); font-size:14px; padding:6px 0; min-height:40px; }
#hc-footer .fcol a:hover{ color:var(--primary,#ef820e); }
#hc-footer .fbot{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  margin-top:36px; padding-top:22px; border-top:1px solid var(--border-soft); font-size:13px; color:var(--dim); }
#hc-footer .pays{ display:flex; gap:8px; flex-wrap:wrap; }
#hc-footer .pc{ height:28px; padding:0 10px; border-radius:7px; background:var(--surface,#fff); box-shadow:inset 0 0 0 1px var(--border-soft);
  display:grid; place-items:center; font-size:10.5px; font-weight:700; color:var(--muted); }

/* sanfter Theme-Fade nutzt vorhandenes theme-fade-v2.js (optional) */

/* ============================================================
   TOP-MARKEN ALT — asymmetrischer Zwei-Band-Split (#hc-cats .tmk2)
   ============================================================ */
#hc-cats .tmk2{ display:flex; flex-direction:column; gap:16px; }
#hc-cats .tmk2 .tmk2-band{ display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:1024px){
  #hc-cats .tmk2 .tmk2-band{ grid-template-columns:minmax(290px,1fr) 2.3fr; align-items:stretch; }
  #hc-cats .tmk2 .tmk2-band.rev{ grid-template-columns:2.3fr minmax(300px,1fr); }
  #hc-cats .tmk2 .tmk2-band.rev .tmk2-tabs{ order:2; }
  #hc-cats .tmk2 .tmk2-band.rev .tmk2-center{ order:1; }
}
#hc-cats .tmk2 .tmk2-tabs{ display:grid; grid-template-columns:1fr 1fr; gap:12px; align-content:start; }
#hc-cats .tmk2 .tmk2-center{ position:relative; }
#hc-cats .tmk2 .tmk-panel{ display:none; position:relative; inset:auto; opacity:1; visibility:visible; transform:none; }
#hc-cats .tmk2 .tmk2-band:not(:has(.brand-tab:hover)) .tmk2-center > .tmk-panel:first-child{ display:flex; flex-direction:column; }
#hc-cats .tmk2 .tmk2-band:has(.t-pkm:hover) .p-pkm,
#hc-cats .tmk2 .tmk2-band:has(.t-gd:hover) .p-gd,
#hc-cats .tmk2 .tmk2-band:has(.t-op:hover) .p-op,
#hc-cats .tmk2 .tmk2-band:has(.t-lor:hover) .p-lor,
#hc-cats .tmk2 .tmk2-band:has(.t-gp:hover) .p-gp,
#hc-cats .tmk2 .tmk2-band:has(.t-snaa:hover) .p-snaa,
#hc-cats .tmk2 .tmk2-band:has(.t-hobby:hover) .p-hobby,
#hc-cats .tmk2 .tmk2-band:has(.t-r2r:hover) .p-r2r{ display:flex; flex-direction:column; }
#hc-cats .tmk2 .tmk2-band:not(:has(.brand-tab:hover)) .tmk2-tabs .brand-tab:first-child{ box-shadow:inset 0 0 0 1.6px color-mix(in srgb,var(--c) 72%, transparent); transform:translateY(-3px); }
#hc-cats .tmk2 .tmk2-band:not(:has(.brand-tab:hover)) .tmk2-tabs .brand-tab:first-child::before{ opacity:1; }
#hc-cats .tmk2 .tmk-prods{ grid-template-columns:repeat(2,1fr); flex:none; grid-auto-rows:auto; }
@media(min-width:1024px){
  #hc-cats .tmk2 .tmk2-tabs{ grid-template-columns:1fr; grid-auto-rows:1fr; }
  #hc-cats .tmk2 .brand-tab{ flex-direction:row; align-items:center; text-align:left; gap:14px; padding:14px 18px; }
  #hc-cats .tmk2 .brand-tab::before{ left:0; right:auto; top:0; bottom:0; width:4px; height:auto; }
  #hc-cats .tmk2 .brand-tab .bt-logo{ width:52px; height:52px; }
  #hc-cats .tmk2 .tmk2-center{ display:flex; }
  #hc-cats .tmk2 .tmk-panel{ flex:1; }
  #hc-cats .tmk2 .tmk-prods{ grid-template-columns:repeat(4,1fr); flex:1; grid-auto-rows:1fr; }
}
@media(max-width:1023px){
  #hc-cats .tmk2 .tmk2-center{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
  #hc-cats .tmk2 .tmk2-center::-webkit-scrollbar{ display:none; }
  #hc-cats .tmk2 .tmk-panel{ display:flex; flex-direction:column; flex:0 0 88%; scroll-snap-align:center; }
}

/* ============================================================
   #hc-themen — Produkt-Konfigurator (unter den 3 Themen-Kacheln)
   ============================================================ */
#hc-themen .hc-konfig{ margin-top:14px; background:var(--surface,#fff); border-radius:var(--r-xl,34px);
  box-shadow:inset 0 0 0 1px var(--border-soft), 0 30px 70px -40px rgba(0,0,0,.5); padding:clamp(20px,3vw,34px); }
#hc-themen .hc-konfig .kf-head{ margin-bottom:18px; }
#hc-themen .hc-konfig .kf-head h3{ font-family:var(--font-display); font-weight:800; font-size:clamp(20px,2.4vw,28px);
  letter-spacing:-.02em; margin-top:6px; }
#hc-themen .hc-konfig .kf-head p{ color:var(--muted); font-size:14.5px; margin-top:6px; max-width:56ch; }
#hc-themen .hc-konfig .kf-grid{ display:grid; grid-template-columns:1fr; gap:16px; }
@media(min-width:760px){ #hc-themen .hc-konfig .kf-grid{ grid-template-columns:repeat(3,1fr); gap:22px; } }
#hc-themen .hc-konfig .kf-lbl{ display:flex; align-items:center; gap:8px; font-weight:700; font-size:13px;
  color:var(--text); margin-bottom:10px; }
#hc-themen .hc-konfig .kf-lbl i{ display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px;
  border-radius:999px; background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100); font-style:normal;
  font-weight:800; font-size:12px; }
#hc-themen .hc-konfig .kf-chips{ display:flex; flex-wrap:wrap; gap:8px; }
#hc-themen .hc-konfig .kf-chip{ appearance:none; cursor:pointer; font:inherit; font-weight:600; font-size:13.5px;
  padding:9px 14px; min-height:40px; border-radius:var(--r-pill,999px); color:var(--text);
  background:var(--card-hi,#fbf8ef); border:1.5px solid var(--border-soft); transition:.16s var(--ease); }
#hc-themen .hc-konfig .kf-chip:hover{ border-color:var(--primary,#ef820e); transform:translateY(-1px); }
#hc-themen .hc-konfig .kf-chip.is-sel{ background:var(--primary,#ef820e); color:var(--primary-ink,#2a1100);
  border-color:var(--primary,#ef820e); box-shadow:var(--glow); }
#hc-themen .hc-konfig .kf-result{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  gap:16px; margin-top:22px; padding-top:20px; border-top:1px solid var(--border-soft); }
#hc-themen .hc-konfig .kf-rk{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.12em;
  text-transform:uppercase; color:var(--dim); margin-bottom:3px; }
#hc-themen .hc-konfig .kf-rsum{ font-family:var(--font-display); font-weight:800; font-size:clamp(16px,2vw,21px);
  letter-spacing:-.01em; color:var(--text); }
#hc-themen .hc-konfig #kfGo[aria-disabled="true"]{ opacity:.45; pointer-events:none; }


/* === 5 · A11y-Politur (Fokus, Touch-Targets) ===================================================== */
/* ============================================================
   POLISH — UX/A11y-Feinschliff (ui-ux-pro-max-Audit, 24.06.2026)
   Marken-sicher: nutzt nur bestehende Tokens, ändert keine Farben/Fonts.
   Override nach hero-final.css.
   ============================================================ */

/* 1) Such-Button auf ≥44×44 px (war 38 — Touch-Target-Regel) */
#hc-hd .search .go,
#hc-hd .go{ width:44px; height:44px; min-width:44px; min-height:44px; }

/* 2) Konsistenter, sichtbarer Fokus-Ring (Tastatur-A11y) in Markenfarbe */
#hc-hd a:focus-visible, #hc-hd button:focus-visible, #hc-hd input:focus-visible,
.sec a:focus-visible, .sec button:focus-visible, .sec input:focus-visible,
#hc-footer a:focus-visible, #hc-footer button:focus-visible,
.kf-chip:focus-visible, .cn-set:focus-visible{
  outline:2px solid var(--primary,#ef820e);
  outline-offset:2px;
  border-radius:6px;
}

/* 3) Mobile: kleine Text-Links in Util-Bar & Footer bekommen tippbare Höhe */
@media (max-width:767px){
  #hc-hd .util a{ display:inline-flex; align-items:center; min-height:40px; }
  #hc-footer .fcol a{ display:inline-flex; align-items:center; min-height:40px; }
}

/* 4) Bild-Slots: weicher Lade-Übergang, kein harter Pop-in */


/* === 6 · Design-Verfeinerung (Elevation, Akzente, Badges) ===================================================== */
/* ============================================================
   OPTIMIZE — Design-Optimierungs-Layer (ui-ux-pro-max + frontend-design)
   Eingriffstiefe: großer Pass · Brand-Spielraum: Akzente erlaubt (Reef bleibt)
   ABSCHALTBAR: einfach diesen <link> entfernen → Ausgangszustand zurück.
   Nutzt nur bestehende Tokens + abgeleitete Akzente. Keine neuen Fonts/Kernfarben.
   24.06.2026
   ============================================================ */

/* ---- 1) Einheitliche Elevation-Skala (Dimensional Layering, 4 Stufen) ---- */
:root{
  --el-1: 0 1px 3px rgba(12,30,42,.08);
  --el-2: 0 6px 16px -8px rgba(12,30,42,.18);
  --el-3: 0 18px 38px -20px rgba(12,30,42,.30);
  --el-4: 0 34px 70px -34px rgba(12,30,42,.46);
  --accent-line: linear-gradient(90deg, var(--brand-teal,#19c7b6), var(--primary,#ef820e));
}

/* ---- 2) Signature-Akzent: Eyebrow mit Marken-Verlaufsstrich (teal→orange) ---- */
.sec .eyebrow::before, #hc-hero .eyebrow::before{
  background: var(--accent-line) !important; height:3px !important; border-radius:999px;
}
.sec-head h2, #hc-hero h1{ letter-spacing:-.025em; }

/* ---- 4) PRODUKTKARTEN (Rondell #hc-new, #hc-foryou, #hc-sale) ---- */
.hc-pcard{ box-shadow: var(--el-2), inset 0 0 0 1px var(--border-soft); transition: transform .22s var(--ease,ease), box-shadow .22s var(--ease,ease); }
.hc-pcard:hover{ transform:translateY(-6px); box-shadow: var(--el-4), inset 0 0 0 1.5px var(--primary,#ef820e); }
.hc-pcard .price{ font-size:20px; letter-spacing:-.01em; }
.hc-pcard .badges .tag.sale,.hc-pcard .tag.sale{ background:linear-gradient(135deg,#ff5d7a,#e0322a); }
.hc-pcard .badges .tag.new,.hc-pcard .tag.new{ background:linear-gradient(135deg,var(--brand-teal,#19c7b6),#0e9d8f); color:#fff; }
.hc-pcard .add{ transition:transform .18s var(--ease,ease), box-shadow .18s; }
.hc-pcard .add:hover{ transform:translateY(-1px) scale(1.08) rotate(-6deg); box-shadow:0 12px 24px -10px rgba(239,130,14,.8); }
.hc-pcard .wish{ transition:transform .18s, color .18s; }
.hc-pcard .wish:hover{ transform:scale(1.12); }

/* Marken-Akkordeon-Produkte (tm-prod) konsistent mit gleicher Tiefe */
.tm-prod{ box-shadow: var(--el-2), inset 0 0 0 1px var(--border-soft); }
.tm-prod:hover{ box-shadow: var(--el-4), inset 0 0 0 1.5px color-mix(in srgb,var(--c,var(--primary)) 70%, transparent); }

/* ---- 5) KONFIGURATOR: klarere Auswahl + Micro-Interaktion ---- */
#hc-themen .hc-konfig{ box-shadow: var(--el-3), inset 0 0 0 1px var(--border-soft); }
#hc-themen .hc-konfig .kf-chip{ transition: all .18s var(--ease,ease); }
#hc-themen .hc-konfig .kf-chip:hover{ transform:translateY(-2px); box-shadow: var(--el-2); }
#hc-themen .hc-konfig .kf-chip.is-sel{ box-shadow: 0 0 0 1px var(--primary,#ef820e), 0 10px 22px -10px rgba(239,130,14,.6); }
#hc-themen .hc-konfig #kfGo{ box-shadow: 0 14px 30px -14px rgba(239,130,14,.7); }

/* ---- 6) THEMENWELTEN-Kacheln: mehr Tiefe + sauberer Hover ---- */
#hc-themen .hc-theme{ box-shadow: var(--el-3); transition: transform .24s var(--ease,ease), box-shadow .24s; position:relative; overflow:hidden; }
#hc-themen .hc-theme::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%, rgba(8,14,22,.28)); opacity:.7; transition:opacity .24s; }
#hc-themen .hc-theme:hover{ transform:translateY(-5px); box-shadow: var(--el-4); }
#hc-themen .hc-theme:hover::after{ opacity:.45; }
#hc-themen .hc-theme > *{ position:relative; z-index:1; }

/* ---- 7) Community + Sale: gleiche Elevation für Gesamt-Konsistenz ---- */
#hc-community .hc-ccard{ box-shadow: var(--el-3); transition: transform .24s var(--ease,ease), box-shadow .24s; }
#hc-community .hc-ccard:hover{ transform:translateY(-5px); box-shadow: var(--el-4); }
#hc-sale .panel{ box-shadow: var(--el-3), inset 0 0 0 1px var(--border-soft); }

/* ---- 8) USP-Strip + Marken-Rondell-Chips: dezente Hebung ---- */
#hc-usp .u{ transition: transform .2s var(--ease,ease); }
#hc-usp .u:hover{ transform:translateY(-2px); }

/* ---- 9) Reduced Motion respektieren (überschreibt die Lifts) ---- */
@media (prefers-reduced-motion: reduce){
  .hc-pcard:hover,.tm-prod:hover,#hc-themen .hc-theme:hover,#hc-community .hc-ccard:hover,
  #hc-hero .btn-buy:hover,#hc-themen .hc-konfig .kf-chip:hover,#hc-usp .u:hover{ transform:none; }
}

/* ===== Trust-Strip #hc-usp deutlich flacher (Marcel 25.06.: zu hoch) ===== */
#hc-usp .row{ padding:8px 0; gap:2px 16px; }
.hc-usp-item{ padding:4px 8px; gap:9px; }
.hc-usp-item .ic{ width:30px; height:30px; border-radius:9px; }
.hc-usp-item b{ font-size:13px; }
.hc-usp-item span{ font-size:11px; }

/* ===================== HERO-SLIDER (4 Banner) — 2026-06-26 ===================== */
/* ============================================================================
   HawaiiCards · Hero-Banner-Slider (4 Slides) — #hc-hero
   Quelle: Hero-Slider/_DEPLOY_4-Slider · 26.06.2026
   Scope: ALLES unter #hc-hero. Keine globalen Selektoren. In custom.css anhängen.
   Canvas-Referenz 1920×664, Skalierung via Container-Queries (cqw), kein Layout-JS.
   ============================================================================ */
/* Reset der alten V3-Hero-Basis (#hc-hero hatte padding + ::before-Gradient),
   damit die neue Bühne bündig sitzt. Diese Regeln laden zuletzt → gewinnen. */
#hc-hero{padding:0!important;overflow:visible;background:none;}
#hc-hero::before{display:none!important;}

#hc-hero{container-type:inline-size;display:block;width:100%;margin:0 0 18px;}
#hc-hero *{box-sizing:border-box;}

/* Bühne: festes 1920/664-Seitenverhältnis, Slides liegen darin gestapelt */
#hc-hero .hc-stage{position:relative;width:100%;aspect-ratio:1920/664;overflow:hidden;
  border-radius:16px;background:#0a141d;box-shadow:0 24px 60px rgba(8,18,28,.4);}

/* Slide = ein vollständiger 4-Layer-Banner, Cross-Fade über opacity */
#hc-hero .hc-slide{position:absolute;inset:0;opacity:0;visibility:hidden;
  transition:opacity .32s ease, visibility 0s linear .32s;z-index:0;}
#hc-hero .hc-slide.is-active{opacity:1;visibility:visible;z-index:1;
  transition:opacity .32s ease;}

/* ── Layer ① Full-Bleed BG (cover) ───────────────────────────────────────── */
#hc-hero .hc-l1{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
#hc-hero .hc-vig{position:absolute;inset:0;z-index:1;pointer-events:none;}

/* ── Layer ② Animation (screen-Blend über ①) ─────────────────────────────── */
#hc-hero .hc-l2{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;
  mix-blend-mode:screen;opacity:.9;}
#hc-hero .hc-l2-vid{z-index:3;}
#hc-hero .hc-dim{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(0deg, rgba(7,15,24,.34), rgba(7,15,24,.26));}

/* ── Links-Scrim (Lesbarkeit) — Breite/Farbe je Slide überschrieben ───────── */
#hc-hero .hc-scrim{position:absolute;left:0;top:0;width:54%;height:100%;z-index:3;pointer-events:none;}

/* ── Layer ③ Content (Text/Buttons) — Basis ──────────────────────────────── */
#hc-hero .hc-content{position:absolute;left:19.17%;top:19.88%;width:28.75%;z-index:5;color:#fff;
  font-family:'Inter','Space Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;}
#hc-hero .hc-badge{display:inline-block;background:#19c7b6;color:#062a26;font-weight:800;
  text-transform:uppercase;letter-spacing:.09em;font-size:clamp(9px,.68cqw,13px);
  padding:.55em 1.2em;border-radius:999px;margin-bottom:1.7em;}
#hc-hero .hc-eyebrow{font-size:clamp(10px,.7cqw,15px);font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:#ef820e;margin:0 0 1.15em;}
#hc-hero .hc-h1{font-size:clamp(26px,3.125cqw,60px);line-height:1.04;font-weight:800;
  letter-spacing:-.022em;margin:0;text-shadow:0 2px 28px rgba(0,0,0,.45);
  font-family:'Epilogue','Oswald',system-ui,sans-serif;}
#hc-hero .hc-sub{font-size:clamp(12px,1cqw,20px);line-height:1.6;margin:1.35em 0 0;max-width:24em;
  color:#e8eef2;text-shadow:0 1px 14px rgba(0,0,0,.5);}
#hc-hero .hc-cta{display:flex;gap:.8em;margin-top:2.05em;flex-wrap:wrap;}
#hc-hero .hc-btn{font-size:clamp(12px,.86cqw,17px);font-weight:800;border-radius:999px;
  padding:.85em 1.5em;text-decoration:none;display:inline-flex;align-items:center;gap:.5em;
  cursor:pointer;border:none;line-height:1;}
#hc-hero .hc-primary{background:linear-gradient(180deg,#ffa24d,#fc6e3b);color:#fff;
  box-shadow:0 12px 28px rgba(252,110,59,.5);}
#hc-hero .hc-ghost{background:rgba(255,255,255,.94);color:#0c1e2a;}

/* ── Layer ④ Produkt-Cluster (contain) — Zone je Slide überschrieben ──────── */
#hc-hero .hc-product{position:absolute;left:49%;top:14%;width:50%;height:74%;z-index:6;
  display:flex;align-items:center;justify-content:center;}
#hc-hero .hc-glow{position:absolute;width:92%;height:70%;border-radius:50%;z-index:0;filter:blur(22px);
  background:radial-gradient(closest-side, rgba(255,184,92,.32), rgba(25,199,182,.15) 55%, transparent 73%);}
#hc-hero .hc-product img{position:relative;z-index:1;max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  filter:drop-shadow(0 16px 28px rgba(0,0,0,.5)) drop-shadow(0 0 48px rgba(3,9,15,.5));}

/* ========================================================================== */
/* SLIDE 1 · Startseite „Sammle. Spiele. Baue." */
/* ========================================================================== */
#hc-hero .hc-slide--startseite .hc-vig{
  background:radial-gradient(125% 105% at 50% 46%, transparent 42%, rgba(10,22,34,.30) 100%);}
#hc-hero .hc-slide--startseite .hc-scrim{width:54%;
  background:linear-gradient(100deg, rgba(6,14,22,.74) 0%, rgba(6,14,22,.50) 36%, rgba(6,14,22,.14) 62%, transparent 82%);}
#hc-hero .hc-slide--startseite .hc-content{left:19.17%;top:19.88%;width:28.75%;color:#fff;}
#hc-hero .hc-slide--startseite .hc-eyebrow{color:#ef820e;}
#hc-hero .hc-slide--startseite .hc-h1 .o{color:#fc6e3b;}
#hc-hero .hc-slide--startseite .hc-h1 .t{color:#19c7b6;}
#hc-hero .hc-slide--startseite .hc-product{left:49%;top:14%;width:50%;height:74%;}

/* ========================================================================== */
/* SLIDE 2 · Pokémon „Wachsendes Chaos" */
/* ========================================================================== */
#hc-hero .hc-slide--pokemon .hc-vig{
  background:radial-gradient(125% 110% at 66% 32%, transparent 38%, rgba(2,10,16,.46) 100%);}
#hc-hero .hc-slide--pokemon .hc-scrim{width:55%;
  background:linear-gradient(100deg, rgba(2,12,18,.84) 0%, rgba(2,12,18,.58) 36%, rgba(2,12,18,.18) 62%, transparent 82%);}
#hc-hero .hc-slide--pokemon .hc-content{left:19.17%;top:18.5%;width:30%;color:#e6fbff;}
#hc-hero .hc-slide--pokemon .hc-eyebrow{color:#fcd34d;font-weight:700;letter-spacing:.2em;margin-bottom:1.05em;}
#hc-hero .hc-slide--pokemon .hc-h1{font-size:clamp(27px,3.35cqw,64px);line-height:1.0;font-weight:700;
  letter-spacing:.005em;text-transform:uppercase;font-family:'Oswald','Epilogue',system-ui,sans-serif;}
#hc-hero .hc-slide--pokemon .hc-h1 .a{color:#a5f3fc;}
#hc-hero .hc-slide--pokemon .hc-h1 .c{color:#fb7185;}
#hc-hero .hc-slide--pokemon .hc-sub{color:#cfe8ef;line-height:1.55;margin-top:1.25em;}
#hc-hero .hc-slide--pokemon .hc-cta{gap:.75em;margin-top:1.9em;}
#hc-hero .hc-slide--pokemon .hc-primary{background:linear-gradient(180deg,#ff8a4c,#FF6A2C);
  box-shadow:0 12px 28px rgba(255,106,44,.5);}
#hc-hero .hc-slide--pokemon .hc-ghost{background:rgba(230,251,255,.94);color:#03161c;}
#hc-hero .hc-slide--pokemon .hc-product{left:54%;top:6%;width:34%;height:90%;}

/* ========================================================================== */
/* SLIDE 3 · One Piece OP16 „The Time of Battle" */
/* ========================================================================== */
#hc-hero .hc-slide--onepiece .hc-vig{
  background:radial-gradient(120% 110% at 60% 34%, transparent 36%, rgba(6,3,4,.5) 100%);}
#hc-hero .hc-slide--onepiece .hc-scrim{width:55%;
  background:linear-gradient(100deg, rgba(6,3,4,.86) 0%, rgba(6,3,4,.60) 36%, rgba(6,3,4,.18) 62%, transparent 82%);}
#hc-hero .hc-slide--onepiece .hc-content{left:19.17%;top:18%;width:31%;color:#f6ede4;}
#hc-hero .hc-slide--onepiece .hc-eyebrow{color:#fcd34d;font-weight:700;letter-spacing:.2em;margin-bottom:1.05em;}
#hc-hero .hc-slide--onepiece .hc-h1{font-size:clamp(26px,3.25cqw,62px);line-height:.98;font-weight:700;
  letter-spacing:.01em;text-transform:uppercase;font-family:'Oswald','Epilogue',system-ui,sans-serif;}
#hc-hero .hc-slide--onepiece .hc-h1 .m{color:#ff4a26;}
#hc-hero .hc-slide--onepiece .hc-sub{color:#e8d8cc;line-height:1.55;margin-top:1.2em;}
#hc-hero .hc-slide--onepiece .hc-cta{gap:.75em;margin-top:1.85em;}
#hc-hero .hc-slide--onepiece .hc-primary{background:linear-gradient(180deg,#ff8a4c,#FF6A2C);
  box-shadow:0 12px 28px rgba(255,106,44,.5);}
#hc-hero .hc-slide--onepiece .hc-ghost{background:rgba(246,237,228,.94);color:#0a0608;}
#hc-hero .hc-slide--onepiece .hc-product{left:50%;top:9%;width:47%;height:82%;}

/* ========================================================================== */
/* SLIDE 4 · Gundam TCG EB01 „Eternal Nexus" */
/* ========================================================================== */
#hc-hero .hc-slide--gundam .hc-vig{
  background:radial-gradient(125% 105% at 64% 40%, transparent 40%, rgba(7,13,20,.40) 100%);}
#hc-hero .hc-slide--gundam .hc-scrim{width:54%;
  background:linear-gradient(100deg, rgba(6,14,22,.80) 0%, rgba(6,14,22,.55) 34%, rgba(6,14,22,.16) 60%, transparent 80%);}
#hc-hero .hc-slide--gundam .hc-content{left:19.17%;top:19.88%;width:28.75%;color:#fff;}
#hc-hero .hc-slide--gundam .hc-badge{background:#19c7b6;color:#062a26;}
#hc-hero .hc-slide--gundam .hc-eyebrow{color:#ef820e;letter-spacing:.18em;}
#hc-hero .hc-slide--gundam .hc-h1 .o{background:linear-gradient(180deg,#ffb15a,#fc6e3b);
  -webkit-background-clip:text;background-clip:text;color:transparent;}
#hc-hero .hc-slide--gundam .hc-h1 .t{color:#19c7b6;}
#hc-hero .hc-slide--gundam .hc-sub{color:#dfe9ee;line-height:1.62;max-width:25em;}
#hc-hero .hc-slide--gundam .hc-cta{margin-top:2.15em;}
#hc-hero .hc-slide--gundam .hc-product{left:52.9%;top:16.9%;width:27.9%;height:66.3%;}
#hc-hero .hc-slide--gundam .hc-product img{
  filter:drop-shadow(0 16px 28px rgba(0,0,0,.55)) drop-shadow(0 0 52px rgba(3,9,15,.62)) drop-shadow(0 0 26px rgba(95,208,255,.18));}

/* ========================================================================== */
/* SLIDER-STEUERUNG — dezente Pfeile + Dots (kein „1/5"-Zähler) */
/* ========================================================================== */
#hc-hero .hc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  background:rgba(8,18,28,.42);color:#fff;font-size:26px;line-height:1;
  backdrop-filter:blur(4px);transition:background .2s, opacity .2s;opacity:.65;}
#hc-hero .hc-arrow:hover,#hc-hero .hc-arrow:focus-visible{background:rgba(8,18,28,.74);opacity:1;outline:2px solid #fff;}
#hc-hero .hc-prev{left:14px;} #hc-hero .hc-next{right:14px;}
#hc-hero .hc-dots{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:20;
  display:flex;gap:10px;align-items:center;padding:8px 6px;}
#hc-hero .hc-dot{width:10px;height:10px;border-radius:50%;border:none;cursor:pointer;padding:0;
  background:rgba(255,255,255,.42);transition:background .2s, width .25s;position:relative;}
/* vergrößerte Touch-Fläche ≥44px ohne sichtbare Vergrößerung */
#hc-hero .hc-dot::before{content:"";position:absolute;inset:-17px;}
#hc-hero .hc-dot.is-active{background:#fff;width:26px;border-radius:999px;}
#hc-hero .hc-dot:focus-visible{outline:2px solid #fff;outline-offset:3px;}
/* Single-Slide-Fallback: keine Steuerung zeigen */
#hc-hero[data-count="1"] .hc-arrow,
#hc-hero[data-count="1"] .hc-dots{display:none;}

/* ========================================================================== */
/* REDUCED MOTION — kein Video, kein Auto-Rotate (JS), nur Poster/Standbild */
/* ========================================================================== */
@media (prefers-reduced-motion:reduce){
  #hc-hero .hc-l2-vid{display:none;}
  #hc-hero .hc-slide{transition:none;}
}

/* ========================================================================== */
/* REFLOW ≤1023px (Mobil + Tablet) — Content oben, Produkt darunter, CTAs voll  */
/* ≥1024 bleibt Referenz-Layout (Anweisung A8); Tablets bekommen die gestapelte */
/* Optik statt eines zu flachen ~265px-Banners.                                */
/* ========================================================================== */
@media (max-width:1023px){
  #hc-hero .hc-stage{aspect-ratio:auto;min-height:clamp(480px,72vw,560px);border-radius:14px;}
  #hc-hero .hc-vig{background:none!important;}
  #hc-hero .hc-scrim{width:100%!important;height:100%!important;
    background:linear-gradient(180deg, rgba(5,11,18,.90) 0%, rgba(5,11,18,.62) 40%, rgba(5,11,18,.34) 72%, rgba(5,11,18,.30) 100%)!important;}
  #hc-hero .hc-content{left:6%!important;right:6%!important;top:6%!important;width:auto!important;}
  #hc-hero .hc-h1{font-size:clamp(28px,8.4vw,40px)!important;}
  #hc-hero .hc-eyebrow{font-size:12px!important;}
  #hc-hero .hc-badge{font-size:11px!important;}
  #hc-hero .hc-sub{font-size:14px!important;max-width:34em!important;line-height:1.5!important;margin-top:.9em!important;}
  #hc-hero .hc-cta{margin-top:1.2em!important;gap:.6em!important;}
  #hc-hero .hc-btn{flex:1 1 44%;justify-content:center;font-size:14px!important;padding:.95em 1em!important;}
  #hc-hero .hc-product{left:5%!important;right:5%!important;width:auto!important;top:auto!important;
    bottom:3%!important;height:46%!important;}
  #hc-hero .hc-dots{bottom:8px;}
  #hc-hero .hc-arrow{width:40px;height:40px;font-size:23px;}
  #hc-hero .hc-prev{left:8px;} #hc-hero .hc-next{right:8px;}
}

/* ===================== MARKEN-AKKORDEON #hc-brands Artworks — 2026-06-26 ===================== */
/* ============================================================
   Marken-Akkordeon #hc-brands - echte Artworks statt Verlaeufe + Monogramm raus
   Quelle: Marken-Akkordeon/_DEPLOY_Akkordeon-Live - 26.06.2026
   Modul nutzt bereits background-image:var(--img,var(--bg)) -> nur --img setzen.
   An startseite-v3.css ANHAENGEN.
   ============================================================ */
#hc-brands .bpanel .sw{ display:none !important; }
#hc-brands .bpanel .bg{ background-size:cover; background-position:50% 50%; }
#hc-brands .bpanel[data-i="0"]{ --img:url(/templates/HawaiiCards/img/akkordeon/pokemon.jpg); }
#hc-brands .bpanel[data-i="1"]{ --img:url(/templates/HawaiiCards/img/akkordeon/onepiece.jpg); }
#hc-brands .bpanel[data-i="2"]{ --img:url(/templates/HawaiiCards/img/akkordeon/gundam.jpg); }
#hc-brands .bpanel[data-i="3"]{ --img:url(/templates/HawaiiCards/img/akkordeon/gunpla.jpg); }
#hc-brands .bpanel[data-i="4"]{ --img:url(/templates/HawaiiCards/img/akkordeon/r2r.jpg); }
#hc-brands .bpanel[data-i="5"]{ --img:url(/templates/HawaiiCards/img/akkordeon/digimon.jpg); }
#hc-brands .bpanel[data-i="6"]{ --img:url(/templates/HawaiiCards/img/akkordeon/lorcana.jpg); }
#hc-brands .bpanel[data-i="7"]{ --img:url(/templates/HawaiiCards/img/akkordeon/snaa.jpg); }
#hc-brands .bpanel[data-i="8"]{ --img:url(/templates/HawaiiCards/img/akkordeon/hobby.jpg); }
#hc-brands .bpanel[data-i="9"]{ --img:url(/templates/HawaiiCards/img/akkordeon/cyber.jpg); }
#hc-brands .bpanel[data-i="10"]{ --img:url(/templates/HawaiiCards/img/akkordeon/funko.jpg); }

/* HC Top-Marken (optimiert) v3 2026-06-27 — scoped unter #hc-cats */
#hc-cats{padding:54px 0 24px;}
#hc-cats .sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-bottom:34px;flex-wrap:wrap;}
#hc-cats .eyebrow{font-family:var(--font-body);font-weight:600;font-size:12px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--primary);display:inline-flex;align-items:center;gap:10px;}
#hc-cats .eyebrow::before{content:"";width:26px;height:2px;background:var(--primary);border-radius:2px;}
#hc-cats .sec-head h2{font-size:clamp(28px,3.6vw,46px);margin-top:14px;}
#hc-cats .sec-head .lead{color:var(--muted);max-width:48ch;margin-top:14px;font-size:16px;}
#hc-cats .sec-link{font-weight:700;color:var(--primary);display:inline-flex;align-items:center;gap:8px;font-size:14.5px;white-space:nowrap;}
#hc-cats .sec-link svg{transition:transform .2s var(--ease);}
#hc-cats .sec-link:hover svg{transform:translateX(4px);}
#hc-cats .tmk{display:flex;flex-direction:column;gap:18px;}
#hc-cats .tmk-band{display:grid;grid-template-columns:1fr;gap:16px;}
@media(min-width:1024px){
  #hc-cats .tmk-band{grid-template-columns:minmax(280px,1fr) 2.5fr;align-items:stretch;}
  #hc-cats .tmk-band.rev{grid-template-columns:2.5fr minmax(280px,1fr);}
  #hc-cats .tmk-band.rev .tmk-rail{order:2;}
  #hc-cats .tmk-band.rev .tmk-center{order:1;}
}
#hc-cats .tmk-rail{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(min-width:1024px){
  #hc-cats .tmk-rail{grid-template-columns:1fr;grid-auto-rows:1fr;}
}
#hc-cats .btab{position:relative;display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:16px;min-height:0;
  background:var(--surface);box-shadow:inset 0 0 0 1px var(--border-soft);cursor:pointer;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);}
#hc-cats .btab::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;border-radius:4px;background:var(--c,var(--primary));
  opacity:0;transition:opacity .2s;}
#hc-cats .btab:hover{transform:translateY(-2px);}
#hc-cats .btab .logo{width:60px;height:60px;flex:none;border-radius:12px;display:grid;place-items:center;overflow:hidden;
  background:color-mix(in srgb,var(--c) 9%, var(--card-hi));box-shadow:inset 0 0 0 1px var(--border-soft);}
#hc-cats .btab .logo img{width:100%;height:100%;object-fit:contain;}
#hc-cats .btab .logo .mono{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.3px;color:var(--c);}
#hc-cats .btab .meta{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1;}
#hc-cats .btab .nm{font-family:var(--font-display);font-weight:800;font-size:15.5px;line-height:1.1;}
#hc-cats .btab .chips{display:flex;flex-wrap:wrap;gap:5px;align-items:center;}
#hc-cats .btab .chips span{font-size:10px;font-weight:700;letter-spacing:.02em;color:var(--muted);
  background:var(--card-hi);padding:2px 8px;border-radius:999px;box-shadow:inset 0 0 0 1px var(--border-soft);}
#hc-cats .btab .cnt{display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-weight:800;font-size:11.5px;color:var(--dim);font-variant-numeric:tabular-nums;}
#hc-cats .btab .cnt svg{width:14px;height:14px;opacity:.7;transition:transform .2s var(--ease);}
#hc-cats .btab:hover .cnt svg{transform:translateX(3px);}
@media(max-width:1023px){
  #hc-cats .btab .chips{display:none;}
  #hc-cats .btab .cnt{display:none;}
  #hc-cats .btab .logo{width:54px;height:54px;}
}
#hc-cats .btab.is-active{background:color-mix(in srgb, var(--c) 9%, var(--surface));
  box-shadow:inset 0 0 0 1.6px color-mix(in srgb,var(--c) 50%, transparent), var(--el-2);}
#hc-cats .btab.is-active::before{opacity:1;}
#hc-cats .btab.is-active .nm{color:color-mix(in srgb,var(--c) 78%, var(--text));}
#hc-cats .btab.is-active .cnt{color:var(--c);}
#hc-cats .tmk-center{position:relative;}
#hc-cats .panel{display:none;flex-direction:column;background:var(--surface);border-radius:var(--r-lg);padding:20px 22px 22px;
  box-shadow:inset 0 4px 0 var(--c,var(--primary)), inset 0 0 0 1px var(--border-soft), var(--el-2);flex:1;}
#hc-cats .panel.is-active{display:flex;}
@media(min-width:1024px){
  #hc-cats .tmk-center{display:grid;}
  #hc-cats .panel{display:flex;grid-area:1/1;opacity:0;visibility:hidden;transform:translateY(8px) scale(.995);
    transition:opacity .5s var(--ease), transform .5s var(--ease), visibility .5s;}
  #hc-cats .panel.is-active{opacity:1;visibility:visible;transform:none;z-index:2;}
}
@media(prefers-reduced-motion:reduce){
  #hc-cats .panel{transition:none;transform:none;}
}
#hc-cats .phead{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;margin-bottom:16px;}
#hc-cats .phead .ptitle{display:flex;flex-direction:column;justify-self:start;}
#hc-cats .phead .logo{width:66px;height:66px;flex:none;border-radius:14px;overflow:hidden;display:grid;place-items:center;justify-self:center;
  background:color-mix(in srgb,var(--c) 9%, var(--card-hi));box-shadow:inset 0 0 0 1px var(--border-soft);}
#hc-cats .phead .logo img{width:100%;height:100%;object-fit:contain;padding:5px;}
#hc-cats .phead .logo .mono{font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--c);}
#hc-cats .phead .k{font-size:10.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--c,var(--primary));}
#hc-cats .phead h3{font-family:var(--font-display);font-weight:800;font-size:23px;line-height:1.04;margin:3px 0 2px;}
#hc-cats .phead .sub{font-size:12.5px;color:var(--muted);}
#hc-cats .phead .all{justify-self:end;align-self:center;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  font-family:var(--font-display);font-weight:800;font-size:13.5px;color:var(--c,var(--primary));
  padding:9px 14px;border-radius:var(--r-pill);box-shadow:inset 0 0 0 1.4px color-mix(in srgb,var(--c) 38%, transparent);
  transition:background .18s var(--ease), box-shadow .18s var(--ease), transform .18s var(--ease);}
#hc-cats .phead .all svg{transition:transform .18s var(--ease);}
#hc-cats .phead .all:hover{background:color-mix(in srgb,var(--c) 10%, transparent);
  box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--c) 62%, transparent);transform:translateY(-1px);}
#hc-cats .phead .all:hover svg{transform:translateX(3px);}
@media(max-width:479px){
  #hc-cats .phead .all .t{display:none;}
  #hc-cats .phead .all{padding:9px;}
}
#hc-cats .prods{display:grid;grid-template-columns:repeat(2,1fr);gap:11px;}
@media(min-width:1024px){
  #hc-cats .prods{grid-template-columns:repeat(4,1fr);align-content:start;}
}
#hc-cats .prod{display:flex;flex-direction:column;background:var(--card);border-radius:16px;overflow:hidden;
  box-shadow:inset 0 0 0 1px var(--border-soft);transition:transform .22s var(--ease), box-shadow .22s var(--ease);}
#hc-cats .prod:hover{transform:translateY(-5px);
  box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--c,var(--primary)) 55%, transparent), 0 26px 48px -28px rgba(0,0,0,.55);}
#hc-cats .art{position:relative;aspect-ratio:1/1;overflow:hidden;}
#hc-cats .art .frames{position:absolute;inset:0;}
#hc-cats .art .frame{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .5s var(--ease);
  background:radial-gradient(120% 90% at 50% 0%, color-mix(in srgb,var(--c) 16%, var(--card-hi)), var(--card-hi) 70%);}
#hc-cats .art .frame.on{opacity:1;}
#hc-cats .art .frame img{width:100%;height:100%;object-fit:cover;}
#hc-cats .art .frame .ph{width:50%;height:50%;opacity:.45;color:var(--c);}
#hc-cats .art .frame .fnum{position:absolute;top:9px;left:50%;transform:translateX(-50%);font-family:var(--font-body);font-weight:700;
  font-size:10px;letter-spacing:.04em;color:var(--c);background:color-mix(in srgb,var(--c) 14%, var(--card-hi));
  padding:2px 8px;border-radius:999px;box-shadow:inset 0 0 0 1px var(--border-soft);}
#hc-cats .art .dots{position:absolute;left:0;right:0;bottom:8px;z-index:3;display:flex;gap:5px;justify-content:center;opacity:0;transition:opacity .2s;}
#hc-cats .prod:hover .art .dots{opacity:1;}
#hc-cats .art .dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.6);box-shadow:0 1px 3px rgba(0,0,0,.45);transition:.25s var(--ease);}
#hc-cats .art .dots i.on{background:#fff;transform:scale(1.3);}
#hc-cats .art .badge{position:absolute;top:9px;left:9px;z-index:3;font-size:10px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;padding:4px 8px;border-radius:7px;background:var(--brand-navy);color:#fff;
  box-shadow:0 4px 10px -4px rgba(0,0,0,.5);}
#hc-cats .art .badge.sale{background:var(--primary);color:var(--primary-ink);}
#hc-cats .art .wish{position:absolute;top:9px;right:9px;z-index:3;width:31px;height:31px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.88);color:var(--brand-navy);box-shadow:0 4px 10px -4px rgba(0,0,0,.4);transition:.18s;border:none;cursor:pointer;}
#hc-cats .art .wish:hover{background:#fff;color:#ff5d7a;transform:scale(1.1);}
#hc-cats .art .fl{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 12px 9px;color:var(--text);
  font-family:var(--font-display);font-weight:800;font-size:13.5px;opacity:.55;
  background:linear-gradient(0deg, color-mix(in srgb,var(--c) 10%, transparent), transparent);}
#hc-cats .pb{padding:10px 11px 12px;display:flex;flex-direction:column;gap:4px;flex:1;}
#hc-cats .cat{font-size:9px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--c,var(--primary));}
#hc-cats .nm{font-size:11.5px;font-weight:600;line-height:1.22;color:var(--text);}
#hc-cats .row{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:6px;}
#hc-cats .pr{font-family:var(--font-display);font-weight:800;font-size:14px;}
#hc-cats .pr .was{font-size:10px;color:var(--dim);text-decoration:line-through;margin-left:3px;font-family:var(--font-body);font-weight:600;}
#hc-cats .add{width:33px;height:33px;flex:none;border-radius:10px;background:var(--primary);color:var(--primary-ink);
  display:grid;place-items:center;box-shadow:var(--glow);transition:transform .18s var(--ease);}
#hc-cats .add:hover{transform:scale(1.1) rotate(-6deg);}
@media(max-width:1023px){
  #hc-cats .tmk-center{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:2px 2px 10px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;}
  #hc-cats .tmk-center::-webkit-scrollbar{display:none;}
  #hc-cats .panel{display:flex;flex:0 0 88%;scroll-snap-align:center;}
  #hc-cats .panel.is-active{display:flex;}
  @media(min-width:560px){
    #hc-cats .panel{flex-basis:60%;}
  }
}

/* Kollisions-Reset gg. altes #hc-cats Modul */
#hc-cats .tmk-center{min-height:0;}
#hc-cats .tmk{grid-template-columns:none;}

/* HC TM v3 Logos boxlos 2026-06-27 v2 — kein Kasten, feste Logo-Hoehe (=Kachelhoehe), kein Overlap */
#hc-cats .btab .logo{background:none;box-shadow:none;border-radius:0;overflow:visible;padding:0;display:flex;align-items:center;justify-content:flex-start;flex:none;width:auto;height:auto;max-width:104px;}
#hc-cats .btab .logo img{height:60px;width:auto;max-width:104px;object-fit:contain;display:block;}
#hc-cats .phead .logo{background:none;box-shadow:none;border-radius:0;overflow:visible;padding:0;display:flex;align-items:center;justify-content:center;width:auto;height:auto;max-width:200px;justify-self:center;}
#hc-cats .phead .logo img{height:66px;width:auto;max-width:200px;object-fit:contain;display:block;}
@media(max-width:1023px){#hc-cats .btab .logo{max-width:92px;}#hc-cats .btab .logo img{height:50px;max-width:92px;}}

/* HC TM v3 Layout-Fix 2026-06-27 v4 — Baender volle Breite (L+R buendig), Buttons 1-zeilig (kein Clip/Overlap), Header+Tabs gleich hoch */
#hc-cats .tmk{align-items:stretch;}
#hc-cats .tmk-band{width:100%;}
@media(min-width:1024px){
  #hc-cats .tmk-band{grid-template-columns:320px 1fr;}
  #hc-cats .tmk-band.rev{grid-template-columns:1fr 320px;}
}
#hc-cats .phead{display:flex;align-items:center;justify-content:space-between;gap:14px;position:relative;min-height:66px;}
#hc-cats .phead .ptitle{min-width:0;}
#hc-cats .phead .logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0;}
#hc-cats .phead .all{flex:0 0 auto;white-space:nowrap;flex-wrap:nowrap;min-width:max-content;max-width:none;}
#hc-cats .phead .all .t{flex:none;white-space:nowrap;min-width:max-content;overflow:visible;}
@media(max-width:1023px){#hc-cats .phead .logo{max-width:120px;}}

/* HC Hero 6-Banner 2026-06-27 — flache Banner, ersetzt 4-Slide-Layer-Hero */
#hc-hero{display:block;width:100%;max-width:1280px;margin:0 auto 18px;}
#hc-hero .hc-stage{position:relative;width:100%;aspect-ratio:1600/830;overflow:hidden;border-radius:16px;background:#0a141d;box-shadow:0 24px 60px rgba(8,18,28,.4);}
#hc-hero .hc-slides{position:absolute;inset:0;}
#hc-hero .hc-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .5s ease, visibility 0s linear .5s;}
#hc-hero .hc-slide.is-active{opacity:1;visibility:visible;transition:opacity .5s ease;z-index:1;}
#hc-hero .hc-banner{display:block;}
#hc-hero .hc-banner img{width:100%;height:100%;object-fit:cover;display:block;}
#hc-hero .hc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:20;width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:rgba(8,18,28,.42);color:#fff;font-size:26px;line-height:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:.6;transition:background .2s,opacity .2s;}
#hc-hero:hover .hc-arrow{opacity:1;}
#hc-hero .hc-arrow:hover{background:rgba(8,18,28,.74);}
#hc-hero .hc-prev{left:14px;}#hc-hero .hc-next{right:14px;}
#hc-hero .hc-dots{display:none;}
@media(max-width:1023px){#hc-hero .hc-stage{aspect-ratio:1600/830;min-height:0;}}
