/*
Theme Name: Phenoroots
Theme URI: https://phenoroots.de
Author: Phenoroots
Author URI: https://phenoroots.de
Description: Offizielles Custom-Theme für Phenoroots – AironiX Low Pressure System. Inkl. WooCommerce.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: phenoroots
Tags: woocommerce, ecommerce, dark, modern
*/

/* ================================================
   RESET & BASE
   ================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0a;
  --bg2:#111111;
  --bg3:#161616;
  --bg4:#1c1c1c;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.12);
  --text:#f0f0f0;
  --text2:#999;
  --text3:#666;
  --accent:#c8ff00;
  --accent2:#a8e000;
  --white:#ffffff;
  --font-h:'Syne',sans-serif;
  --font-b:'Inter',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-h);color:var(--white);line-height:1.15;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem)}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}

/* WordPress admin bar offset */
.admin-bar nav{top:32px}
@media(max-width:782px){.admin-bar nav{top:46px}}

/* ================================================
   NAV
   ================================================ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 5vw;
  background:rgba(10,10,10,0.9);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo img{height:104px;width:auto;display:block}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{
  font-size:0.78rem;font-weight:400;letter-spacing:0.06em;
  color:var(--text2);text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover{color:var(--text)}
.nav-cta{
  background:var(--accent)!important;color:#000!important;
  padding:0.55rem 1.4rem;border-radius:4px;
  font-weight:600!important;font-size:0.78rem!important;
  letter-spacing:0.06em!important;transition:background 0.2s!important;
}
.nav-cta:hover{background:var(--accent2)!important}
.nav-links a.active{color:var(--accent)!important}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--text2);transition:all 0.2s}
.mobile-nav{
  display:none;position:fixed;inset:0;top:60px;z-index:190;
  background:rgba(10,10,10,0.97);backdrop-filter:blur(20px);
  flex-direction:column;align-items:center;justify-content:center;gap:2rem;
}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:1.1rem;color:var(--text2);text-decoration:none;letter-spacing:0.06em}
.mobile-nav a.nav-cta{background:var(--accent);color:#000;padding:0.75rem 2rem;border-radius:4px}

/* ================================================
   HERO
   ================================================ */
