/* ── Design Tokens ── */
:root{
  --brand:#D51D43;--brand-2:#FF6C8E;
  --bg:#ffffff;--bg-2:#ffffff;
  --fg:#1b1c1f;--muted:#5b5f6b;
  --card:#ffffff;--card-2:#fff7f9;
  --border:#f0c8d2;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{max-width:100%;overflow-x:hidden}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--fg);background:#fff;display:flex;flex-direction:column;min-height:100vh}
main{flex:1}
a{color:var(--brand)}

/* Container */
.container{width:min(1100px,92vw);margin:0 auto;overflow-x:clip}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border);backdrop-filter:saturate(1.1) blur(6px);transition:transform .3s ease}
.nav{display:flex;align-items:center;gap:20px;padding:8px 0;position:relative}
.nav a{color:var(--fg);text-decoration:none;font-size:14px;font-weight:700}
.nav a:hover{color:var(--brand)}
.nav .spacer{flex:1}
.nav img{height:40px;width:auto;object-fit:contain}
.burger{display:none;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.6));border:1.5px solid var(--border);border-radius:12px;color:var(--brand);cursor:pointer;padding:8px 11px;line-height:0}
@media(max-width:720px){
  .burger{display:flex;align-items:center;justify-content:center;position:absolute;right:12px;top:50%;transform:translateY(-50%);z-index:100;padding:10px 14px;border-radius:14px}
  header .container.nav a:not(.logo){display:none}
}
.mobile-menu{display:none;position:sticky;left:0;right:0;top:0;background:rgba(255,255,255,.98);border-top:1px solid var(--border);box-shadow:0 8px 20px rgba(213,29,67,.08);z-index:49}
.mobile-menu .menu-inner{padding:4px 20px 12px}
.mobile-menu a{display:block;padding:12px 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--fg);font-size:17px}
.mobile-menu a:last-child{border-bottom:none}
body.menu-open .mobile-menu{display:block}

