/* ═══════════════════════════════════════════════════════════
   SVH TEAMSHOP — Shop-Komponenten (teamshop.sv-heimstetten.de)
   Baut auf svh-base.css (Tokens, .btn, Footer) der Landingpage auf.
   ═══════════════════════════════════════════════════════════ */

/* Skip-Link */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--svh-rot);color:#fff;padding:10px 16px;z-index:3000;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ── Shop-Header (eigener Header mit Warenkorb) ── */
.shop-head{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--svh-linie)}
.shop-head__bar{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:0 24px;height:68px}
.shop-logo{display:flex;align-items:center;gap:11px;cursor:pointer;border:none;background:none;padding:0}
.shop-logo .svh-badge{height:42px;width:auto;max-width:56px}
.shop-logo__txt{display:flex;flex-direction:column;line-height:1.1;text-align:left}
.shop-logo__name{font-family:var(--font-display);font-size:15px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--svh-text)}
.shop-logo__sub{font-family:var(--font-display);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--svh-rot)}
.shop-head__spacer{flex:1}
.shop-head__back{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--svh-text-sek);padding:8px 10px;border-radius:8px}
.shop-head__back:hover{color:var(--svh-rot);background:var(--svh-bg)}
.cart-btn{position:relative;display:inline-flex;align-items:center;gap:8px;background:var(--svh-rot);color:#fff;padding:11px 16px;border-radius:var(--r-btn);font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:.03em;text-transform:uppercase;border:none;cursor:pointer}
.cart-btn:hover{background:var(--svh-rot-dunkel)}
.cart-btn svg{width:18px;height:18px}
.cart-badge{min-width:21px;height:21px;background:#fff;color:var(--svh-rot);border-radius:20px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;padding:0 6px}

/* ── Layout ── */
.wrap{max-width:1180px;margin:0 auto;padding:26px 24px 70px}
.crumb{font-size:13px;color:var(--svh-text-sek);margin-bottom:16px;font-weight:600}
.crumb button{background:none;border:none;color:var(--svh-rot);font-weight:700;cursor:pointer;font-size:13px;padding:0}
.crumb button:hover{text-decoration:underline}

/* ── Hero ── */
.shop-hero{position:relative;overflow:hidden;background:var(--svh-anthrazit);color:#fff;border-radius:var(--r-lg);padding:46px 38px;margin-bottom:22px}
.shop-hero::after{content:"";position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(174,21,32,.5),transparent 65%);pointer-events:none}
.shop-hero__in{position:relative;z-index:1;max-width:640px}
.eyebrow{display:inline-block;font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--svh-sand-hell);margin-bottom:14px}
.shop-hero h1{font-family:var(--font-display);font-size:clamp(28px,4.4vw,44px);font-weight:900;line-height:1;letter-spacing:-.02em;text-transform:uppercase;color:#fff;margin-bottom:12px}
.shop-hero p{color:rgba(255,255,255,.82);font-size:16px;line-height:1.6;max-width:56ch}

/* ── Faktenleiste ── */
.fakten{display:grid;grid-template-columns:repeat(4,1fr);background:var(--svh-rot);border-radius:var(--r-md);overflow:hidden;margin-bottom:26px}
.fakten div{padding:20px 12px;text-align:center;color:#fff;border-right:1px solid rgba(255,255,255,.16)}
.fakten div:last-child{border-right:none}
.fakten b{font-family:var(--font-display);display:block;font-size:22px;font-weight:900;letter-spacing:-.02em}
.fakten span{font-size:12px;opacity:.88}

.sec-head{margin:30px 0 14px}
.sec-head .eyebrow{color:var(--svh-rot);margin-bottom:6px}
.sec-head h2{font-family:var(--font-display);font-size:clamp(20px,3vw,28px);font-weight:900;letter-spacing:-.02em;text-transform:uppercase;color:var(--svh-text)}

/* ── Sparten-Grid ── */
.grid{display:grid;gap:16px}
.sparten{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.sparte-card{position:relative;background:#fff;border:1px solid var(--svh-linie);border-radius:var(--r-md);padding:24px 18px;text-align:center;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s}
.sparte-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--svh-rot-hell)}
.sparte-card .ico{font-size:38px;display:block;margin-bottom:8px}
.sparte-card b{font-family:var(--font-display);font-size:15px;font-weight:800;letter-spacing:-.01em;color:var(--svh-text)}
.sparte-card.disabled{opacity:.5;cursor:not-allowed}
.sparte-card.disabled:hover{transform:none;box-shadow:none;border-color:var(--svh-linie)}
.tag{position:absolute;top:8px;right:8px;font-family:var(--font-display);font-size:9.5px;font-weight:800;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.tag-live{background:var(--svh-erfolg);color:#fff}
.tag-soon{background:var(--svh-bg);color:var(--svh-text-sek)}

/* ── Filter ── */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}
.chip{padding:9px 14px;background:#fff;border:1px solid var(--svh-linie);border-radius:20px;font-weight:700;font-size:13.5px;color:var(--svh-text-2);cursor:pointer;font-family:var(--font-text)}
.chip:hover{border-color:var(--svh-rot-hell)}
.chip.active{background:var(--svh-text);color:#fff;border-color:var(--svh-text)}
.seg{display:inline-flex;background:#fff;border:1px solid var(--svh-linie);border-radius:var(--r-btn);overflow:hidden}
.seg button{padding:9px 18px;background:#fff;font-weight:700;color:var(--svh-text-2);font-size:13.5px;border:none;cursor:pointer;font-family:var(--font-text)}
.seg button.active{background:var(--svh-rot);color:#fff}

/* ── Produkt-Grid ── */
.produkte{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));margin-top:14px}
.p-card{background:#fff;border:1px solid var(--svh-linie);border-radius:var(--r-md);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s,border-color .18s}
.p-card:hover{box-shadow:var(--shadow-md);border-color:#d4d7db}
.p-img{height:170px;position:relative;display:flex;align-items:center;justify-content:center;background:var(--svh-sand);background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.08) 0 16px,rgba(0,0,0,.05) 16px 32px)}
.p-img .ph-ico{font-size:48px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.25))}
.p-img.has-img{background:#fff;background-image:none}
.p-img.has-img .ph-ico{display:none}
.p-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:10px;background:#fff}
.p-img .pct{position:absolute;bottom:8px;left:8px;background:var(--svh-rot);color:#fff;font-family:var(--font-display);font-size:11px;font-weight:900;padding:3px 8px;border-radius:6px;z-index:2}
.p-body{padding:14px;display:flex;flex-direction:column;flex:1}
.p-body .cat{font-family:var(--font-display);font-size:10.5px;color:var(--svh-grau);font-weight:800;text-transform:uppercase;letter-spacing:.14em}
.p-body h3{font-family:var(--font-display);font-size:15px;font-weight:800;margin:3px 0 2px;letter-spacing:-.01em;color:var(--svh-text)}
.p-body .sub{font-size:12px;color:var(--svh-text-sek);margin-bottom:10px;min-height:15px}
.price-row{margin-top:auto;display:flex;align-items:baseline;gap:8px}
.price{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--svh-rot)}
.uvp{font-size:13px;color:var(--svh-text-sek);text-decoration:line-through}
.p-card .btn{width:100%;margin-top:12px}

/* ── Overlays / Modal ── */
.overlay{position:fixed;inset:0;background:rgba(26,26,26,.55);z-index:2000;display:none;align-items:center;justify-content:center;padding:16px}
.overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);max-width:560px;width:100%;max-height:92vh;overflow:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--svh-linie);position:sticky;top:0;background:#fff;z-index:2}
.modal-head h2{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:-.01em;text-transform:uppercase;color:var(--svh-text);margin:0}
.x{font-size:26px;color:var(--svh-text-sek);background:none;border:none;line-height:1;padding:4px;cursor:pointer}
.x:hover{color:var(--svh-rot)}
.modal-body{padding:22px}
.field{margin-bottom:16px}
.field>label{display:block;font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--svh-text-2);margin-bottom:8px}
.field .hint{font-weight:600;color:var(--svh-text-sek);font-size:12px;text-transform:none;letter-spacing:0}
.sizes{display:flex;flex-wrap:wrap;gap:8px}
.size-btn{min-width:46px;padding:10px 12px;border:1.5px solid var(--svh-linie);background:#fff;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;font-family:var(--font-text)}
.size-btn:hover{border-color:var(--svh-rot-hell)}
.size-btn.active{border-color:var(--svh-rot);background:var(--svh-rot);color:#fff}
.badge-fix{display:inline-flex;align-items:center;gap:6px;background:var(--svh-rot-hell);color:var(--svh-rot-dunkel);border:1px solid var(--svh-rot-hell);padding:8px 12px;border-radius:8px;font-size:13px;font-weight:700}
.shop input[type=text],.shop input[type=number],.shop input[type=email],.shop select{width:100%;padding:12px 13px;border:1.5px solid var(--svh-linie);border-radius:8px;font-size:15px;font-family:inherit;background:#fff;-webkit-appearance:none}
.shop input:focus,.shop select:focus{outline:none;border-color:var(--svh-rot);box-shadow:0 0 0 3px rgba(174,21,32,.12)}
.toggle-row{display:flex;align-items:center;gap:10px;margin:14px 0 10px}
.toggle-row input{width:18px;height:18px;accent-color:var(--svh-rot)}
.toggle-row label{margin:0;cursor:pointer;font-size:14px;color:var(--svh-text-2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.preview-flock{background:var(--svh-anthrazit);color:#fff;border-radius:8px;padding:14px;text-align:center;margin-top:10px}
.preview-flock small{opacity:.7;display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.preview-flock .name{font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:3px;text-transform:uppercase}
.preview-flock .num{font-family:var(--font-display);font-size:30px;font-weight:900}
.field-err{color:var(--svh-rot);font-size:12.5px;font-weight:600;margin-top:8px;text-align:center}

/* ── Warenkorb-Drawer ── */
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:100%;background:#fff;z-index:2100;box-shadow:-6px 0 28px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .25s;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:18px 20px;border-bottom:1px solid var(--svh-linie);display:flex;justify-content:space-between;align-items:center}
.drawer-head h2{font-family:var(--font-display);font-size:18px;font-weight:800;text-transform:uppercase;margin:0}
.drawer-body{flex:1;overflow:auto;padding:14px 20px}
.drawer-foot{padding:18px 20px;border-top:1px solid var(--svh-linie)}
.ci{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--svh-linie)}
.ci .thumb{width:54px;height:54px;background:var(--svh-bg);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;overflow:hidden}
.ci .thumb img{width:100%;height:100%;object-fit:contain}
.ci .meta{flex:1;font-size:13px}
.ci .meta b{font-size:14px;font-family:var(--font-display);font-weight:800}
.ci .meta .sub{color:var(--svh-text-sek)}
.ci .qty{display:flex;align-items:center;gap:8px;margin-top:6px}
.ci .qty button{width:28px;height:28px;border:1px solid var(--svh-linie);border-radius:6px;background:#fff;font-weight:800;font-size:16px;line-height:1;cursor:pointer}
.ci .rm{color:var(--svh-text-sek);background:none;border:none;font-size:12px;text-decoration:underline;cursor:pointer;margin-top:4px;padding:0}
.sum-row{display:flex;justify-content:space-between;margin-bottom:6px;font-size:14px}
.sum-row.total{font-family:var(--font-display);font-size:19px;font-weight:900;margin:10px 0 14px}
.empty{text-align:center;color:var(--svh-text-sek);padding:48px 12px}
.empty svg{width:46px;height:46px;color:var(--svh-grau-300);margin-bottom:10px}

/* ── Checkout / Info ── */
.info-box{background:var(--svh-bg);border:1px solid var(--svh-linie);border-left:4px solid var(--svh-rot);border-radius:8px;padding:14px 16px;font-size:14px;line-height:1.55;color:var(--svh-text-2);margin-bottom:18px}
.mollie-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:12px 0}
.pm{border:1px solid var(--svh-linie);border-radius:6px;padding:6px 10px;font-size:12px;font-weight:700;background:#fff;color:var(--svh-text-2)}
.btn-green{background:var(--svh-erfolg);color:#fff;border-color:var(--svh-erfolg)}
.btn-green:hover{background:#176b2f;border-color:#176b2f}
.note{background:#FFF8E6;border:1px solid #F2D98A;border-radius:8px;padding:11px 14px;font-size:13px;color:#6b5200;margin-bottom:18px}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Danke-Seite ── */
.danke{max-width:640px;margin:0 auto;text-align:center;padding:60px 24px}
.danke__icon{width:74px;height:74px;border-radius:50%;background:var(--svh-erfolg);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:38px}
.danke h1{font-family:var(--font-display);font-size:clamp(26px,4vw,38px);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;color:var(--svh-text);margin-bottom:12px}
.danke p{color:var(--svh-text-sek);font-size:16px;line-height:1.7;margin-bottom:8px}
.danke .flow{display:flex;flex-direction:column;gap:8px;margin:26px 0;text-align:left}
.danke .step{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--svh-linie);border-radius:10px;padding:13px 16px}
.danke .step .n{width:26px;height:26px;background:var(--svh-erfolg);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex-shrink:0}
.danke .oid{font-family:var(--font-display);font-weight:900;color:var(--svh-rot)}

/* ── Loading / leer ── */
.loading{text-align:center;color:var(--svh-text-sek);padding:60px 12px}
.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.skel{height:300px;border-radius:var(--r-md);background:linear-gradient(100deg,#eee 30%,#f6f6f6 50%,#eee 70%);background-size:200% 100%;animation:sh 1.2s infinite}
@keyframes sh{to{background-position:-200% 0}}

/* Rechtliches-Leiste (Shop-spezifisch, über dem geteilten Footer) */
.shop-legal{max-width:1180px;margin:0 auto;padding:18px 24px;display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;font-size:13px;border-top:1px solid var(--svh-linie)}
.shop-legal a{color:var(--svh-text-sek);font-weight:600}
.shop-legal a:hover{color:var(--svh-rot)}

@media(max-width:680px){
  .shop-head__back{display:none}
  .shop-hero{padding:34px 24px}
  .grid2{grid-template-columns:1fr}
}
@media(max-width:560px){
  .fakten{grid-template-columns:repeat(2,1fr)}
  .fakten div:nth-child(2){border-right:none}
}