.hero{
  min-height:100vh;
  display:grid;grid-template-columns:1fr 1fr;
  padding-top:4.5rem;
  position:relative;overflow:hidden;
  background:var(--bg);
}
.hero-noise{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;
}
.hero-grid-lines{
  position:absolute;inset:0;z-index:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,black 0%,transparent 100%);
}
.hero-left{
  position:relative;z-index:1;
  display:flex;flex-direction:column;justify-content:center;
  padding:7rem 3rem 5rem 5vw;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:0.5rem;
  border:1px solid var(--border2);border-radius:99px;
  padding:0.3rem 0.875rem;
  font-size:0.7rem;font-weight:500;letter-spacing:0.1em;
  color:var(--text2);margin-bottom:2rem;width:fit-content;
  text-transform:uppercase;
}
.tag-dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}
h1.hero-h{
  font-family:var(--font-h);
  font-size:clamp(3rem,5vw,5rem);
  font-weight:800;line-height:1.0;
  letter-spacing:-0.02em;
  color:var(--white);margin-bottom:1.5rem;
}
h1.hero-h .hl{color:var(--accent)}
.hero-desc{
  font-size:0.95rem;font-weight:300;color:var(--text2);
  line-height:1.75;max-width:42ch;margin-bottom:2.5rem;
}
.hero-actions{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:3rem}
.btn-acc{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--accent);color:#000;
  text-decoration:none;font-family:var(--font-b);
  font-size:0.85rem;font-weight:600;
  padding:0.85rem 1.875rem;border-radius:4px;
  transition:all 0.2s;border:1px solid transparent;letter-spacing:0.02em;
}
.btn-acc:hover{background:var(--accent2)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:0.5rem;
  color:var(--text2);text-decoration:none;
  font-size:0.85rem;font-weight:400;
  padding:0.85rem 1.5rem;border:1px solid var(--border2);
  border-radius:4px;transition:all 0.2s;
}
.btn-ghost:hover{color:var(--text);border-color:rgba(255,255,255,0.25)}
.hero-stats{
  display:flex;gap:2.5rem;padding-top:2rem;
  border-top:1px solid var(--border);
}
.hstat-num{
  font-family:var(--font-h);font-size:1.6rem;font-weight:700;
  color:var(--white);line-height:1;margin-bottom:0.2rem;
}
.hstat-label{font-size:0.72rem;color:var(--text3);font-weight:400;letter-spacing:0.04em}
.hero-right{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;
  padding:5rem 4rem 4rem 2rem;
}
.hero-img-outer{position:relative;width:100%;max-width:400px}
.hero-product-img{
  width:100%;aspect-ratio:3/4;object-fit:contain;display:block;
  filter:drop-shadow(0 40px 80px rgba(200,255,0,0.08)) drop-shadow(0 0 1px rgba(255,255,255,0.05));
}
.hero-float-badge{
  position:absolute;top:2rem;left:-2rem;
  background:var(--bg3);border:1px solid var(--border2);
  border-radius:8px;padding:0.875rem 1.25rem;
  backdrop-filter:blur(10px);
}
.hfb-label{font-size:0.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.25rem}
.hfb-val{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--white)}
.hero-float-badge2{
  position:absolute;bottom:3rem;right:-1.5rem;
  background:var(--accent);border-radius:8px;padding:0.875rem 1.25rem;
}
.hfb2-label{font-size:0.65rem;color:rgba(0,0,0,0.6);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.2rem}
.hfb2-val{font-family:var(--font-h);font-size:1rem;font-weight:700;color:#000}

/* ================================================
   MARQUEE STRIP
   ================================================ */
.strip{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:0.875rem 0;overflow:hidden;background:var(--bg2);
}
.strip-track{
  display:flex;gap:4rem;white-space:nowrap;
  animation:marquee 28s linear infinite;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.strip-item{
  display:flex;align-items:center;gap:0.75rem;
  font-size:0.72rem;font-weight:500;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--text3);flex-shrink:0;
}
.strip-item .sdot{color:var(--accent);font-size:0.5rem}

/* ================================================
   SECTIONS
   ================================================ */
.section{padding:8rem 0}
.si{max-width:1200px;margin:0 auto;padding:0 5vw}
.slabel{
  font-size:0.68rem;font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--accent);margin-bottom:0.875rem;
}
.stitle{
  font-family:var(--font-h);
  font-size:clamp(2rem,3.5vw,3rem);
  font-weight:700;letter-spacing:-0.02em;
  color:var(--white);line-height:1.1;
}
.stitle .hl{color:var(--accent)}

/* ================================================
   FEATURES
   ================================================ */
.feat-section{background:var(--bg2)}
.feat-layout{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:start}
.feat-sticky{position:sticky;top:7rem}
.feat-product-img{
  width:100%;aspect-ratio:1;object-fit:contain;
  border:1px solid var(--border);border-radius:8px;
  padding:2.5rem;background:var(--bg3);
}
.feat-list{display:flex;flex-direction:column;gap:0}
.feat-item{
  padding:1.75rem 0;border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:2.5rem 1fr;gap:1.25rem;align-items:start;
}
.feat-item:first-child{border-top:1px solid var(--border)}
.feat-num{font-family:var(--font-h);font-size:0.72rem;font-weight:600;color:var(--text3);padding-top:0.2rem;letter-spacing:0.06em}
.feat-title{font-family:var(--font-h);font-weight:600;font-size:0.95rem;color:var(--white);margin-bottom:0.4rem;letter-spacing:-0.01em}
.feat-body{font-size:0.85rem;color:var(--text2);line-height:1.7;font-weight:300}

/* ================================================
   SPECS
   ================================================ */
