/* ════════════════════════════════════════════════════════════════
   mk-kreativ · Premium Shop-Theme  v2  (foto-getrieben, artroom-orientiert)
   Weiß / Schwarz dezent / Rot-Fineline / dezentes Glas
   NUR mk-kreativ. Siehe memory: project_mk_kreativ_design_system
   ════════════════════════════════════════════════════════════════ */
@font-face{font-family:'DM Sans';font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/dm-sans-400.woff2) format('woff2')}
@font-face{font-family:'DM Sans';font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/dm-sans-500.woff2) format('woff2')}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/dm-mono-400.woff2) format('woff2')}

:root{
  --bg:#ffffff; --bg-soft:#f6f6f7; --bg-tint:#f1ece8;
  --ink:#111114; --ink-2:#43434b; --ink-3:#86868f;
  --line:rgba(17,17,20,.10); --line-2:rgba(17,17,20,.06);
  --red:#d61f34; --red-ink:#b3192b; --red-soft:rgba(214,31,52,.10);
  --glass-bg:rgba(255,255,255,.55); --glass-bd:rgba(255,255,255,.68);
  --blur:saturate(1.8) blur(22px);
  --glass-sh:inset 0 1px 0 rgba(255,255,255,.72), 0 1px 2px rgba(17,17,20,.04), 0 16px 44px rgba(22,24,42,.11);
  --glass-sh-hi:inset 0 1px 0 rgba(255,255,255,.85), 0 2px 6px rgba(17,17,20,.06), 0 26px 64px rgba(22,24,42,.18);
  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:28px;
  --sh-1:0 2px 10px rgba(17,17,20,.05); --sh-2:0 8px 30px rgba(17,17,20,.08); --sh-3:0 20px 60px rgba(17,17,20,.12);
  --f-sans:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --f-mono:'DM Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.22,.8,.28,1); --maxw:1280px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;background:#f5f7fa;color-scheme:light}
body{background:radial-gradient(58% 42% at 8% -2%,rgba(214,31,52,.05),transparent 60%),radial-gradient(52% 48% at 94% 4%,rgba(64,86,140,.06),transparent 62%),linear-gradient(180deg,#f8f9fc,#edeff3);background-attachment:fixed;color:var(--ink);font-family:var(--f-sans);font-weight:400;line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
.hidden{display:none!important}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.4rem)}
.eyebrow{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);display:inline-flex;align-items:center;gap:.7rem}
.eyebrow::before{content:none}
h1,h2,h3{font-weight:600;letter-spacing:-.02em;line-height:1.1;color:var(--ink)}
.sec-h{text-align:center;max-width:660px;margin:0 auto clamp(2rem,5vw,3.2rem)}
.sec-h .eyebrow{justify-content:center;margin-bottom:1rem}
.sec-h h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}
.sec-h p{color:var(--ink-2);margin-top:.9rem;font-size:1.02rem}
section{padding:clamp(3.4rem,7vw,5.6rem) 0}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:48px;padding:0 1.6rem;border-radius:100px;font-weight:500;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease);white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:rgba(17,17,20,.86);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);color:#fff;border-color:rgba(255,255,255,.14);box-shadow:inset 0 1px 0 rgba(255,255,255,.2),0 10px 30px rgba(17,17,20,.22)}
.btn-primary:hover{}
.btn-ghost{background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-color:var(--glass-bd);color:var(--ink);box-shadow:var(--glass-sh)}
.btn-ghost:hover{}
.btn-red{background:rgba(214,31,52,.88);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);color:#fff;border-color:rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.26),0 10px 28px rgba(214,31,52,.3)}
.btn-red:hover{}
.btn-light{background:rgba(255,255,255,.82);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);color:var(--ink);border-color:var(--glass-bd);box-shadow:var(--glass-sh)}
.btn-light:hover{}