/* Page Header (Unterseiten) */
.page-header{background:linear-gradient(135deg,#7a0a20 0%,#D51D43 60%,#e8456a 100%);padding:28px 0 24px}
.page-header .kicker{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:6px}
.page-header h1{font-size:clamp(22px,4vw,32px);font-weight:900;color:#fff;text-transform:uppercase;line-height:1.1;margin:0 0 6px}
.page-header p{color:rgba(255,255,255,.7);font-size:14px;margin:0}

/* Hero */
.hero-new{background:linear-gradient(135deg,#7a0a20 0%,#D51D43 60%,#e8456a 100%);padding:44px 0 36px;position:relative;overflow:hidden}
.hero-bg-img{position:absolute;top:0;right:calc(50% - 550px);height:100%;width:700px;object-fit:cover;object-position:center;mix-blend-mode:multiply;opacity:0.55;pointer-events:none;user-select:none}
.hero-pill{padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.25)}
.hero-title{font-size:clamp(30px,5vw,44px);font-weight:900;color:#fff;line-height:1.05;letter-spacing:-.02em;text-transform:uppercase;margin:14px 0 12px}
.hero-lead{color:rgba(255,255,255,.75);font-size:15px;max-width:480px;line-height:1.55;margin:0 0 22px}
.btn-white{display:inline-flex;align-items:center;padding:11px 22px;border-radius:10px;background:#fff;color:var(--brand);font-weight:800;font-size:14px;text-decoration:none}
.btn-ghost{display:inline-flex;align-items:center;padding:11px 22px;border-radius:10px;background:rgba(255,255,255,.15);color:#fff;font-weight:700;font-size:14px;text-decoration:none;border:1px solid rgba(255,255,255,.3)}

/* Stats */
.stats-strip{background:#fff;border-bottom:1px solid var(--border)}.stats-strip-inner{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;width:min(1100px,92vw);margin:0 auto}
.stat-cell{padding:16px 8px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px}
.stat-cell+.stat-cell{border-left:1px solid var(--border)}
.stat-num{font-size:clamp(18px,3vw,26px);font-weight:900;color:var(--brand);line-height:1.1;display:flex;align-items:center;justify-content:center;text-align:center;padding:16px 8px 8px}
.stat-lbl{font-size:clamp(10px,1.5vw,12px);color:var(--muted);line-height:1.35;text-align:center;padding:0 8px 16px;align-self:start}

/* Sections */
.section{padding:52px 0;background:#fff}
.section-tinted{padding:52px 0;background:#fff7f9}
.section-dark{background:linear-gradient(135deg,#6a0018 0%,#a81228 55%,#C4203D 100%);padding:52px 0}
.section-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
h1{font-size:clamp(26px,4vw,40px);margin:0 0 10px}
h2{font-size:clamp(20px,3vw,28px);margin:0 0 12px;font-weight:800;color:var(--fg)}
p.lead{color:var(--muted);margin:0 0 18px;font-size:15px}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 4px 16px rgba(213,29,67,.06)}
.card-grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
@media(max-width:720px){.card-grid{grid-template-columns:1fr}}
.icon-box{width:36px;height:36px;border-radius:10px;background:#ffe0e7;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.badge{display:inline-block;font-size:12px;padding:5px 10px;background:#ffe0e7;border:1px solid var(--border);border-radius:999px;color:#9c1736}

/* Dark section */
.dark-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:720px){.dark-grid{grid-template-columns:1fr;gap:28px}}

/* Buttons */
.button{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;border:1px solid var(--border);color:var(--fg);text-decoration:none;font-weight:700;background:linear-gradient(180deg,rgba(255,255,255,.6),rgba(255,255,255,.4))}
.button.primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff}
.button.block{width:100%;justify-content:center}

/* Forms */
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:720px){.row{grid-template-columns:1fr}}
input,select,textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:#fff;color:var(--fg);font-family:inherit;font-size:14px}
input[type=number]{appearance:textfield}
input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=range]{height:34px;padding:0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));border:none}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));border:none}
label{display:block;font-size:13px;font-weight:600;color:var(--fg);margin-bottom:5px}
.small{font-size:13px;color:var(--muted)}

/* Tooltip */
.tooltip-container{position:relative;display:inline-block;cursor:pointer;padding:4px;margin:-4px;border-radius:6px}
.tooltip-container .tooltip-text{visibility:hidden;width:min(260px,80vw);background:#1b1c1f;color:#fff;padding:10px;border-radius:8px;position:fixed;z-index:200;margin-top:6px;font-size:12px;line-height:1.5;font-weight:400;left:50%;transform:translateX(-50%);top:auto}
.tooltip-container:hover .tooltip-text{visibility:visible}.tooltip-container.tt-open .tooltip-text{visibility:visible}

/* Summary boxes */
.summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.summary .box{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px}
.strikethrough{text-decoration:line-through;color:#aaa}
.underlined{text-decoration:underline;font-weight:800}

/* Rechner Kategorie-Tabs */
.cat-tabs-wrap{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.cat-tab{padding:13px 36px;border-radius:14px;border:1.5px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.6));color:var(--fg);cursor:pointer;font-size:17px;font-weight:700;transition:background .15s,border-color .15s,color .15s;white-space:nowrap;box-shadow:0 2px 8px rgba(213,29,67,.06)}
.cat-tab.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff}
.prod-tab{width:100%;padding:10px 6px;border-radius:10px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.4));color:var(--fg);cursor:pointer;font-size:13px;font-weight:600;line-height:1.35;transition:background .15s,border-color .15s,color .15s;text-align:center}
.prod-tab.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff}
.prod-tab small{font-weight:400;opacity:.85}
.anderes-tab{border:2px dashed var(--brand)!important;font-weight:800!important}
.anderes-short{display:none}
.anderes-long{display:inline}
.method-tab{width:100%;padding:10px 8px;border-radius:10px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.4));color:var(--fg);cursor:pointer;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,color .15s}
.method-tab.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#fff}
.color-swatch{width:30px;height:30px;border-radius:50%;cursor:pointer;flex-shrink:0;transition:transform .15s,box-shadow .15s;padding:0;-webkit-tap-highlight-color:transparent;border:2px solid transparent}
.color-swatch.active{transform:scale(1.22);box-shadow:0 0 0 2.5px var(--brand)}
.prod-info-list{list-style:none;padding:0;margin:0;font-size:13px;color:var(--muted)}
.prod-info-list li{padding:4px 0;border-bottom:1px dashed var(--border)}
.prod-info-list li:last-child{border-bottom:none}
.prod-img-box{border-radius:12px;overflow:hidden;border:1px solid var(--border);background:linear-gradient(135deg,#ffe0e7,#fff1f4);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.prod-img-box img{width:100%;height:100%;object-fit:contain;display:block}
.mobile-prod-info{display:none}
.rg{display:grid;grid-template-columns:1fr 1.6fr;grid-template-areas:"img right" "sw right" "info right";column-gap:28px;row-gap:6px;align-items:start}
.rg-img{grid-area:img}
.rg-right{grid-area:right;display:flex;flex-direction:column;gap:8px}
.rg-sw{grid-area:sw}
.rg-info{grid-area:info}
#shirt-swatches,#polo-swatches{display:flex;gap:10px;flex-wrap:wrap}
.anfrage-box{margin-top:14px;padding:16px;border-radius:12px;background:#fff1f4;border:1px solid var(--border);text-align:center}
.anfrage-box p{margin:0;color:var(--muted);font-size:14px}
.anfrage-box strong{display:block;font-size:18px;color:var(--brand);margin-bottom:4px}
.cat-section{display:none}
.cat-section.active{display:block}

/* FAQ accordion */
.faq-new-item{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff;transition:box-shadow .2s;margin-bottom:10px}
.faq-new-item.open{box-shadow:0 4px 16px rgba(213,29,67,.1)}
.faq-new-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border:none;cursor:pointer;text-align:left;gap:12px;font-family:inherit}
.faq-new-q:hover{background:#fff7f9}
.faq-new-q-text{font-size:15px;font-weight:700;color:var(--fg);line-height:1.3}
.faq-new-icon{width:24px;height:24px;border-radius:50%;background:#ffe0e7;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:700;color:var(--brand);transition:transform .25s;line-height:1}
.faq-new-item.open .faq-new-icon{transform:rotate(45deg);background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
.faq-new-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-new-item.open .faq-new-a{max-height:500px}
.faq-new-a-inner{padding:0 20px 18px;font-size:14px;color:var(--muted);line-height:1.7;border-top:1px solid var(--border)}
.faq-new-a-inner p{margin-top:12px}
.faq-cat-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:12px;margin-top:4px}
.faq-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:720px){.faq-cols{grid-template-columns:1fr}}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gallery{grid-template-columns:1fr}}
.gallery .tile{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card)}
.gallery img{width:100%;height:220px;object-fit:cover;display:block}

/* Leistungen */
.leistungen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch;margin-top:18px}
.kachel{background:linear-gradient(180deg,rgba(213,29,67,.04),rgba(213,29,67,.01));border-radius:12px;overflow:hidden;box-shadow:0 4px 14px rgba(0,0,0,.05);display:flex;flex-direction:column}
.kachel .imgwrap{width:100%;aspect-ratio:16/10;overflow:hidden;flex:0 0 auto}
.kachel img{width:100%;height:100%;object-fit:cover;display:block}
.kachel .kachel-body{padding:14px 12px;flex:1 1 auto;display:flex;flex-direction:column;justify-content:space-between}
.kachel h3{margin:0 0 8px;font-size:1.05rem;color:#111}
.kachel p{margin:0;color:#444;font-size:.95rem;line-height:1.4}
@media(max-width:900px){.leistungen-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.leistungen-grid{grid-template-columns:1fr}}

/* Footer */
footer{margin-top:0;padding:0;border-top:none;color:var(--muted);background:#1a0008}
.footer-dark{background:linear-gradient(180deg,#8a0e20 0%,#3d0410 50%,#1a0008 100%);padding:36px 0 0}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:720px){.footer-grid{grid-template-columns:1fr;gap:20px}}
.footer-logo{height:36px;margin-bottom:12px;display:block;width:auto}
.footer-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:4px}
.footer-addr{font-size:13px;color:rgba(255,255,255,.55);line-height:1.9}
.footer-addr a{color:rgba(255,255,255,.75);text-decoration:none}
.foot-kataloge{border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:16px 20px;background:rgba(255,255,255,.06)}
.kicker{font-size:12px;font-weight:700;color:#fff;display:block;margin-bottom:8px}
.footer-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:0}
.footer-links a{font-size:12px;color:rgba(255,255,255,.6);text-decoration:underline}
.end{padding:12px 0;background:rgba(0,0,0,.4);width:100%;display:block}
.end small{font-size:11px;color:rgba(255,255,255,.45)}
.end a{font-size:11px;color:rgba(255,255,255,.5);text-decoration:none}

/* Forms */
.form-status{margin-top:8px;font-size:.95rem;opacity:.92}
.kd-success{margin-top:14px;padding:16px;border-radius:12px;background:#f0fdf4;border:1px solid #86efac;color:#14532d}
.kd-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#1b1c1f;color:#fff;padding:12px 24px;border-radius:12px;opacity:0;transition:all .3s;z-index:999;pointer-events:none}
.kd-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Skeleton */
.skeleton{position:relative;overflow:hidden;background:#f0e0e5;border-radius:8px}
.skeleton::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);animation:skeleton-shimmer 1.4s infinite}
@keyframes skeleton-shimmer{to{transform:translateX(100%)}}
img.lazy-img{opacity:0;transition:opacity .35s ease}
img.lazy-img.loaded{opacity:1}

/* Mobile Rechner */
@media(max-width:680px){
  .cat-tab{padding:11px 18px;font-size:14px;width:100%}
  .cat-tabs-wrap{flex-direction:column;gap:8px;align-items:stretch;margin-bottom:20px}
  .rg{grid-template-columns:115px 1fr;grid-template-areas:"img tabs" "sw sw" "calc calc" "info info";column-gap:10px;row-gap:8px}
  .rg-right{display:contents}
  .rg-tabs{grid-area:tabs}
  .rg-calc{grid-area:calc}
  .prod-img-box{aspect-ratio:1/1}
  .prod-tabs-grid{grid-template-columns:1fr 1fr!important;gap:5px!important}
  .prod-tab{font-size:11px;padding:7px 3px;line-height:1.25}
  .prod-tab small{font-size:10px}
  .anderes-short{display:inline}
  .anderes-long{display:none}
  #shirt-swatches,#polo-swatches{flex-wrap:nowrap;overflow-x:auto;padding:5px 8px 8px 4px;scrollbar-width:none;-ms-overflow-style:none;gap:8px}
  #shirt-swatches::-webkit-scrollbar,#polo-swatches::-webkit-scrollbar{display:none}
  .color-swatch{width:27px;height:27px}
  .rg-info{display:none}
  .mobile-prod-info{display:block;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
  .mobile-prod-info:empty{display:none}
}

/* Ref preview mobile */
@media(max-width:680px){
  #ref-preview{grid-template-columns:1fr!important}
  #ref-preview .tile img{height:200px}
}
#kontakt-leistungen{margin-top:28px}

.hero-new .hero-facts span{color:#fff!important}
@media(max-width:720px){
  .tooltip-container .tooltip-text{
    width:min(280px,90vw);
    left:50%!important;
    transform:translateX(-50%)!important;
    position:fixed!important;
    top:auto!important;
    bottom:80px!important;
  }
}

@media(max-width:720px){.tooltip-container .tooltip-text{width:72vw;left:auto;right:-8px;top:auto;bottom:calc(100% + 8px)}}
@media(max-width:720px){input[type=range]{margin-bottom:10px}}
.stats-strip-inner .stat-num:nth-child(2),.stats-strip-inner .stat-lbl:nth-child(5){border-left:1px solid var(--border)}
.stats-strip-inner .stat-num:nth-child(3),.stats-strip-inner .stat-lbl:nth-child(6){border-left:1px solid var(--border)}
/* Tooltip Banner (Mobile only) */
.tt-banner{display:none}
@media(max-width:720px){
  .tt-banner{display:block;position:fixed;top:0;left:0;right:0;z-index:999;background:#1b1c1f;color:#fff;font-size:13px;line-height:1.5;padding:14px 16px 14px 48px;transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.8,.3,1);box-shadow:0 4px 20px rgba(0,0,0,.3)}
  .tt-banner.show{transform:translateY(0)}
  .tt-banner .tt-close{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px;color:rgba(255,255,255,.6);background:none;border:none;cursor:pointer;padding:4px;line-height:1}
  .tooltip-container svg,.tooltip-container circle,.tooltip-container text{pointer-events:none}
  .tooltip-container .tooltip-text{display:none!important}
}
/* ── Cookie Banner ─────────────────────────────────────────── */
.kd-cookie{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#1a0008;border-top:1px solid rgba(255,255,255,.12);padding:18px 20px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;transform:translateY(100%);transition:transform .35s ease;box-shadow:0 -4px 24px rgba(0,0,0,.3)}
.kd-cookie.kd-cookie--visible{transform:translateY(0)}
.kd-cookie__text{flex:1;min-width:220px;font-size:13px;color:rgba(255,255,255,.85);line-height:1.5}
.kd-cookie__text a{color:#FF6C8E;text-decoration:underline}
.kd-cookie__actions{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.kd-cookie__btn{padding:9px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:none;line-height:1;white-space:nowrap}
.kd-cookie__btn--accept{background:#D51D43;color:#fff}
.kd-cookie__btn--accept:hover{background:#b81636}
.kd-cookie__btn--decline{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}
.kd-cookie__btn--decline:hover{background:rgba(255,255,255,.2)}
@media(max-width:600px){.kd-cookie{padding:14px 16px}.kd-cookie__actions{width:100%}.kd-cookie__btn{flex:1;text-align:center}}