.spec-section{background:var(--bg)}
.spec-layout{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.spec-table{width:100%;border-collapse:collapse;margin-top:2.5rem}
.spec-table tr{border-bottom:1px solid var(--border)}
.spec-table tr:last-child{border-bottom:none}
.spec-table td{padding:1rem 0;font-size:0.875rem}
.spec-table td:first-child{color:var(--text3);font-weight:300;width:50%}
.spec-table td:last-child{color:var(--text);font-weight:400;text-align:right}
.spec-img-wrap{
  border:1px solid var(--border);border-radius:8px;
  overflow:hidden;background:var(--bg2);
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:2rem;
}
.spec-img-wrap img{width:100%;object-fit:contain}

/* ================================================
   KONFIGURATOR
   ================================================ */
.konfig{background:var(--bg2)}
.konfig-layout{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.konfig-left{position:sticky;top:7rem}
.konfig-preview{
  border:1px solid var(--border);border-radius:8px;
  background:var(--bg3);padding:3rem;
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
}
.konfig-preview img{width:100%;object-fit:contain}
.kh{font-family:var(--font-h);font-size:1.75rem;font-weight:700;color:var(--white);letter-spacing:-0.02em;margin-bottom:0.5rem}
.ksub{font-size:0.875rem;color:var(--text2);font-weight:300;line-height:1.7;margin-bottom:2.5rem}
.kopt{margin-bottom:1.75rem}
.kopt-label{font-size:0.68rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text3);margin-bottom:0.75rem}
.chips{display:flex;gap:0.5rem;flex-wrap:wrap}
.chip{
  padding:0.5rem 1.1rem;border:1px solid var(--border2);
  border-radius:4px;font-size:0.82rem;color:var(--text2);
  cursor:pointer;transition:all 0.15s;font-family:var(--font-b);
  background:transparent;font-weight:400;
}
.chip:hover{border-color:rgba(255,255,255,0.25);color:var(--text)}
.chip.sel{background:var(--white);color:#000;border-color:var(--white);font-weight:500}
.price-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem;border:1px solid var(--border);border-radius:8px;
  margin:2rem 0;background:var(--bg3);
}
.pr-label{font-size:0.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.35rem}
.pr-num{font-family:var(--font-h);font-size:2.2rem;font-weight:700;color:var(--white);line-height:1}
.pr-note{font-size:0.72rem;color:var(--text3);margin-top:0.25rem}
.pr-badge{
  background:rgba(200,255,0,0.1);border:1px solid rgba(200,255,0,0.2);
  border-radius:4px;padding:0.4rem 0.875rem;
  font-size:0.72rem;font-weight:600;color:var(--accent);
  letter-spacing:0.08em;text-transform:uppercase;
  display:flex;align-items:center;gap:0.4rem;
}
.pr-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.btn-buy{
  display:flex;align-items:center;justify-content:center;gap:0.625rem;
  width:100%;padding:1rem;
  background:var(--accent);color:#000;
  font-family:var(--font-b);font-size:0.875rem;font-weight:600;
  border-radius:4px;border:none;cursor:pointer;
  text-decoration:none;letter-spacing:0.04em;transition:background 0.2s;
}
.btn-buy:hover{background:var(--accent2)}
.konfig-note{margin-top:0.875rem;font-size:0.75rem;color:var(--text3);text-align:center;line-height:1.6}

/* ================================================
   B2B
   ================================================ */
.b2b{background:var(--bg3);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.b2b-layout{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.b2b-left .stitle{margin-bottom:1.25rem}
.b2b-desc{font-size:0.9rem;color:var(--text2);line-height:1.8;font-weight:300;margin-bottom:2rem}
.b2b-points{display:flex;flex-direction:column;gap:0.625rem;margin-bottom:2.5rem}
.b2b-point{display:flex;align-items:center;gap:0.75rem;font-size:0.85rem;color:var(--text2);font-weight:300}
.b2b-point::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}
.b2b-right{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:2.5rem}
.b2b-card-title{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:0.5rem;letter-spacing:-0.01em}
.b2b-card-sub{font-size:0.82rem;color:var(--text3);margin-bottom:2rem;line-height:1.6}
.b2b-form{display:flex;flex-direction:column;gap:0.75rem}
.b2b-input{
  background:var(--bg3);border:1px solid var(--border);
  border-radius:4px;padding:0.875rem 1rem;
  font-size:0.85rem;color:var(--text);font-family:var(--font-b);
  outline:none;transition:border-color 0.2s;width:100%;
}
.b2b-input:focus{border-color:var(--border2)}
.b2b-input::placeholder{color:var(--text3)}
textarea.b2b-input{resize:vertical;min-height:100px}
.btn-b2b{
  display:flex;align-items:center;justify-content:center;gap:0.5rem;
  padding:0.875rem;background:var(--white);color:#000;
  font-family:var(--font-b);font-size:0.85rem;font-weight:600;
  border:none;border-radius:4px;cursor:pointer;letter-spacing:0.04em;
  transition:background 0.2s;text-decoration:none;
}
.btn-b2b:hover{background:var(--accent)}

/* ================================================
   COMPARE
   ================================================ */
.compare{background:var(--bg)}
.comp-wrap{overflow-x:auto;margin-top:3rem}
.comp-table{width:100%;border-collapse:collapse;min-width:600px}
.comp-table th{padding:1rem 1.5rem;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;color:var(--text3);border-bottom:1px solid var(--border);text-align:left;font-family:var(--font-b)}
.comp-table th.hl-th{color:var(--accent);border-bottom-color:var(--accent)}
.comp-table td{padding:1rem 1.5rem;font-size:0.875rem;font-weight:300;color:var(--text2);border-bottom:1px solid var(--border)}
.comp-table tr:last-child td{border-bottom:none}
.comp-table td.hl-td{color:var(--text);font-weight:400}
.check{color:var(--accent)}
.cross{color:var(--text3)}
.neu{color:var(--text2)}

/* ================================================
   FAQ
   ================================================ */
.faq{background:var(--bg2)}
.faq-wrap{max-width:740px;margin:3rem auto 0}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;background:none;border:none;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem 0;cursor:pointer;text-align:left;
  font-family:var(--font-b);font-size:0.9rem;font-weight:400;
  color:var(--text2);transition:color 0.2s;gap:1rem;
}
.faq-q:hover{color:var(--text)}
.faq-icon{
  width:24px;height:24px;flex-shrink:0;
  border:1px solid var(--border2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.85rem;color:var(--text3);
  transition:transform 0.25s,background 0.2s,color 0.2s;
}
.faq-item.open .faq-q{color:var(--text)}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--accent);color:#000;border-color:var(--accent)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-item.open .faq-ans{max-height:300px}
.faq-ans-inner{padding-bottom:1.5rem;font-size:0.85rem;color:var(--text3);line-height:1.8;font-weight:300}

/* ================================================
   FOOTER CTA
   ================================================ */
.fcta{padding:10rem 0;background:var(--bg);position:relative;overflow:hidden;text-align:center}
.fcta-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:400px;
  background:radial-gradient(ellipse,rgba(200,255,0,0.06) 0%,transparent 70%);
  pointer-events:none;
}
.fcta-bg-text{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--font-h);font-weight:800;font-size:18vw;white-space:nowrap;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.03);
  pointer-events:none;user-select:none;letter-spacing:-0.04em;
}
.fcta-inner{position:relative;z-index:1;max-width:600px;margin:0 auto;padding:0 5vw}
.fcta-eyebrow{font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text3);margin-bottom:1.25rem}
.fcta-title{font-family:var(--font-h);font-size:clamp(2.5rem,5vw,4rem);font-weight:800;letter-spacing:-0.03em;color:var(--white);line-height:1.05;margin-bottom:1.25rem}
.fcta-title .hl{color:var(--accent)}
.fcta-sub{font-size:0.9rem;color:var(--text2);font-weight:300;line-height:1.8;margin-bottom:3rem}
.fcta-actions{display:flex;gap:0.75rem;justify-content:center;flex-wrap:wrap}