.skip-link{position:absolute;left:-999px;top:0;z-index:999;background:var(--ink);color:#fff;padding:.6rem 1rem}
.skip-link:focus{left:0}
#scrollTop{position:fixed;left:1.1rem;bottom:max(1.1rem,env(safe-area-inset-bottom));width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--glass-bd);background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);color:var(--ink);font-size:1.25rem;line-height:1;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s var(--ease),transform .25s var(--ease),box-shadow .25s,border-color .25s;z-index:90;box-shadow:var(--glass-sh)}
#scrollTop.show,#scrollTop.visible{opacity:1;visibility:visible;transform:none}
#scrollTop:hover{}

/* ── Schnell-Kontakt-Bubble (main.js #vtContactBubble) → mk-kreativ Liquid Glass ── */
/* Override mit !important, da main.js sein Style nachträglich in <head> injiziert (Gold/Dunkel = varotech). main.js bleibt unangetastet, nur mk-kreativ-Theme divergiert. */
#vtContactBubbleBtn{background:var(--glass-bg)!important;-webkit-backdrop-filter:var(--blur)!important;backdrop-filter:var(--blur)!important;border:1px solid var(--glass-bd)!important;color:var(--ink)!important;box-shadow:var(--glass-sh)!important}
#vtContactBubbleBtn:hover{transform:translateY(-2px)!important;background:var(--glass-bg)!important;border-color:var(--glass-bd)!important;color:var(--ink)!important;box-shadow:0 0 0 1.5px var(--red),0 10px 26px rgba(17,17,20,.14)!important}
#vtContactBubbleBtn:focus-visible{outline:2px solid var(--red)!important;outline-offset:3px!important}
#vtContactBubblePanel{background:var(--glass-bg)!important;-webkit-backdrop-filter:var(--blur)!important;backdrop-filter:var(--blur)!important;border:1px solid var(--glass-bd)!important;box-shadow:var(--glass-sh-hi)!important;border-radius:18px!important}
.vt-cb-hd{color:var(--ink-3)!important;border-bottom:1px solid var(--line)!important}
.vt-cb-item{color:var(--ink-2)!important}
.vt-cb-item:hover{background:rgba(17,17,20,.04)!important;color:var(--ink)!important}
.vt-cb-item-ic{background:rgba(17,17,20,.05)!important;border:1px solid var(--glass-bd)!important;color:var(--ink)!important}
.vt-cb-item:hover .vt-cb-item-ic{background:rgba(214,31,52,.1)!important;color:var(--red)!important}
.vt-cb-item-label{color:var(--ink)!important}
.vt-cb-item-sub{color:var(--ink-3)!important}

/* Image-Slot (echte Fotos rein -> /images/...; fehlt das Foto, zeigt der Slot ein Label) */
.imgslot{position:relative;background:linear-gradient(135deg,var(--bg-tint),#eceef2);overflow:hidden}
.imgslot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-62%);width:38px;height:38px;background:rgba(17,17,20,.12);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.3' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='18' height='18' rx='2'/><circle cx='8.5' cy='8.5' r='1.5'/><path d='M21 15l-5-5L5 21'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.3' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='18' height='18' rx='2'/><circle cx='8.5' cy='8.5' r='1.5'/><path d='M21 15l-5-5L5 21'/></svg>") center/contain no-repeat;pointer-events:none;z-index:0}
.imgslot::before{content:attr(data-label);position:absolute;left:0;right:0;bottom:.55rem;text-align:center;padding:0 .8rem;font-family:var(--f-mono);font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(17,17,20,.24);pointer-events:none}
.imgslot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}

/* Announcement */
.anno{background:var(--ink);color:rgba(255,255,255,.82);text-align:center;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;padding:.55rem 1rem}
.anno b{color:#fff;font-weight:400}.anno .sep{color:var(--red);margin:0 .7rem}

/* Header (zweizeilig: Top + Nav) */
.hdr{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.85);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border-bottom:1px solid var(--line-2);transition:box-shadow .3s var(--ease)}
.hdr.scrolled{box-shadow:0 6px 28px rgba(17,17,20,.07)}
.hdr-top{display:flex;align-items:center;gap:clamp(.8rem,2.5vw,1.8rem);height:68px}
.logo{display:flex;align-items:center;gap:.04em;font-weight:700;font-size:1.4rem;letter-spacing:-.03em;flex-shrink:0;color:var(--ink)}
.logo .k{font-weight:400;color:var(--ink-2)}.logo .d{color:var(--red)}
/* Suchleiste + Live-Vorschläge */
.search-wrap{position:relative;flex:1;max-width:560px}
.search{display:flex;width:100%;align-items:center;gap:.5rem;background:var(--bg-soft);border:1px solid var(--line);border-radius:100px;padding:0 .35rem 0 1.1rem;height:46px;transition:border-color .2s,box-shadow .2s}
.search:focus-within{border-color:var(--ink);box-shadow:0 0 0 4px rgba(17,17,20,.05);background:#fff}
.search>svg{width:18px;height:18px;color:var(--ink-3);flex-shrink:0}
.search input{flex:1;min-width:0;border:none;background:none;font-size:.92rem;color:var(--ink);outline:none}
.search input::placeholder{color:var(--ink-3)}
.search input::-webkit-search-cancel-button{-webkit-appearance:none}
.search button{width:36px;height:36px;border-radius:50%;border:none;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .2s}
.search button:hover{background:var(--red)}.search button svg{width:16px;height:16px}
.search-sug{position:absolute;top:calc(100% + 8px);left:0;right:0;background:rgba(255,255,255,.72);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r);box-shadow:var(--glass-sh);padding:.4rem;z-index:130;max-height:min(72vh,520px);overflow-y:auto}
.sug-item{display:flex;align-items:center;gap:.85rem;padding:.55rem .6rem;border-radius:10px;transition:background .12s var(--ease)}
.sug-item:hover,.sug-item.sel{background:var(--bg-soft)}
.sug-img{width:48px;height:48px;border-radius:8px;background:var(--bg-tint);overflow:hidden;flex-shrink:0}
.sug-img img{width:100%;height:100%;object-fit:cover}
.sug-tx{flex:1;min-width:0}
.sug-name{display:block;font-size:.9rem;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sug-cat{display:block;font-size:.68rem;color:var(--ink-3);font-family:var(--f-mono);letter-spacing:.06em;text-transform:uppercase;margin-top:1px}
.sug-price{font-weight:600;font-size:.92rem;color:var(--ink);flex-shrink:0;white-space:nowrap}
.sug-empty{padding:1.1rem;text-align:center;color:var(--ink-3);font-size:.88rem}
.sug-all{display:block;text-align:center;padding:.7rem;margin-top:.2rem;border-top:1px solid var(--line-2);font-family:var(--f-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red-ink);border-radius:0 0 8px 8px}
.sug-all:hover,.sug-all.sel{background:var(--red-soft);color:var(--red)}
/* Ausfahrbares Such-Panel (Icon -> Panel unter dem Header) */
.hdr-search{border-top:1px solid var(--line-2);background:rgba(255,255,255,.97);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur)}
.hdr-search[hidden]{display:none}
.hdr-search>.wrap{padding-top:.75rem;padding-bottom:.75rem}
.hdr-search .search-wrap{position:relative;max-width:760px;margin:0 auto;display:flex;align-items:center;gap:.6rem}
.hdr-search .search{flex:1;max-width:none}
.hdr-search:not([hidden]) .search-wrap{animation:mkSlideDown .25s var(--ease)}
@keyframes mkSlideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.search-close{width:44px;height:44px;flex-shrink:0;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,color .15s}
.search-close:hover{border-color:var(--ink);color:var(--ink)}
.search-close svg{width:18px;height:18px}
.hdr-actions{display:flex;align-items:center;gap:.1rem;flex-shrink:0;margin-left:auto}
/* Ausfahrbare Suche (Icon -> Feld gleitet horizontal auf) */
.search-x{position:relative;display:flex;align-items:center;height:44px}
.sx-input{position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;opacity:0;height:42px;border:1px solid transparent;border-radius:100px;background:var(--bg-soft);padding:0;font-family:var(--f-sans);font-size:.92rem;color:var(--ink);outline:none;pointer-events:none;transition:width .4s var(--ease),opacity .3s var(--ease),padding .4s var(--ease),border-color .2s var(--ease);z-index:2;will-change:width}
.search-x.open .sx-input{width:clamp(200px,28vw,330px);opacity:1;padding:0 3rem 0 1.1rem;border-color:var(--line);background:#fff;pointer-events:auto;box-shadow:var(--glass-sh)}
.sx-input::placeholder{color:var(--ink-3)}
.sx-input::-webkit-search-cancel-button{-webkit-appearance:none}
.sx-icon{position:relative;z-index:3}
.search-x.open .sx-icon{color:var(--red)}
.search-x .search-sug{right:0;left:auto;width:clamp(280px,32vw,360px)}
.ic-btn{height:42px;width:42px;min-width:42px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--ink);border-radius:50%;position:relative;transition:background .18s var(--ease),color .18s var(--ease)}
.ic-btn:hover{}
.ic-btn svg{width:22px;height:22px;stroke-width:1.6}
.ic-btn .lbl-txt{display:none}
.cart-badge{position:absolute;top:4px;right:2px;min-width:17px;height:17px;padding:0 4px;background:var(--red);color:#fff;border-radius:100px;font-size:.6rem;font-weight:600;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono)}
.burger{display:none}
/* Eingeloggtes Konto (main.js rendert Avatar + Name) — premium Glas-Pille mit Hover */
.nav-user{display:inline-flex;align-items:center;gap:.55rem;height:42px;padding:0 .95rem 0 .28rem;border-radius:100px;cursor:pointer;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);box-shadow:var(--glass-sh);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}
.nav-user:hover{}
.nav-user-avatar{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;flex-shrink:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
.nav-user-name{font-size:.88rem;font-weight:500;color:var(--ink);white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis}
/* Nav-Zeile */
.hdr-nav{border-top:1px solid var(--line-2)}
.hdr-nav .wrap{display:flex;align-items:center;height:50px}
.nav{display:flex;align-items:center;gap:.1rem}
.nav-item{position:relative}
.nav-link{display:inline-flex;align-items:center;gap:.34rem;padding:.55rem .85rem;font-size:.92rem;font-weight:500;color:var(--ink-2);border-radius:8px;transition:color .18s var(--ease);background:none;border:none;cursor:pointer}
.nav-link .chev{width:13px;height:13px;opacity:.6;transition:transform .25s var(--ease)}
.nav-link::after{content:'';position:absolute;left:.85rem;right:.85rem;bottom:.2rem;height:1.5px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav-item:hover .nav-link,.nav-link.active{color:var(--ink)}
.nav-item:hover .nav-link::after,.nav-link.active::after{transform:scaleX(1)}
.nav-item:hover .nav-link .chev{transform:rotate(180deg)}
.dd{position:absolute;top:calc(100% + 6px);left:0;min-width:236px;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r);box-shadow:var(--sh-3);padding:.5rem;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:120}
.dd::before{content:'';position:absolute;top:-8px;left:0;right:0;height:8px}
.nav-item:hover .dd{opacity:1;visibility:visible;transform:none}
.dd a{display:flex;align-items:center;gap:.6rem;padding:.62rem .8rem;border-radius:9px;font-size:.9rem;color:var(--ink-2);transition:background .15s,color .15s}
.dd a:hover{background:rgba(17,17,20,.045);color:var(--ink)}
.dd a .dot{width:5px;height:5px;border-radius:50%;background:var(--red);opacity:0;transition:opacity .15s}
.dd a:hover .dot{opacity:1}
.nav-spacer{margin-left:auto;display:flex;gap:1.1rem;align-items:center}
.nav-pill{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);display:inline-flex;align-items:center;gap:.5rem}
.nav-pill svg{width:14px;height:14px;color:var(--red)}

/* Hero — Vollbild-Foto + Overlay */
.hero{position:relative;min-height:clamp(440px,72vh,660px);display:flex;align-items:center;overflow:hidden}
.hero .hero-media{position:absolute;inset:0;background:var(--bg-tint)}
.hero .hero-media::before{color:rgba(17,17,20,.45)}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,8,10,.66),rgba(8,8,10,.34) 48%,rgba(8,8,10,.06) 80%)}
.hero-overlay{position:relative;z-index:2;width:100%;padding:clamp(2rem,5vw,3rem) 0}
.hero-overlay .eyebrow{color:rgba(255,255,255,.72)}
.hero-overlay .eyebrow::before{background:var(--red)}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.6vw,4.4rem);max-width:15ch;margin:1.2rem 0 0;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 .ra{position:relative;white-space:nowrap}
.hero h1 .ra::after{content:none}
.hero-sub{color:rgba(255,255,255,.9);font-size:clamp(1.05rem,1.5vw,1.2rem);line-height:1.7;max-width:44ch;margin:1.4rem 0 0}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2.2rem}
.hero .btn-ghost{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.45);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.hero .btn-ghost:hover{}
.hero-meta{display:flex;gap:1.6rem;margin-top:2.2rem;flex-wrap:wrap}
.hero-meta-i{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:rgba(255,255,255,.85)}
.hero-meta-i svg{width:17px;height:17px;color:#ffa6b0;stroke-width:1.8}

/* Trust / Value-Props */
.trust{padding:clamp(2rem,4vw,2.8rem) 0;border-bottom:1px solid var(--line-2)}
.trust-in{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.trust-card{display:flex;align-items:center;gap:.85rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r);box-shadow:var(--glass-sh);padding:1.05rem 1.15rem}
.trust-card svg{width:26px;height:26px;color:var(--ink);stroke-width:1.5;flex-shrink:0}
.trust-card b{display:block;font-size:.9rem;font-weight:600}.trust-card span{font-size:.76rem;color:var(--ink-3)}

/* Spotlight (Bild + Text, abwechselnd) — artroom-Stil */
.spot-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.spot.rev .spot-img{order:2}
.spot-img{aspect-ratio:4/3;border-radius:var(--r-lg);box-shadow:var(--sh-2)}
.spot-text .eyebrow{margin-bottom:1rem}
.spot-text h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
.spot-text p{color:var(--ink-2);margin:1.1rem 0 0;line-height:1.75;font-size:1.02rem}
.spot-text .btn{margin-top:1.7rem}

/* Karten */
.grid{display:grid;gap:1.3rem}
.cat-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(150px,17vw,200px)}
.cat-card{position:relative;border-radius:var(--r-lg);overflow:hidden;height:100%;box-shadow:var(--glass-sh);transition:transform .3s var(--ease),box-shadow .3s var(--ease);border:1px solid var(--glass-bd);display:block}
.cat-card:first-child{grid-column:span 2;grid-row:span 2}
.cat-card:first-child .glass-label b{font-size:1.15rem}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.cat-card .imgslot{position:absolute;inset:0}
.cat-card::after{content:'';position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,transparent 40%,rgba(10,10,12,.45))}
.cat-card .glass-label{position:absolute;left:1rem;bottom:1rem;right:1rem;z-index:3;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:12px;padding:.7rem .95rem;display:flex;align-items:center;justify-content:space-between}
.cat-card .glass-label b{font-size:1rem;font-weight:600}
.cat-card .glass-label .arw{width:30px;height:30px;border-radius:50%;background:rgba(17,17,20,.82);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.18);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.2);transition:background .2s}
.cat-card:hover .glass-label .arw{background:var(--red)}.cat-card .glass-label .arw svg{width:15px;height:15px}
.prod-grid{grid-template-columns:repeat(4,1fr)}
.prod{background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--glass-sh);transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:block}
.prod:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.prod .imgslot{aspect-ratio:1/1}
.prod .ptag{position:absolute;left:.7rem;top:.7rem;z-index:3;background:var(--red);color:#fff;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .55rem;border-radius:6px}
.prod .pfav{position:absolute;right:.6rem;top:.6rem;z-index:3;width:34px;height:34px;border-radius:50%;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);display:flex;align-items:center;justify-content:center;color:var(--ink-2);cursor:pointer;transition:color .15s,border-color .15s,transform .15s}
.prod .pfav svg{width:16px;height:16px;transition:fill .15s}
.prod .pfav:hover{color:var(--red);transform:translateY(-1px)}
.prod .pfav.is-fav{color:var(--red);border-color:var(--red)}
.prod .pfav.is-fav svg{fill:var(--red)}
.prod .pbody{padding:1rem 1.1rem 1.15rem}
.prod .pcat{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.prod .pname{font-weight:600;font-size:1rem;margin:.3rem 0 .5rem;line-height:1.3}
.prod .prate{display:flex;align-items:center;gap:.3rem;font-size:.76rem;color:var(--ink-3)}.prod .prate .s{color:var(--red);letter-spacing:1px}
.prod .pfoot{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}
.prod .pprice{font-weight:600;font-size:1.05rem}
.prod .pprice .old{color:var(--ink-3);font-weight:400;font-size:.82rem;text-decoration:line-through;margin-right:.4rem}
.prod .padd{width:40px;height:40px;border-radius:11px;background:rgba(17,17,20,.82);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid rgba(255,255,255,.16);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.2);transition:background .2s,transform .2s}
.prod:hover .padd{background:var(--red)}.prod .padd svg{width:18px;height:18px}
/* Anlässe */
.occ-grid{grid-template-columns:repeat(5,1fr)}
.occ{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line-2);box-shadow:var(--sh-1);transition:transform .3s var(--ease);display:block}
.occ:hover{transform:translateY(-4px)}
.occ .imgslot{position:absolute;inset:0}
.occ::after{content:'';position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,transparent 42%,rgba(10,10,12,.6))}
.occ b{position:absolute;left:1rem;bottom:.95rem;right:1rem;z-index:3;color:#fff;font-size:1.05rem;font-weight:600}
.occ b::before{content:'';display:block;width:22px;height:2px;background:var(--red);margin-bottom:.5rem}

/* Story */
.story{background:var(--bg-soft)}
.story-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.story-img{aspect-ratio:5/4;border-radius:var(--r-lg);box-shadow:var(--sh-2)}
.story h2{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:1.1rem 0 0}
.story p{color:var(--ink-2);margin-top:1.1rem;line-height:1.75}
.story ul{list-style:none;margin:1.5rem 0 0;display:grid;gap:.7rem}
.story li{display:flex;align-items:center;gap:.7rem;font-size:.95rem;color:var(--ink-2)}.story li svg{width:20px;height:20px;color:var(--red);flex-shrink:0}

/* Testimonials */
.testi{background:var(--bg-soft)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.testi-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r-lg);padding:1.7rem;box-shadow:var(--glass-sh)}
.testi-card .stars{color:var(--red);letter-spacing:2px;font-size:.9rem}
.testi-card p{color:var(--ink-2);margin:.8rem 0 1.3rem;line-height:1.7;font-size:.96rem}
.testi-who{display:flex;align-items:center;gap:.7rem}
.testi-av{width:40px;height:40px;border-radius:50%;background:var(--bg-tint);color:var(--ink);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}
.testi-who b{font-size:.9rem;font-weight:600}.testi-who span{display:block;font-size:.72rem;color:var(--ink-3)}