/* ================================================
   FOOTER
   ================================================ */
footer{background:#050505;padding:4rem 0 2rem;border-top:1px solid var(--border)}
.footer-grid{max-width:1200px;margin:0 auto;padding:0 5vw;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
.footer-logo img{height:104px;width:auto;margin-bottom:1rem;display:block}
.footer-tagline{font-size:0.78rem;color:var(--text3);font-weight:300;line-height:1.7;max-width:26ch}
.fcol-label{font-size:0.64rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text3);margin-bottom:1rem;opacity:0.6}
.flinks{list-style:none;display:flex;flex-direction:column;gap:0.5rem}
.flinks a{font-size:0.8rem;color:var(--text3);text-decoration:none;font-weight:300;transition:color 0.2s}
.flinks a:hover{color:var(--text2)}
.footer-bottom{
  max-width:1200px;margin:2.5rem auto 0;padding:1.5rem 5vw 0;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.7rem;color:var(--text3);opacity:0.5;
}

/* ================================================
   REVIEWS
   ================================================ */
.reviews{background:var(--bg3);border-top:1px solid var(--border)}
.rev-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.rev-score{display:flex;align-items:baseline;gap:0.75rem}
.rev-num{font-family:var(--font-h);font-size:3.5rem;font-weight:800;color:var(--white);line-height:1;letter-spacing:-0.04em}
.rev-meta{display:flex;flex-direction:column;gap:0.2rem}
.stars{color:var(--accent);font-size:0.9rem;letter-spacing:0.1em}
.rev-count{font-size:0.75rem;color:var(--text3);font-weight:300}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.rev-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:1.75rem;transition:border-color 0.2s}
.rev-card:hover{border-color:var(--border2)}
.rev-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.rev-author{display:flex;align-items:center;gap:0.75rem}
.rev-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--bg4);border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:0.8rem;font-weight:700;color:var(--text2);flex-shrink:0;
}
.rev-name{font-size:0.85rem;font-weight:500;color:var(--text);margin-bottom:0.1rem}
.rev-date{font-size:0.72rem;color:var(--text3)}
.rev-stars{color:var(--accent);font-size:0.8rem;letter-spacing:0.06em}
.rev-text{font-size:0.85rem;color:var(--text2);line-height:1.75;font-weight:300}
.rev-tag{
  display:inline-block;margin-top:1rem;
  background:rgba(200,255,0,0.07);border:1px solid rgba(200,255,0,0.15);
  border-radius:99px;padding:0.2rem 0.75rem;
  font-size:0.68rem;font-weight:500;color:var(--accent);letter-spacing:0.08em;text-transform:uppercase;
}

/* ================================================
   SCROLL REVEAL
   ================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

/* ================================================
   LEGAL PAGES (AGB, Datenschutz, etc.)
   ================================================ */
.legal-page{padding:8rem 5vw 6rem;max-width:780px;margin:0 auto}
.legal-page h1{font-family:var(--font-h);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--white);margin-bottom:0.5rem}
.legal-page .last-updated{font-size:0.78rem;color:var(--text3);margin-bottom:3rem}
.legal-page h2{font-family:var(--font-h);font-size:1.2rem;color:var(--white);margin:2.5rem 0 0.75rem}
.legal-page p{font-size:0.9rem;color:var(--text2);line-height:1.8;margin-bottom:1rem}
.legal-page ul{margin:0.5rem 0 1rem 1.5rem;list-style:disc}
.legal-page ul li{font-size:0.9rem;color:var(--text2);line-height:1.8;margin-bottom:0.3rem}
.legal-page a{color:var(--accent)}
.legal-page strong{color:var(--text)}
.legal-formular{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin:1rem 0 1.5rem;font-size:0.85rem;color:var(--text2);line-height:1.8}

/* ================================================
   WOOCOMMERCE
   ================================================ */
.woo-shop{padding:6rem 5vw 8rem;max-width:1200px;margin:0 auto}
.woo-shop-header{margin-bottom:3rem}
.woo-shop-header .slabel{display:block}
.woo-products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.woo-product-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  overflow:hidden;transition:border-color 0.2s,transform 0.2s;
}
.woo-product-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.woo-product-img{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  padding:2rem;background:var(--bg3);overflow:hidden;
}
.woo-product-img img{width:100%;height:100%;object-fit:contain}
.woo-product-body{padding:1.25rem}
.woo-product-cat{font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:0.4rem}
.woo-product-name{font-family:var(--font-h);font-size:1rem;font-weight:600;color:var(--white);margin-bottom:0.5rem}
.woo-product-desc{font-size:0.82rem;color:var(--text2);line-height:1.6;margin-bottom:1rem}
.woo-product-footer{
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem 1.25rem;border-top:1px solid var(--border);
}
.woo-product-price{font-family:var(--font-h);font-size:1.1rem;font-weight:700;color:var(--white)}
.woo-product-price span{font-size:0.72rem;color:var(--text3);font-weight:300;margin-left:0.3rem}
.woo-btn-detail{
  font-size:0.78rem;color:var(--text2);border:1px solid var(--border2);
  padding:0.5rem 1rem;border-radius:4px;transition:all 0.2s;text-decoration:none;
}
.woo-btn-detail:hover{color:var(--text);border-color:rgba(255,255,255,0.3)}