/* Newsletter */
.nl{padding-bottom:clamp(3.5rem,8vw,6rem)}
.nl-box{position:relative;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);box-shadow:var(--glass-sh);border-radius:var(--r-xl);padding:clamp(2.4rem,5vw,3.8rem);overflow:hidden;text-align:center;color:var(--ink)}
.nl-box::before{content:'';position:absolute;inset:0;background:radial-gradient(55% 80% at 88% 6%,rgba(214,31,52,.06),transparent 55%),radial-gradient(52% 72% at 8% 100%,rgba(64,86,140,.07),transparent 55%)}
.nl-box>*{position:relative;z-index:1}
.nl-box .eyebrow{color:var(--ink-3);justify-content:center}
.nl-box h2{color:var(--ink);font-size:clamp(1.7rem,3.4vw,2.4rem);margin-top:.9rem}
.nl-box p{color:var(--ink-2);margin:.8rem auto 0;max-width:46ch}
.nl-form{display:flex;gap:.6rem;max-width:440px;margin:1.8rem auto 0;flex-wrap:wrap}
.nl-form input{flex:1;min-width:200px;height:50px;border-radius:100px;border:1px solid var(--line);background:#fff;padding:0 1.2rem;color:var(--ink);font-size:.95rem}
.nl-form input::placeholder{color:var(--ink-3)}.nl-form input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 4px rgba(17,17,20,.05)}