/* WooCommerce native overrides */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  background:var(--accent)!important;color:#000!important;
  font-family:var(--font-b)!important;font-weight:600!important;
  border:none!important;border-radius:4px!important;
  padding:0.75rem 1.5rem!important;cursor:pointer!important;
  transition:background 0.2s!important;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{background:var(--accent2)!important}
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info{
  background:var(--bg2);border-top:3px solid var(--accent);color:var(--text2);
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea{
  background:var(--bg2);border:1px solid var(--border);color:var(--text);
  font-family:var(--font-b);padding:0.75rem;border-radius:4px;
}
.woocommerce form .form-row label{color:var(--text2);font-size:0.85rem}
.woocommerce-cart table.cart,
.woocommerce-checkout form.checkout{color:var(--text2)}
.woocommerce table.shop_table{border-collapse:collapse;width:100%}
.woocommerce table.shop_table td,.woocommerce table.shop_table th{
  border:1px solid var(--border);padding:0.75rem 1rem;color:var(--text2);font-size:0.875rem;
}
.woocommerce table.shop_table th{color:var(--text3);font-weight:600;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase}

/* Single product page */
.woocommerce div.product{padding:6rem 5vw;max-width:1200px;margin:0 auto}
.woocommerce div.product .product_title{
  font-family:var(--font-h);font-size:clamp(1.8rem,4vw,2.8rem);
  color:var(--white);margin-bottom:1rem;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price{
  font-family:var(--font-h);font-size:1.8rem;color:var(--accent);font-weight:700;
}
.woocommerce div.product .woocommerce-product-gallery{
  border:1px solid var(--border);border-radius:8px;
  background:var(--bg2);padding:1.5rem;
}

/* ================================================
   ÜBER UNS PAGE
   ================================================ */
.about-hero{
  padding:8rem 5vw 5rem;background:var(--bg);
  border-bottom:1px solid var(--border);
}
.about-hero .slabel{display:block;margin-bottom:0.875rem}
.about-hero h1{font-family:var(--font-h);color:var(--white);margin-bottom:1rem}
.about-hero p{font-size:0.95rem;color:var(--text2);max-width:520px;font-weight:300;line-height:1.75}
.about-grid{max-width:1200px;margin:0 auto;padding:0 5vw}
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.about-img{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg2)}
.about-img img{width:100%;object-fit:cover;aspect-ratio:4/3}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.value-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:1.75rem}
.value-icon{font-size:1.5rem;margin-bottom:0.875rem}
.value-title{font-family:var(--font-h);font-size:0.95rem;font-weight:600;color:var(--white);margin-bottom:0.5rem}
.value-desc{font-size:0.82rem;color:var(--text2);line-height:1.7;font-weight:300}

/* ================================================
   WOOCOMMERCE – SINGLE PRODUCT
   ================================================ */
.woo-single{max-width:1200px;margin:0 auto;padding:6rem 5vw 4rem}
.woo-single-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:4rem}
.woo-single-main-img img{width:100%;height:auto;border-radius:12px;display:block;background:var(--bg2)}
.woo-single-thumbs{display:flex;gap:0.75rem;margin-top:1rem;flex-wrap:wrap}
.woo-thumb{width:72px;height:72px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid var(--border);transition:border-color .2s}
.woo-thumb.active,.woo-thumb:hover{border-color:var(--accent)}
.woo-single-title{font-family:var(--font-h);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;color:var(--white);line-height:1.2;margin:0.5rem 0 1.25rem}
.woo-single-price{margin-bottom:1.5rem}
.woo-single-price .woocommerce-Price-amount{font-family:var(--font-h);font-size:1.8rem;font-weight:700;color:var(--accent)}
.woo-mwst{display:block;font-size:0.78rem;color:var(--text3);margin-top:0.25rem}
.woo-single-short-desc{font-size:0.88rem;color:var(--text2);line-height:1.8;margin-bottom:1.75rem}
.woo-trust{display:flex;flex-direction:column;gap:0.5rem;margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.woo-trust-item{font-size:0.82rem;color:var(--text2);display:flex;gap:0.5rem}
.woo-trust-item span{color:var(--accent);font-weight:700}

/* Tabs */
.woo-single-tabs{margin-top:2rem;border-top:1px solid var(--border);padding-top:2rem}
.woo-tabs-nav{display:flex;gap:0.5rem;margin-bottom:2rem;flex-wrap:wrap}
.woo-tab-btn{background:none;border:1px solid var(--border);color:var(--text2);padding:0.5rem 1.25rem;border-radius:6px;font-family:var(--font-b);font-size:0.85rem;cursor:pointer;transition:all .2s}
.woo-tab-btn.active,.woo-tab-btn:hover{border-color:var(--accent);color:var(--accent)}
.woo-tab-content{display:none}
.woo-tab-content.active{display:block}
.woo-long-desc{font-size:0.88rem;color:var(--text2);line-height:1.9}
.woo-long-desc p{margin-bottom:1rem}
.woo-long-desc ul{margin:0.5rem 0 1rem 1.5rem}
.woo-long-desc li{margin-bottom:0.3rem}
.woo-attr-table{width:100%;border-collapse:collapse}
.woo-attr-table tr{border-bottom:1px solid var(--border)}
.woo-attr-table td{padding:0.75rem 0.5rem;font-size:0.85rem;color:var(--text2)}
.woo-attr-table td:first-child{font-weight:500;color:var(--text);width:40%}

/* Related */
.woo-related{margin-top:4rem}
.woo-related-title{font-family:var(--font-h);font-size:1.4rem;font-weight:600;color:var(--white);margin-bottom:2rem}

/* WooCommerce form overrides */
.woocommerce-variation-add-to-cart,.cart{display:flex;flex-direction:column;gap:1rem}
.woocommerce-variation-price .woocommerce-Price-amount{font-family:var(--font-h);font-size:1.4rem;font-weight:700;color:var(--accent)}
.variations td,.variations th{padding:0.5rem 0;font-size:0.85rem;color:var(--text2);vertical-align:middle}
.variations th{font-weight:500;color:var(--text);padding-right:1rem;white-space:nowrap}
.variations select{background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:0.5rem 1rem;border-radius:6px;font-family:var(--font-b);font-size:0.85rem;cursor:pointer}
.variations select:focus{outline:none;border-color:var(--accent)}
.variations table{border-collapse:collapse}
.single_add_to_cart_button,.button.alt{background:var(--accent);color:#000;border:none;padding:0.9rem 2.5rem;border-radius:8px;font-family:var(--font-h);font-size:0.95rem;font-weight:700;cursor:pointer;transition:background .2s;text-transform:uppercase;letter-spacing:0.05em;width:100%;text-align:center;display:block}
.single_add_to_cart_button:hover,.button.alt:hover{background:var(--accent2)}
input[type="number"].qty{background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:0.5rem 0.75rem;border-radius:6px;width:80px;font-family:var(--font-b)}
.quantity{display:flex;align-items:center;gap:0.5rem}
.woocommerce-variation-description p{font-size:0.85rem;color:var(--text2);margin:0.5rem 0}
.reset_variations{font-size:0.75rem;color:var(--text3);margin-top:0.25rem;cursor:pointer}
.reset_variations:hover{color:var(--accent)}

/* ================================================
   RESPONSIVE
   ================================================ */
@media(max-width:1024px){
  .nav-links li:not(:last-child){display:none}
  .nav-burger{display:flex}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-left{padding:7rem 5vw 3rem}
  .hero-right{padding:2rem 5vw 5rem}
  .hero-float-badge{left:0}
  .feat-layout,.spec-layout,.konfig-layout,.b2b-layout,.about-layout{grid-template-columns:1fr;gap:3rem}
  .feat-sticky,.konfig-left{position:static}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:0.5rem;text-align:center}
  .woo-products-grid{grid-template-columns:repeat(2,1fr)}
  .woo-single-wrap{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:768px){
  .rev-grid{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  h1.hero-h{font-size:2.5rem}
  .hero-stats{gap:1.5rem}
  .fcta-title{font-size:2.2rem}
  .footer-grid{grid-template-columns:1fr}
  .hero-float-badge,.hero-float-badge2{display:none}
  .rev-grid{grid-template-columns:1fr}
  .woo-products-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
}