/* Footer */
.ft{border-top:1px solid var(--line);padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.ft-brand .logo{font-size:1.3rem;margin-bottom:.9rem}.ft-brand p{color:var(--ink-2);font-size:.9rem;max-width:30ch;line-height:1.7}
.ft-col h4{font-size:.7rem;font-family:var(--f-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1rem}
.ft-col a{display:block;color:var(--ink-2);font-size:.9rem;padding:.32rem 0;transition:color .15s}.ft-col a:hover{color:var(--red-ink)}
.ft-bot{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--line-2);font-size:.8rem;color:var(--ink-3)}
.ft-pay{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.ft-pay span{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;border:1px solid var(--line);border-radius:6px;padding:.3rem .5rem;color:var(--ink-2)}

/* Mobile-Menü */
.mob-panel{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:330;transform:translateX(100%);transition:transform .3s var(--ease);padding:1.2rem;overflow-y:auto}
.mob-panel.open{transform:none;box-shadow:var(--sh-3)}
.mob-ov{position:fixed;inset:0;background:rgba(17,17,20,.4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:320;opacity:0;visibility:hidden;transition:opacity .3s}
.mob-ov.open{opacity:1;visibility:visible}
.mob-panel .m-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.mob-panel details{border-bottom:1px solid var(--line-2)}
.mob-panel summary{list-style:none;padding:.95rem .2rem;font-weight:500;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.mob-panel summary::-webkit-details-marker{display:none}
.mob-panel details a,.mob-panel>a{display:block;padding:.7rem .2rem;color:var(--ink-2);font-size:.92rem}
.mob-panel details[open] .mchev{transform:rotate(180deg)}.mchev{width:15px;height:15px;transition:transform .25s}
.mob-sub{padding-left:.6rem;padding-bottom:.5rem}

/* Drawer */
.cart-overlay{position:fixed;inset:0;background:rgba(17,17,20,.42);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .3s var(--ease);z-index:300}
.cart-overlay.open,.cart-overlay.active,.cart-overlay.show,.cart-overlay.visible{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;height:100dvh;width:min(430px,93vw);background:rgba(255,255,255,.9);-webkit-backdrop-filter:saturate(1.6) blur(26px);backdrop-filter:saturate(1.6) blur(26px);transform:translateX(100%);transition:transform .36s var(--ease);z-index:310;display:flex;flex-direction:column}
.cart-drawer.open,.cart-drawer.active,.cart-drawer.show,.cart-drawer.visible{transform:none;box-shadow:-24px 0 70px rgba(17,17,20,.2)}
.cart-hd{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-bottom:1px solid var(--line)}
.cart-hd-title{font-weight:600;font-size:1.05rem;display:flex;align-items:center;gap:.5rem}
.cart-hd-title-count{background:var(--ink);color:#fff;font-size:.62rem;font-weight:600;font-family:var(--f-mono);min-width:19px;height:19px;border-radius:100px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;letter-spacing:.02em}
/* Kostenloser-Versand-Hinweis: positiv = Grün (nicht Rot), Fortschritt dezent ink; Balken premium */
.cart-drawer .vt-freeship-msg{color:var(--ink-3)!important;font-weight:500;letter-spacing:.01em}
.cart-drawer .vt-freeship-msg.is-unlocked{color:#16a34a!important;font-weight:600}
.cart-drawer .vt-freeship-bar{background:rgba(17,17,20,.07)!important}
.cart-drawer .vt-freeship-fill{background:var(--ink)!important}
.cart-drawer .vt-freeship-msg.is-unlocked ~ .vt-freeship-bar .vt-freeship-fill{background:#16a34a!important}
.cart-close{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}
.cart-close:hover{}
.cart-items{flex:1;overflow-y:auto;padding:1.2rem 1.4rem;color:var(--ink-2)}
.cart-ft{border-top:1px solid var(--line);padding:1.1rem 1.4rem;background:var(--bg-soft)}
.cart-total-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.cart-total-lbl{color:var(--ink-2);font-size:.95rem}.cart-total-val{font-weight:700;font-size:1.25rem}
.cart-checkout-btn{width:100%;min-height:50px;border-radius:100px;background:var(--ink);color:#fff;border:none;font-weight:600;font-size:.98rem;cursor:pointer;transition:background .2s,transform .2s;margin-bottom:.6rem}
.cart-checkout-btn:hover{}
.cart-continue-btn{width:100%;min-height:46px;border-radius:100px;background:none;border:1px solid var(--line);color:var(--ink-2);font-weight:500;cursor:pointer;transition:border-color .2s,color .2s}
.cart-continue-btn:hover{}

/* ═══ Drawer-Innenleben — main.js rendert Cart/Konto/Login/Checkout hier rein ═══ */
/* main.js schreibt varotech-DUNKLE Inline-Farben fest (für dunklen Drawer). mk-kreativ-Drawer
   ist HELL → helle Inline-Texte per scoped Catch-all auf Ink umfärben (robust über alle 4 Drawer). */
.cart-drawer [style*="f5f5f0"]{color:var(--ink)!important}
.cart-drawer [style*="245,245,240"]{color:var(--ink-2)!important}
.cart-drawer [style*="200,180,140"]{border-color:var(--line)!important}
/* Cart-Zeilen */
.cart-item{display:flex;gap:.75rem;padding:.85rem 0;border-bottom:1px solid var(--line);align-items:flex-start}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:54px;height:54px;object-fit:cover;border-radius:12px;border:1px solid var(--line);flex-shrink:0;background:var(--bg-tint);color:var(--ink-3)!important}
.cart-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.cart-item-title{font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cart-item-cat{font-size:.66rem;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}
.cart-item-variant{color:var(--ink-3)!important;font-size:.72rem;margin-top:.2rem}
.cart-item-price{font-size:.92rem;font-weight:700;color:var(--ink);margin-top:.35rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.cart-item-price span span{color:var(--ink-3)!important;font-weight:500}
.cart-item-qty{border-color:var(--line)!important;background:rgba(17,17,20,.03)!important;border-radius:100px!important}
.cart-qty-btn{color:var(--ink-2)!important}
.cart-qty-btn:hover{color:var(--red)!important;background:rgba(214,31,52,.07)!important}
.cart-qty-inp{color:var(--ink)!important;border-color:var(--line)!important}
.cart-item-remove{display:none}
.cart-item-remove:hover{color:var(--red)!important;background:rgba(214,31,52,.08)!important}
/* Empty-State + Primär-Button (.btn-p) */
.cart-empty{text-align:center;color:var(--ink-3)}
.cart-empty .btn-p svg{display:none}
/* ── Toast (main.js erzeugt .vt-toast-*; war nur in style.css = auf mk-kreativ unsichtbar) → hell-glasig ── */
.vt-toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:100000;display:flex;flex-direction:column-reverse;gap:.6rem;pointer-events:none}
.vt-toast-item{background:rgba(255,255,255,.92);-webkit-backdrop-filter:saturate(1.6) blur(20px);backdrop-filter:saturate(1.6) blur(20px);border:1px solid var(--glass-bd);padding:.8rem 1rem;min-width:280px;max-width:380px;font-size:.82rem;font-family:var(--f-sans);display:flex;align-items:center;gap:.7rem;opacity:0;transform:translateY(12px);transition:opacity .2s ease-out,transform .2s ease-out;pointer-events:all;border-radius:14px;box-shadow:0 16px 44px rgba(17,17,20,.16),0 0 0 1px rgba(17,17,20,.04);position:relative;overflow:hidden}
.vt-toast-item.show{opacity:1;transform:translateY(0)}
.vt-toast-item.hide{opacity:0;transform:translateY(12px)}
.vt-toast-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px}
.vt-toast-icon svg{width:17px;height:17px}
.vt-toast-item.toast-ok .vt-toast-icon{background:rgba(22,163,74,.12);color:#16a34a}
.vt-toast-item.toast-warn .vt-toast-icon{background:rgba(214,31,52,.1);color:var(--red)}
.vt-toast-item.toast-error .vt-toast-icon{background:rgba(214,31,52,.12);color:var(--red)}
.vt-toast-body{flex:1;min-width:0}
.vt-toast-title{font-weight:600;font-size:.84rem;color:var(--ink);line-height:1.3}
.vt-toast-msg{color:var(--ink-3);font-size:.74rem;line-height:1.5;margin-top:.15rem}
.vt-toast-close{background:none;border:none;color:var(--ink-3);cursor:pointer;padding:4px;flex-shrink:0;display:flex;align-items:center;transition:color .15s}
.vt-toast-close:hover{color:var(--ink)}
.vt-toast-progress{position:absolute;bottom:0;left:0;width:100%;height:2px;border-radius:0 0 14px 14px;background:var(--red);transform-origin:left;animation:vtToastProgress linear forwards}
@keyframes vtToastProgress{to{transform:scaleX(0)}}
.vt-toast-item.toast-ok .vt-toast-progress{background:#16a34a}
.vt-toast-item.toast-warn .vt-toast-progress,.vt-toast-item.toast-error .vt-toast-progress{background:var(--red)}
@media(max-width:600px){.vt-toast{left:1rem;right:1rem;bottom:1rem}.vt-toast-item{min-width:auto;max-width:100%}}
/* Mehrere Auswahlen nebeneinander (Tabs Konto/Login) → rote scaleX-Unterstreichung bei Hover + aktiv, wie Header-Nav (.nav-link::after) */
.acct-tab,.auth-tab{position:relative}
.acct-tab::after,.auth-tab::after{content:'';position:absolute;left:.4rem;right:.4rem;bottom:-1px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);pointer-events:none}
.acct-tab:hover::after,.auth-tab:hover::after,.acct-tab.acct-tab-active::after,.auth-tab.active::after{transform:scaleX(1)}
.acct-tab.acct-tab-active,.auth-tab.active{border-bottom-color:transparent!important}
.btn-p{background:var(--ink);color:#fff;border:none;border-radius:100px;padding:.72rem 1.35rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s,transform .2s}
.btn-p:hover{}
/* Eingaben — Login/Konto/Checkout teilen .auth-input / .acct-input */
.auth-field{margin-bottom:.85rem}
.auth-label,.acct-lbl{display:block;font-size:.72rem;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem}
.auth-input,.acct-input{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);padding:.7rem .85rem;font-family:inherit;font-size:.92rem;border-radius:12px;outline:none;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
.auth-input:focus,.acct-input:focus{border-color:var(--ink);box-shadow:0 0 0 4px rgba(17,17,20,.05)}
.auth-input::placeholder,.acct-input::placeholder{color:var(--ink-3)}
/* Tabs — Login/Konto */
.auth-tabs,.acct-tablist{display:flex;gap:.2rem;margin-bottom:1.1rem;border-bottom:1px solid var(--line)}
.auth-tab,.acct-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--ink-3);padding:.7rem .5rem;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:color .15s,border-color .15s}
.auth-tab:hover,.acct-tab:hover{color:var(--ink)}
.auth-tab.active,.acct-tab.active,.acct-tab-active{color:var(--ink);border-bottom-color:transparent}
/* Primär-Buttons (Login/Konto/Checkout absenden) auf Ink-Pille zwingen (überschreibt JS-Inline) */
#authDrawerContent button[id$="Submit"],#checkoutContent button[id$="Submit"],#accountContent button[id$="Submit"]{background:var(--ink)!important;color:#fff!important;border:1px solid var(--ink)!important;border-radius:100px!important}
#authDrawerContent button[id$="Submit"]:hover,#checkoutContent button[id$="Submit"]:hover,#accountContent button[id$="Submit"]:hover{background:var(--ink)!important;border-color:var(--ink)!important;box-shadow:0 0 0 1.5px var(--red),0 8px 22px rgba(17,17,20,.18)!important}
/* Konto-Details */
.acct-hd-icon{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s}
.acct-hd-icon:hover{}
.acct-fav-empty{text-align:center;color:var(--ink-3);border:1px dashed var(--line);border-radius:14px;padding:2rem 1.2rem;font-size:.82rem}
.acct-fav-empty a{color:var(--red);text-decoration:none}
/* Konto-Drawer: main.js injiziert vtAcctTabsCSS (Gold + helle Texte) NACH mk-shop.css → mit !important auf hell/rot zwingen */
.acct-tab{color:var(--ink-3)!important}
.acct-tab:hover{color:var(--ink)!important}
.acct-tab.acct-tab-active{color:var(--ink)!important;border-bottom-color:transparent!important}
.acct-tab:focus-visible,.acct-hd-icon:focus-visible{outline-color:var(--ink)!important}
.acct-lbl{color:var(--ink-3)!important}
.acct-hd-icon{background:#fff!important;border:1px solid var(--line)!important;color:var(--ink)!important;opacity:1!important;border-radius:50%!important;width:34px!important;height:34px!important}
.acct-hd-icon:hover{transform:translateY(-2px)!important;background:#fff!important;color:var(--ink)!important;box-shadow:0 0 0 1.5px var(--red),0 10px 26px rgba(17,17,20,.14)!important}
.acct-hd-icon.is-active{background:rgba(214,31,52,.1)!important;border-color:rgba(214,31,52,.35)!important;color:var(--red)!important}
.acct-hd-icon.is-active svg{fill:var(--red)!important}
/* Konto-Avatar (Inline-Gold-Verlauf) + var(--gold)-Inline-Akzente → Ink/Rot */
.cart-drawer [style*="linear-gradient(135deg,#c8a96e"]{background:var(--ink)!important;color:#fff!important}
.cart-drawer [style*="var(--gold"]{color:var(--red)!important}
.cart-drawer [style*="200,169,110"]{border-color:var(--line)!important}

/* ═══ Admin-Promo-Banner (#vtPromoBanner, main.js) — dunkle Glas-Leiste wie .anno, roter Akzent ═══ */
.vt-promo-banner{position:fixed;top:var(--vt-sandbox-h,0);left:0;right:0;z-index:250;background:rgba(17,17,20,.85);-webkit-backdrop-filter:saturate(1.4) blur(18px);backdrop-filter:saturate(1.4) blur(18px);box-shadow:inset 0 -1px 0 rgba(255,255,255,.07);color:rgba(255,255,255,.82);font-family:inherit;font-size:13px}
.vt-promo-inner{max-width:none;margin:0;padding:9px clamp(1.25rem,4vw,4rem);padding-right:calc(clamp(1.25rem,4vw,4rem) + 32px);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:14px;position:relative;line-height:1.45}
.vt-promo-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--red);flex-shrink:0;width:22px;height:22px;border-radius:50%;background:rgba(214,31,52,.16);border:1px solid rgba(214,31,52,.32)}
.vt-promo-text{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px}
.vt-promo-text strong{color:#fff;font-weight:600}
.vt-promo-mid{color:rgba(255,255,255,.62)}
.vt-promo-code-wrap{display:inline-flex;align-items:center;gap:5px;padding:0 4px}
.vt-promo-code-lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);font-weight:500}
.vt-promo-code{display:inline-block;background:transparent;color:#fff;font-family:var(--f-mono);font-size:12px;font-weight:600;padding:2px 8px;border-radius:6px;letter-spacing:.06em;border:1px dashed rgba(214,31,52,.6)}
.vt-promo-sep{color:rgba(255,255,255,.22);margin:0 2px}
.vt-promo-until{color:rgba(255,255,255,.5);font-size:12px}
.vt-promo-date{color:rgba(255,255,255,.82);font-weight:500;font-size:12px}
.vt-promo-cta{display:inline-flex;align-items:center;gap:5px;font-family:inherit;font-size:12.5px;font-weight:600;color:#fff;text-decoration:none;border:none;background:transparent;padding:4px 0 4px 6px;white-space:nowrap}
.vt-promo-cta:hover{text-decoration:underline;text-underline-offset:3px}
.vt-promo-close{position:absolute;right:clamp(1rem,3vw,2rem);top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}
.vt-promo-close:hover{background:rgba(255,255,255,.12);color:#fff}

/* ═══ Hover-„Draw"-Linie: rote Fineline zeichnet sich einmal um den Button bis sie sich schließt ═══ */
/* Nur bei :hover (kein Dauer-Rahmen). Fallback ohne @property: roter Ring erscheint ohne Zeichen-Animation. */
/* ═══ Premium Button-Hover: feine rote Outline + dezente Anhebung + Press — EINHEITLICH (Apple/Stripe-Niveau) ═══ */
.btn,.ic-btn,.cart-checkout-btn,.cart-continue-btn,.cart-close,.btn-p,.acct-hd-icon,#scrollTop,#vtContactBubbleBtn,.nav-user{transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}
.btn:hover,.ic-btn:hover,.cart-checkout-btn:hover,.cart-continue-btn:hover,.cart-close:hover,.btn-p:hover,#scrollTop:hover,.nav-user:hover{transform:translateY(-2px);box-shadow:0 0 0 1.5px var(--red),0 10px 26px rgba(17,17,20,.14)}
.btn:active,.ic-btn:active,.cart-checkout-btn:active,.cart-continue-btn:active,.cart-close:active,.btn-p:active,.acct-hd-icon:active,#scrollTop:active,#vtContactBubbleBtn:active,.nav-user:active{transform:translateY(0) scale(.97)}
@media(prefers-reduced-motion:reduce){.btn:hover,.ic-btn:hover,.cart-checkout-btn:hover,.cart-continue-btn:hover,.cart-close:hover,.btn-p:hover,.acct-hd-icon:hover,#scrollTop:hover,#vtContactBubbleBtn:hover,.nav-user:hover{transform:none}.btn:active,.ic-btn:active,.cart-checkout-btn:active,.cart-continue-btn:active,.cart-close:active,.btn-p:active,.acct-hd-icon:active,#scrollTop:active,#vtContactBubbleBtn:active,.nav-user:active{transform:none}}
/* Schwarze/Filter-Buttons: gleiche rote Hover/Press-Animation wie .btn (User-Wunsch: überall einheitlich) */
.ref-cat-btn,.padd{transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease),color .2s var(--ease)}
.ref-cat-btn:hover,.padd:hover{transform:translateY(-2px);box-shadow:0 0 0 1.5px var(--red),0 10px 26px rgba(17,17,20,.14)}
.ref-cat-btn:active,.padd:active{transform:translateY(0) scale(.97)}
@media(prefers-reduced-motion:reduce){.ref-cat-btn:hover,.padd:hover,.ref-cat-btn:active,.padd:active{transform:none}}

/* ── Kontaktseite: Kontaktdetails + Formular + FAQ (mk-Premium) ── */
.form-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.ci{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.25rem}
.ci-icon{width:42px;height:42px;border-radius:11px;background:var(--glass-bg);border:1px solid var(--glass-bd);display:flex;align-items:center;justify-content:center;color:var(--red);flex-shrink:0}
.ci-label{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.18rem}
.ci-val{font-size:.96rem;color:var(--ink);line-height:1.5}
.ci-val a{color:inherit;text-decoration:none}.ci-val a:hover{color:var(--red)}
.cf{background:#fff;border:1px solid var(--line);border-radius:20px;padding:clamp(1.3rem,3vw,2rem);box-shadow:var(--glass-sh)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{margin-bottom:1rem;display:flex;flex-direction:column}
.fl{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);margin-bottom:.4rem}
.fi-in,.fi-ta{width:100%;box-sizing:border-box;background:var(--bg-soft);border:1px solid var(--line);border-radius:11px;padding:.7rem .9rem;font-family:var(--f-sans);font-size:.95rem;color:var(--ink);transition:border-color .15s,box-shadow .15s,background .15s}
.fi-in:focus,.fi-ta:focus{outline:none;background:#fff;border-color:var(--red);box-shadow:0 0 0 3px rgba(214,31,52,.1)}
.fi-ta{min-height:130px;resize:vertical;line-height:1.5}
.fcheck{display:flex;gap:.6rem;align-items:flex-start;font-size:.82rem;color:var(--ink-3);margin:.5rem 0}
.fcheck input{margin-top:.15rem;width:16px;height:16px;accent-color:var(--red);flex-shrink:0}
.fcheck a,.f-consent-info a{color:var(--red)}
.f-consent-info{font-size:.72rem;color:var(--ink-3);line-height:1.55;margin:.6rem 0 .8rem}
.f-submit{width:100%;background:var(--ink);color:#fff;border:none;border-radius:100px;padding:.85rem 1.5rem;font-family:var(--f-sans);font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.f-submit:hover{transform:translateY(-2px);box-shadow:0 0 0 1.5px var(--red),0 10px 26px rgba(17,17,20,.14)}
.f-submit:active{transform:translateY(0) scale(.97)}
.f-hint{font-size:.72rem;color:var(--ink-3);margin-top:.7rem;text-align:center}
.mk-faq{max-width:760px;margin:0 auto}
.mk-faq details{border:1px solid var(--line);border-radius:14px;margin-bottom:.7rem;background:#fff;overflow:hidden}
.mk-faq summary{padding:1rem 1.2rem;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--ink)}
.mk-faq summary::-webkit-details-marker{display:none}
.mk-faq summary::after{content:'+';font-size:1.3rem;line-height:1;color:var(--red);font-weight:400;transition:transform .2s}
.mk-faq details[open] summary::after{transform:rotate(45deg)}
.mk-faq details p{padding:0 1.2rem 1.1rem;color:var(--ink-3);font-size:.92rem;line-height:1.65;margin:0}
@media(max-width:760px){.form-grid{grid-template-columns:1fr}.fr{grid-template-columns:1fr}}

/* ── Rechtsseiten (Impressum/AGB/Datenschutz/Widerruf) — Prose ── */
.legal{max-width:820px;margin:0 auto;color:var(--ink-2);font-size:.95rem;line-height:1.75}
.legal h2{font-size:1.3rem;color:var(--ink);margin:2.2rem 0 .8rem;letter-spacing:-.01em}
.legal h3{font-size:1.05rem;color:var(--ink);margin:1.7rem 0 .5rem}
.legal>h2:first-child,.legal>h3:first-child{margin-top:0}
.legal p{margin:0 0 .9rem;color:var(--ink-3)}
.legal a{color:var(--red)}
.legal strong{color:var(--ink-2)}
.legal ul,.legal ol{margin:0 0 1rem;padding-left:1.3rem;color:var(--ink-3)}
.legal li{margin-bottom:.4rem}
.legal .lg{display:grid;grid-template-columns:repeat(auto-fit,minmax(235px,1fr));gap:1.1rem;margin-bottom:1.6rem}
.legal .lb{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.3rem}
.legal .lb h3{margin:0 0 .55rem;font-size:.95rem}
.legal .lb p{margin:0 0 .22rem;color:var(--ink-2);font-size:.92rem}
.legal .lb a{color:var(--red)}

/* Responsive */
@media (max-width:1000px){
  .hdr-nav{display:none}
  .burger{display:inline-flex}
  .search{max-width:none}
  .hero::after{background:linear-gradient(180deg,rgba(8,8,10,.32),rgba(8,8,10,.62))}
  .hero h1{max-width:none}
  .spot-in,.story-in{grid-template-columns:1fr;gap:2rem}
  .spot.rev .spot-img,.story-img{order:-1}
  .spot-img{aspect-ratio:16/10}
  .prod-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(140px,26vw,190px)}
  .cat-card:first-child{grid-column:span 2;grid-row:span 1}
  .occ-grid{grid-template-columns:repeat(3,1fr)}
  .trust-in{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr 1fr}
  .testi-grid>:nth-child(3){display:none}
}
@media (max-width:600px){
  .logo{font-size:1.2rem}
  .nav-user-name{display:none}
  .nav-user{padding:0 .2rem}
  .hdr-actions .ic-btn#userBtn{display:inline-flex}
  .occ-grid,.prod-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-auto-rows:42vw}
  .anno .hide-sm{display:none}
  .ft-grid,.testi-grid{grid-template-columns:1fr}
  .hero{min-height:auto;padding:3rem 0}
  .search-x.open .sx-input{width:min(74vw,330px)}
  .search-x .search-sug{width:min(88vw,360px)}
}
:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}

/* 312g Abs.2 Nr.1 BGB - Hinweis personalisierte Produkte (Widerruf ausgeschlossen) */
.vt-perso-note{margin-top:.7rem;padding:.6rem .85rem;font-size:.78rem;line-height:1.5;border-radius:10px;background:rgba(214,31,52,.07);border:1px solid rgba(214,31,52,.22);color:var(--red)}
.vt-perso-note strong{color:var(--red)}

/* ===== Konto-Drawer: Premium-Security-Karten (2FA / Login-Verlauf) — mk Light-Theme ===== */
/* Portiert aus varotech style.css (Gold/Dark) -> mk (Weiss/Ink/Rot). Klassen von vtRenderAcct2fa/vtRenderAcctLoginlog. */
.acct-set-row{padding:2px 0}
.acct-set-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.acct-set-title{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.005em}
.acct-set-desc{margin:5px 0 0;font-size:11.5px;color:var(--ink-3);line-height:1.55}
.acct-set-action{margin-top:12px}
.acct-set-action .acct-fav-btn{max-width:300px}
.acct-set-link{background:none;border:0;padding:0;cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;color:var(--ink-2);text-decoration:underline;text-underline-offset:2px;transition:color .15s ease}
.acct-set-link:hover{color:var(--ink)}
.acct-set-link--danger{color:var(--ink-2)}
.acct-set-link--danger:hover{color:var(--ink)}
.acct-set-link:focus-visible{outline:2px solid var(--red);outline-offset:2px;border-radius:3px}
.acct-set-form{margin-top:10px;max-width:300px}
.acct-sec-pill{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;letter-spacing:.02em;padding:4px 9px;border-radius:999px;white-space:nowrap}
.acct-sec-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.acct-sec-pill--on{color:var(--red);background:rgba(214,31,52,.1)}
.acct-sec-pill--off{color:var(--ink-3);background:rgba(17,17,20,.05)}
.acct-sec-pill--muted{color:var(--ink-3);background:rgba(17,17,20,.04)}
.acct-sec-note{margin:0;font-size:11.5px;color:var(--ink-3);line-height:1.5}
.acct-sec-skel{height:64px;border-radius:10px;background:linear-gradient(100deg,#f0f0ec 30%,#f7f7f3 50%,#f0f0ec 70%);background-size:200% 100%;animation:acctSkel 1.2s ease-in-out infinite}
@keyframes acctSkel{0%{background-position:200% 0}100%{background-position:-200% 0}}
@media (prefers-reduced-motion:reduce){.acct-sec-skel{animation:none}}
.acct-2fa-status{display:flex;align-items:center;gap:9px;margin-top:12px;padding:11px 13px;border-radius:10px;font-size:12.5px;line-height:1.4}
.acct-2fa-status svg{width:18px;height:18px;flex-shrink:0}
.acct-2fa-status--on{color:var(--red);background:rgba(214,31,52,.08);border:1px solid rgba(214,31,52,.22)}
.acct-2fa-status--off{color:var(--ink-3);background:var(--bg-soft);border:1px solid var(--line)}
.acct-2fa-meta{margin:11px 0 0;font-size:12px;line-height:1.55;color:var(--ink-3)}
.acct-2fa-meta strong{color:var(--ink);font-weight:600}
.acct-2fa-lbl{display:block;font-size:11.5px;font-weight:500;color:var(--ink-3);margin-bottom:5px;letter-spacing:-.005em}
.acct-2fa-input{width:100%;box-sizing:border-box;background:var(--bg-soft);border:1px solid var(--line);color:var(--ink);padding:9px 12px;border-radius:10px;font-family:inherit;font-size:13px;outline:none;transition:border-color .15s ease}
.acct-2fa-input:focus{border-color:var(--red)}
.acct-2fa-input::placeholder{color:var(--ink-3)}
.acct-2fa-err{margin:7px 0 0;font-size:11.5px;color:var(--red)}
.acct-fav-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;box-sizing:border-box;padding:10px 14px;border-radius:100px;font-family:inherit;font-size:13px;font-weight:600;letter-spacing:-.005em;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}
.acct-fav-btn:hover{box-shadow:0 0 0 1.5px var(--red),0 8px 22px rgba(17,17,20,.12)}
.acct-fav-btn:focus-visible{outline:2px solid var(--red);outline-offset:2px}
.acct-fav-btn--primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.acct-fav-btn--primary:hover{background:var(--ink);box-shadow:0 0 0 1.5px var(--red),0 8px 22px rgba(17,17,20,.18)}
.acct-2fa-btn-danger{color:var(--ink);border-color:rgba(214,31,52,.4);background:#fff}
.acct-2fa-btn-danger:hover{box-shadow:0 0 0 1.5px var(--red),0 8px 22px rgba(17,17,20,.12)}
.acct-2fa-codes{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:6px}
.acct-2fa-code{font-family:var(--f-mono),'DM Mono',monospace;font-size:12.5px;letter-spacing:.04em;color:var(--ink);background:var(--bg-soft);border:1px solid var(--line);border-radius:7px;padding:8px 6px;text-align:center}
.acct-loglist{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}
.acct-logitem{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;border:1px solid var(--line);background:var(--bg-soft)}
.acct-logitem__ico{flex-shrink:0;width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:rgba(214,31,52,.08);color:var(--red)}
.acct-logitem__ico svg{width:15px;height:15px}
.acct-logitem__body{min-width:0;display:flex;flex-direction:column;gap:1px}
.acct-logitem__event{font-size:12.5px;font-weight:500;color:var(--ink)}
.acct-logitem__meta{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums}
.acct-log-drop{border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);overflow:hidden}
.acct-log-summary{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;list-style:none;-webkit-tap-highlight-color:transparent;user-select:none}
.acct-log-summary::-webkit-details-marker{display:none}
.acct-log-summary:hover{background:rgba(17,17,20,.03)}
.acct-log-summary:focus-visible{outline:2px solid var(--red);outline-offset:-2px}
.acct-log-hdico{width:16px;height:16px;flex-shrink:0;color:var(--red)}
.acct-log-hdtxt{flex:1;font-size:12.5px;font-weight:600;color:var(--ink);letter-spacing:-.005em}
.acct-log-count{font-family:var(--f-mono),'DM Mono',monospace;font-size:10px;font-weight:400;color:var(--red);min-width:20px;text-align:center}
.acct-log-chev{width:14px;height:14px;flex-shrink:0;color:var(--ink-3);transition:transform .15s ease}
.acct-log-drop[open] .acct-log-chev{transform:rotate(180deg)}
.acct-log-panel{padding:2px 14px 12px;border-top:1px solid var(--line)}
.acct-log-privacy{margin:12px 0 0;padding-top:10px;border-top:1px solid var(--line);font-size:10.5px;color:var(--ink-3);line-height:1.5}
.acct-log-panel .acct-loglist{margin:4px 0 0;gap:0;position:relative}
.acct-log-panel .acct-logitem{position:relative;background:transparent;border:0;border-radius:0;padding:11px 0 11px 26px;align-items:flex-start;gap:0}
.acct-log-panel .acct-logitem::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:1px;background:var(--line)}
.acct-log-panel .acct-logitem:first-child::before{top:14px}
.acct-log-panel .acct-logitem:last-child::before{bottom:auto;height:14px}
.acct-log-panel .acct-logitem__ico{position:absolute;left:3px;top:13px;width:13px;height:13px;min-width:13px;padding:0;border-radius:50%;background:#fff;border:2px solid var(--red);display:block}
.acct-log-panel .acct-logitem__ico svg{display:none}
.acct-log-panel .acct-logitem--warn .acct-logitem__ico{border-color:#e2a14a}
.acct-log-panel .acct-logitem--ok .acct-logitem__ico{border-color:var(--red)}
.acct-log-panel .acct-logitem__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.acct-log-panel .acct-logitem__event{font-size:12.5px;font-weight:600;color:var(--ink);letter-spacing:-.005em}
.acct-log-panel .acct-logitem__meta{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums}

/* ===== Über-uns: Premium-Politur (UI-Skill: Liquid-Glass Storytelling) ===== */
/* Kennzahlen-Leiste */
.ab-stats-sec{padding:clamp(1rem,2.5vw,1.8rem) 0}
.ab-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:var(--r-lg);box-shadow:var(--glass-sh);padding:clamp(1.5rem,3vw,2.3rem) clamp(1.1rem,3vw,2rem)}
.ab-stat{text-align:center;position:relative}
.ab-stat:not(:last-child)::after{content:'';position:absolute;right:-.5rem;top:50%;transform:translateY(-50%);height:40px;width:1px;background:var(--line)}
.ab-stat-num{display:block;font-family:var(--f-sans);font-size:clamp(1.45rem,3.4vw,2.1rem);font-weight:700;letter-spacing:-.02em;color:var(--ink);line-height:1}
.ab-stat-lbl{display:block;font-family:var(--f-mono);font-size:.63rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-top:.6rem;line-height:1.45}
@media(max-width:680px){.ab-stats{grid-template-columns:repeat(2,1fr);gap:1.6rem 1rem}.ab-stat::after{display:none}}
/* Gründer-Signatur (Pull-Quote) */
.ab-sig{margin:1.8rem 0 0;padding:.1rem 0 .1rem 1.2rem;border-left:3px solid var(--red);font-size:1.06rem;line-height:1.62;color:var(--ink);font-style:italic}
.ab-sig cite{display:block;margin-top:.75rem;font-style:normal;font-family:var(--f-mono);font-size:.65rem;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-3)}
/* Prozess-Schritte */
.ab-step{background:var(--glass-bg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);border:1px solid var(--glass-bd);border-radius:18px;padding:1.7rem;box-shadow:var(--glass-sh);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.ab-step:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(17,17,20,.13);border-color:rgba(214,31,52,.25)}
.ab-step-num{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-weight:600;font-size:.92rem;margin-bottom:1rem;transition:background .3s var(--ease)}
.ab-step:hover .ab-step-num{background:var(--red)}
.ab-step h3{font-size:1.05rem;margin:0 0 .45rem;color:var(--ink)}
.ab-step p{color:var(--ink-3);font-size:.9rem;line-height:1.6;margin:0}
/* Werte-Cards: Hover-Politur */
.trust-card{transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.trust-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(17,17,20,.12);border-color:rgba(214,31,52,.22)}
.trust-card svg{transition:color .25s var(--ease)}
.trust-card:hover svg{color:var(--red)}
/* CTA-Buttons: Hover-States (waren leer) */
.btn-red,.btn-light{transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease)}
.btn-red:hover{transform:translateY(-2px);box-shadow:inset 0 1px 0 rgba(255,255,255,.26),0 14px 34px rgba(214,31,52,.42)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 0 0 1.5px var(--red),0 12px 30px rgba(17,17,20,.14)}
@media(prefers-reduced-motion:reduce){.ab-step,.trust-card,.btn-red,.btn-light,.ab-step-num,.trust-card svg{transition:none}.ab-step:hover,.trust-card:hover,.btn-red:hover,.btn-light:hover{transform:none}}

/* Konto-Buttons: Danger-Variante + Link-Reset (Daten-Export ist <a>) */
.acct-fav-btn{text-decoration:none}
.acct-fav-btn--danger{background:#fff;border-color:rgba(214,31,52,.38);color:var(--ink)}
.acct-fav-btn--danger:hover{box-shadow:0 0 0 1.5px var(--red),0 8px 22px rgba(17,17,20,.12)}

/* ===== Kundenstimmen-Marquee (Liquid-Glass, Auto-Scroll, Klick→Volltext-Modal) ===== */
.mk-rev-marquee{position:relative;width:100%;overflow:hidden;padding:.6rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.mk-rev-marquee.is-static{display:flex;justify-content:center;-webkit-mask-image:none;mask-image:none}
.mk-rev-track{display:flex;gap:1.4rem;width:max-content;animation:mkRevScroll 60s linear infinite;will-change:transform}
.mk-rev-marquee.is-static .mk-rev-track{animation:none;width:auto}
.mk-rev-marquee:hover .mk-rev-track{animation-play-state:paused}
@keyframes mkRevScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(calc(-100% / var(--mk-rev-loops,2)),0,0)}}
.mk-rev-card{flex:0 0 340px;width:340px;min-height:226px;text-align:left;cursor:pointer;font-family:inherit;
  display:flex;flex-direction:column;gap:.9rem;background:var(--glass-bg);
  -webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);
  border:1px solid var(--glass-bd);border-radius:18px;box-shadow:var(--glass-sh);padding:1.55rem 1.65rem;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.mk-rev-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(17,17,20,.12);border-color:rgba(214,31,52,.25)}
.mk-rev-stars{color:var(--red);letter-spacing:2px;font-size:.95rem;line-height:1;display:flex;gap:1px}
.mk-rev-stars .mk-rev-star-o{color:rgba(214,31,52,.22)}
.mk-rev-text{color:var(--ink-2);line-height:1.65;font-size:.96rem;margin:0;flex:1}
.mk-rev-more{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red);font-weight:600;opacity:.85;transition:opacity .2s}
.mk-rev-card:hover .mk-rev-more{opacity:1}
.mk-rev-who{display:flex;align-items:center;gap:.75rem;margin-top:auto}
.mk-rev-av{width:42px;height:42px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.82rem;letter-spacing:.02em;color:#fff;
  background:linear-gradient(135deg,var(--red),#a3162a);box-shadow:0 3px 10px rgba(214,31,52,.28)}
.mk-rev-meta{min-width:0;line-height:1.35}
.mk-rev-meta b{display:block;font-size:.92rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mk-rev-meta i{display:block;font-style:normal;font-size:.74rem;color:var(--ink-3);margin-top:1px}
/* Volltext-Modal */
.mk-rev-modal{position:fixed;inset:0;z-index:9000;background:rgba(17,17,20,.45);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:1.5rem;animation:mkRevFade .25s ease}
.mk-rev-modal.open{display:flex}
@keyframes mkRevFade{from{opacity:0}to{opacity:1}}
@keyframes mkRevUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
.mk-rev-modal-box{position:relative;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:2.2rem 2.3rem 1.9rem;
  box-shadow:0 24px 60px rgba(17,17,20,.22);animation:mkRevUp .3s cubic-bezier(.2,.8,.2,1)}
.mk-rev-modal-box .mk-rev-stars{font-size:1.2rem;margin-bottom:1rem}
.mk-rev-modal-x{position:absolute;top:1rem;right:1rem;width:34px;height:34px;border-radius:50%;
  background:var(--bg-soft);border:1px solid var(--line);color:var(--ink-2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,color .15s,border-color .15s}
.mk-rev-modal-x:hover{background:#fff;color:var(--red);border-color:rgba(214,31,52,.3)}
.mk-rev-modal-text{color:var(--ink-2);line-height:1.75;font-size:1rem;margin:0 0 1.5rem;white-space:pre-wrap;word-wrap:break-word}
.mk-rev-modal-box .mk-rev-who{margin-top:0}
@media(max-width:600px){.mk-rev-card{flex-basis:280px;width:280px;min-height:210px}}
@media(prefers-reduced-motion:reduce){.mk-rev-track{animation:none}.mk-rev-marquee{overflow-x:auto}.mk-rev-card:hover{transform:none}}
/* Footer Coded-by-Credit (zentriert, VaroTech 2-farbig) */
.ft-credit-line{text-align:center;margin-top:1.1rem;padding-top:.95rem;border-top:1px solid var(--line);font-size:.85rem}
.ft-credit{color:var(--ink-2);text-decoration:none;font-weight:600;letter-spacing:.01em;transition:opacity .2s var(--ease)}
.ft-credit:hover{opacity:.65}
.ft-credit .vt-t{color:#c8a96e}

/* Recently-Viewed / „Weiter stöbern"-Widget: von der gemeinsamen main.js injiziert
   (var(--white)/var(--gold) für varotech-dunkel gedacht). Auf mks hellem Frontend
   ist --white/--gold undefiniert → Fallback #fff = weiß-auf-weiß. mk-only Override → Ink/Rot. */
.vt-recent-sub,.vt-recent-card,.vt-recent-title{color:var(--ink)!important}
.vt-recent-label,.vt-recent-price{color:var(--red-ink)!important}
.vt-recent-img{background-color:#eceef2!important}
.vt-recent-img-empty{color:var(--ink-3)!important}
.vt-recent-card:hover .vt-recent-img{border-color:var(--red)!important}

/* Favoriten/Merkliste im Konto-Drawer — kompakte Zeilen-Optik (war nur in style.css,
   das die Shop-Seiten nicht laden → Favoriten waren ungestylt/riesig). mk-Palette. */
#acctFavList,.acct-fav-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.acct-fav-card{display:flex;align-items:center;gap:11px;padding:9px;background:#fff;border:1px solid var(--line);border-radius:10px;transition:border-color .15s var(--ease),background .15s var(--ease)}
.acct-fav-card:hover{border-color:var(--line-2,#dcdce2);background:var(--bg-soft,#f6f6f7)}
.acct-fav-media{flex-shrink:0;width:52px;height:52px;border-radius:6px;background:#eceef2;display:flex;align-items:center;justify-content:center;overflow:hidden;text-decoration:none}
.acct-fav-media img{width:100%;height:100%;object-fit:cover}
.acct-fav-media span{font-family:var(--f-mono),monospace;font-size:11px;color:var(--ink-3)}
.acct-fav-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.acct-fav-cat{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct-fav-title{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct-fav-price{font-family:var(--f-mono),monospace;font-size:12px;color:var(--red-ink);margin-top:1px}
.acct-fav-actions{display:flex;align-items:center;gap:5px;flex-shrink:0}
.acct-fav-iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;cursor:pointer;-webkit-tap-highlight-color:transparent;border:1px solid transparent;transition:all .15s var(--ease)}
.acct-fav-iconbtn:focus-visible{outline:2px solid var(--red);outline-offset:2px}
.acct-fav-iconbtn svg{width:16px;height:16px}
.acct-fav-iconbtn--add{background:var(--ink);color:#fff;border-color:var(--ink)}
.acct-fav-iconbtn--add:hover{box-shadow:0 0 0 1.5px var(--red)}
.acct-fav-iconbtn--del{background:transparent;color:var(--ink-3);border:1px solid var(--line)}
.acct-fav-iconbtn--del:hover{border-color:rgba(214,31,52,.5);color:var(--red);background:rgba(214,31,52,.06)}

/* ═══ Checkout — Glas-Style Zahlungs-Buttons + premium Versand-Balken (Audit 2026-06-15) ═══ */
.vt-checkout-methods{display:flex;flex-direction:column;gap:9px;margin-bottom:16px}
.vt-checkout-method{display:flex;align-items:center;gap:11px;padding:13px 15px;width:100%;box-sizing:border-box;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);text-align:left;
  background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid var(--glass-bd)!important;border-radius:14px!important;box-shadow:var(--glass-sh)!important;
  transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .15s,background .15s}
.vt-checkout-method:hover{transform:translateY(-1px);box-shadow:var(--glass-sh-hi)!important;border-color:rgba(214,31,52,.32)!important}
.vt-checkout-method.active{border-color:var(--red)!important;background:rgba(255,255,255,.72)!important;box-shadow:var(--glass-sh-hi),0 0 0 1px var(--red)!important}
.vt-checkout-radio{width:17px;height:17px;border-radius:50%;border:2px solid rgba(17,17,20,.20);flex-shrink:0;transition:all .15s}
.vt-checkout-method.active .vt-checkout-radio{background:var(--red);border-color:var(--red);box-shadow:inset 0 0 0 3px #fff}
.vt-checkout-method .ic{display:inline-flex;color:var(--ink-3)}
.vt-checkout-method.active .ic{color:var(--red)}
.vt-method-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.vt-method-btn{display:flex;align-items:center;gap:9px;padding:12px 13px;box-sizing:border-box;min-width:0;min-height:48px;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink);
  background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid var(--glass-bd)!important;border-radius:13px!important;box-shadow:var(--glass-sh)!important;
  transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .15s,background .15s}
.vt-method-btn:hover{transform:translateY(-1px);box-shadow:var(--glass-sh-hi)!important;border-color:rgba(214,31,52,.32)!important}
.vt-method-btn.active{border-color:var(--red)!important;background:rgba(255,255,255,.72)!important;box-shadow:var(--glass-sh-hi),0 0 0 1px var(--red)!important}
.vt-method-btn .ic{display:inline-flex;color:var(--ink-3);flex-shrink:0}
.vt-method-btn.active .ic{color:var(--red)}
.vt-method-btn .lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vt-coin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:16px}
.vt-coin-btn{box-sizing:border-box;min-height:48px;padding:9px 6px;text-align:center;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink);
  background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid var(--glass-bd)!important;border-radius:13px!important;box-shadow:var(--glass-sh)!important;transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .2s,border-color .15s}
.vt-coin-btn:hover{transform:translateY(-1px);box-shadow:var(--glass-sh-hi)!important;border-color:rgba(214,31,52,.32)!important}
.vt-coin-btn.active{border-color:var(--red)!important;background:rgba(255,255,255,.72)!important}
.vt-coin-btn .sym{font-family:'DM Mono',monospace;color:var(--ink-3);margin-right:3px}
.vt-coin-btn.active .sym{color:var(--red)}
/* Free-Shipping-Balken: premium Markenrot, abgerundet, mehr Abstand zum Button */
#cartFreeShipBar{margin:.65rem 0 1.15rem!important}
.vt-freeship-msg{margin-bottom:7px!important;font-size:.66rem!important}
.vt-freeship-bar{height:6px!important;border-radius:999px!important;background:rgba(17,17,20,.06)!important;overflow:hidden}
.vt-freeship-fill{background:linear-gradient(90deg,var(--red-ink),var(--red))!important;border-radius:999px!important;box-shadow:0 1px 4px rgba(214,31,52,.30)}
.vt-freeship-msg.is-unlocked ~ .vt-freeship-bar .vt-freeship-fill{background:linear-gradient(90deg,#15803d,#16a34a)!important}
/* Mobile: Eingabefelder >=16px → verhindert iOS-Safari Auto-Zoom beim Fokus (Go-Live Audit 2026-06-16) */
@media(max-width:600px){.auth-input,.acct-input,.search input,.sx-input,#searchInput,.coupon-input,input[type="text"],input[type="email"],input[type="tel"],input[type="password"],input[type="search"],input[type="number"],textarea,select{font-size:16px!important}}


/* ═══ Personalisierungs-Panel (Produktseite) — Premium, helle mk-Palette ═══ */
.vt-perso-panel{margin-top:16px;border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden;box-shadow:var(--sh-1)}
.vt-perso-head{display:flex;align-items:center;gap:9px;padding:12px 15px;border-bottom:1px solid var(--line-2);background:linear-gradient(180deg,rgba(214,31,52,.05),rgba(214,31,52,.012))}
.vt-perso-head .vt-perso-ic{width:16px;height:16px;color:var(--red);flex-shrink:0}
.vt-perso-title{font-weight:600;font-size:13.5px;color:var(--ink);letter-spacing:-.01em}
.vt-perso-sur{margin-left:auto;font-family:var(--f-mono);font-size:12px;font-weight:600;color:var(--red-ink);background:var(--red-soft);border:1px solid rgba(214,31,52,.22);padding:3px 11px;border-radius:100px;white-space:nowrap}
.vt-perso-body{padding:13px 15px;display:flex;flex-direction:column;gap:11px}
.vt-perso-line,.vt-perso-legal{display:flex;gap:9px;align-items:flex-start;line-height:1.55}
.vt-perso-line{font-size:12.5px;color:var(--ink-2)}
.vt-perso-line svg{color:var(--red)}
.vt-perso-legal{font-size:11.5px;color:var(--ink-3)}
.vt-perso-legal svg{color:var(--ink-3)}
.vt-perso-line svg,.vt-perso-legal svg{width:14px;height:14px;flex-shrink:0;margin-top:2px}


/* ═══ Konto: Bestell-Karten (Übersicht) — Premium, helle mk-Palette ═══ */
.vt-ocard{background:#fff;border:1px solid var(--line);border-radius:14px;cursor:pointer;transition:border-color .15s var(--ease),box-shadow .15s var(--ease),transform .12s var(--ease);margin-bottom:10px;overflow:hidden;box-shadow:var(--sh-1)}
.vt-ocard:hover{border-color:rgba(214,31,52,.35);box-shadow:var(--sh-2);transform:translateY(-1px)}
.vt-ocard-inner{padding:14px 16px}
.vt-ocard-hd{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:9px}
.vt-ocard-id{font-size:13px;color:var(--ink);font-weight:600;letter-spacing:-.01em;word-break:break-all;font-variant-numeric:tabular-nums}
.vt-ocard-date{color:var(--ink-3);font-size:11px;font-weight:400;white-space:nowrap;font-variant-numeric:tabular-nums}
.vt-ocard-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.vt-ocard-meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap;color:var(--ink-2);font-size:12px;font-weight:400}
.vt-ocard-meta .sep{color:var(--line)}
.vt-ocard-total{color:var(--ink);font-size:14.5px;font-weight:700;letter-spacing:-.01em;line-height:1;white-space:nowrap;font-variant-numeric:tabular-nums}
.vt-ocard-ft{display:none}
.vt-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:10.5px;font-weight:600;letter-spacing:.02em;flex-shrink:0;white-space:nowrap}
.vt-badge-pending{background:rgba(232,179,0,.15);color:#8a6a00}
.vt-badge-paid,.vt-badge-delivered{background:rgba(30,122,52,.12);color:#1f7a34}
.vt-badge-shipped{background:rgba(64,86,140,.12);color:#3f558c}
.vt-badge-cancelled,.vt-badge-refunded,.vt-badge-partially_refunded,.vt-badge-expired,.vt-badge-draft{background:rgba(17,17,20,.06);color:var(--ink-3)}
.vt-badge-disputed{background:var(--red-soft);color:var(--red-ink)}
.vt-pending-hint{margin-top:8px;display:flex;align-items:center;gap:6px;padding:7px 11px;background:rgba(232,179,0,.09);border:1px solid rgba(232,179,0,.22);border-radius:9px;color:#8a6a00;font-size:11.5px;font-weight:500}
.vt-badges{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-top:6px}

/* MK-Wappen (Kreis+Krone) im Header-Logo */
.logo-crest{width:46px;height:46px;flex-shrink:0;margin-right:3px;align-self:center;display:inline-block;position:relative;top:-4px}
@media(max-width:520px){.logo-crest{width:38px;height:38px;margin-right:5px;top:-3px}}

/* --------------------------------------------------------------------------
   THEME-PORTABLE SURFACES (geteiltes main.js):
   main.js ist mit VaroTech-Dunkel als Inline-Fallback geschrieben
   (rgba(var(--sf-ink,245,245,240),A), var(--sf-card,#161614) usw.).
   VaroTech definiert diese Tokens nicht -> Fallback = unveraendert dunkel.
   MK ueberschreibt sie hier scoped auf hell, NUR in Account-Drawer + Modals,
   damit Toasts u. a. ausserhalb ihren Dunkel-Fallback behalten.
   -------------------------------------------------------------------------- */
#accountDrawer,
#vtCancelReqOverlay,
#vtReviewOverlay,
#vtGoogleCrossPost{
  --sf-ink:17,17,20;          /* Primaertext-RGB fuer rgba(var(--sf-ink),A) */
  --sf-card:#ffffff;          /* Modal-/Karten-Hintergrund */
  --sf-inset:#f5f5f6;         /* Input-/Inset-Hintergrund */
  --sf-text:#111114;          /* Solide Textfarbe */
  --sf-bd:var(--line);        /* Input-Rahmen */
  --sf-cs:light;              /* color-scheme der Formfelder */
  /* VaroTech-Tokennamen, die Review-/Google-Modal direkt nutzen: */
  --card:#ffffff;
  --border:var(--line);
  --border2:var(--line);
  --white:var(--ink);
  --muted:var(--ink-3);
  --gold:var(--red);
  --black:#ffffff;
}
/* Submit-Button im Cancel-Modal: MK-Button-Regel (schwarzer Pill, weisser Text) */
#vtCancelReqOverlay #vtCancelSubmitBtn{
  background:var(--ink)!important;border-color:var(--ink)!important;color:#fff!important;
}
#vtCancelReqOverlay #vtCancelSubmitBtn:hover{
  box-shadow:0 0 0 2px var(--red)!important;
}

/* Sterne-Auswahl im Bewertungs-Modal (fehlte in MK -> Sterne wirkten unklickbar).
   Inaktiv = blasses Grau, aktiv/hover = Rot. Hover-Vorschau: ueberfahrene
   Sterne rot, dahinterliegende wieder grau (klassisches Sterne-Rating). */
.review-modal-stars{display:flex;gap:.35rem;margin:1rem 0}
.review-modal-stars span{font-size:2rem;line-height:1;cursor:pointer;color:var(--line-2,#e5e5ea);transition:color .15s;-webkit-user-select:none;user-select:none}
.review-modal-stars span.active{color:var(--red)}
.review-modal-stars:hover span{color:var(--red)}
.review-modal-stars span:hover~span{color:var(--line-2,#e5e5ea)}
