/* ============================================================
   PANEON GmbH — style.css
   Dark-first theme · Mobile-first · CSS Custom Properties
   Primary: #2980b9 · Derived from original website palette
   Reference: survivaltraining.at (SSI Goldstandard)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --primary:#2980b9;
  --primary-dark:#1a5276;
  --primary-darker:#0e3d5c;
  --primary-light:#3498db;
  --primary-lighter:#5dade2;
  --primary-pale:#85c1e9;

  --black:#050608;
  --dark:#0a0d12;
  --night:#0d1118;
  --surface:#111820;
  --surface-light:#182230;
  --border:rgba(41,128,185,.18);
  --border-hover:rgba(41,128,185,.35);

  --white:#f0f4f8;
  --cream:#d5dde6;
  --muted:#8899aa;

  --accent:#e74c3c;
  --accent-light:#ec7063;

  --section-pad:6rem 2rem;
  --container:1140px;
  --ease:cubic-bezier(.4,0,.2,1);
}

[data-theme="light"]{
  --black:#f5f7fa;
  --dark:#eef1f5;
  --night:#e8ecf0;
  --surface:#f0f3f7;
  --surface-light:#e2e7ed;
  --border:rgba(26,82,118,.12);
  --border-hover:rgba(26,82,118,.25);
  --white:#1a1d21;
  --cream:#2c3e50;
  --muted:#5d6d7e;
  --primary:#2471a3;
  --primary-dark:#1a5276;
  --primary-light:#2980b9;
  --accent:#c0392b;
  --accent-light:#e74c3c;
}

html{scroll-behavior:smooth;font-size:16px}

body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--black);
  color:var(--cream);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--primary-light);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--primary-lighter)}
img{max-width:100%;height:auto;display:block}

.container{max-width:var(--container);margin:0 auto;padding:0 1.5rem}

h1,h2,h3,h4{font-family:'Inter',system-ui,sans-serif;font-weight:700;line-height:1.15;color:var(--white)}

.section-tag{font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;color:var(--primary-light);margin-bottom:.8rem;display:block}
.section-title{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;margin-bottom:1.2rem}
.section-lead{font-size:1.05rem;line-height:1.8;color:var(--cream);max-width:680px;opacity:.9}
.section-line{width:50px;height:2px;background:var(--primary);margin-bottom:1.5rem}
.text-center{text-align:center}
.text-center .section-line{margin-left:auto;margin-right:auto}
.mx-auto{margin-left:auto;margin-right:auto}

/* --- Navigation --- */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:.8rem 2rem;
  display:flex;justify-content:space-between;align-items:center;
  transition:background .4s var(--ease),border-color .4s var(--ease);
  background:linear-gradient(to bottom,rgba(5,6,8,.75) 0%,rgba(5,6,8,.3) 70%,transparent 100%);
  border-bottom:1px solid transparent;
}
[data-theme="light"] .site-nav{background:linear-gradient(to bottom,rgba(245,247,250,.85) 0%,rgba(245,247,250,.4) 70%,transparent 100%)}
.site-nav.scrolled{background:rgba(5,6,8,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
[data-theme="light"] .site-nav.scrolled{background:rgba(245,247,250,.97)}
.nav-logo img{height:52px;width:auto}
.nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
.nav-links a{color:var(--cream);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;text-shadow:0 1px 3px rgba(0,0,0,.3);transition:color .2s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--primary-light)}
.nav-links .has-dropdown{position:relative}
.nav-links .dropdown{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--dark);border:1px solid var(--border);border-radius:6px;padding:.5rem 0;min-width:180px;box-shadow:0 8px 32px rgba(0,0,0,.4);z-index:210}
.nav-links .has-dropdown:hover .dropdown{display:block}
.dropdown a{display:block;padding:.5rem 1.2rem;font-size:.75rem;text-shadow:none;white-space:nowrap}
.dropdown a:hover{background:var(--surface)}
.nav-dropdown{position:relative}
.nav-sub{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--dark);border:1px solid var(--border);border-radius:6px;padding:.5rem 0;min-width:180px;box-shadow:0 8px 32px rgba(0,0,0,.4);z-index:210;list-style:none}
.nav-dropdown:hover .nav-sub{display:block}
.nav-sub a{display:block;padding:.5rem 1.2rem;font-size:.75rem;text-shadow:none;white-space:nowrap}
.nav-sub a:hover{background:var(--surface)}
.nav-cta{background:var(--primary) !important;color:#fff !important;padding:.45rem 1.2rem;border-radius:4px;font-weight:600 !important;transition:background .2s var(--ease) !important;text-shadow:none !important}
.nav-cta:hover{background:var(--primary-dark) !important}

.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;z-index:210}
.nav-hamburger span{width:24px;height:2px;background:var(--cream);display:block;transition:.3s var(--ease)}
.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.nav-mobile{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(5,6,8,.98);z-index:190;padding:5rem 2rem 2rem;flex-direction:column;gap:.15rem;overflow-y:auto}
.nav-mobile.open{display:flex}
.nav-mobile a{font-size:1.15rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--cream);opacity:.75;text-decoration:none;padding:.55rem 0;border-bottom:1px solid var(--border);transition:color .2s,opacity .2s}
.nav-mobile a:hover{color:var(--primary-light);opacity:1}
.nav-mobile .mobile-sub{padding-left:1.2rem;font-size:.95rem;opacity:.6}

/* --- Hero --- */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;
  background:
    linear-gradient(135deg,rgba(5,6,8,.85) 0%,rgba(10,15,25,.7) 40%,rgba(41,128,185,.15) 70%,rgba(5,6,8,.92) 100%),
    radial-gradient(ellipse at 30% 50%,rgba(41,128,185,.12) 0%,transparent 60%),
    radial-gradient(ellipse at 70% 30%,rgba(52,152,219,.08) 0%,transparent 50%);
  background-color:var(--dark);
}
[data-theme="light"] .hero-bg{
  background:
    linear-gradient(135deg,rgba(245,247,250,.9) 0%,rgba(238,241,245,.8) 40%,rgba(41,128,185,.08) 70%,rgba(245,247,250,.95) 100%),
    radial-gradient(ellipse at 30% 50%,rgba(41,128,185,.06) 0%,transparent 60%);
  background-color:var(--dark);
}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 20% 80%,rgba(41,128,185,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(41,128,185,.06) 0%,transparent 50%);
  animation:heroPulse 8s ease-in-out infinite alternate;
}
@keyframes heroPulse{from{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.05)}}

.hero-content{position:relative;text-align:center;max-width:900px;padding:0 2rem;margin-top:2rem}
.hero-eyebrow{font-size:.72rem;letter-spacing:.45em;text-transform:uppercase;color:var(--primary-light);margin-bottom:1.5rem;animation:fadeUp .9s var(--ease) .3s both}
.hero-title{font-size:clamp(2.8rem,10vw,5.5rem);font-weight:800;line-height:.95;color:var(--white);margin-bottom:1.5rem;animation:fadeUp .9s var(--ease) .5s both}
.hero-title .accent{color:var(--primary-light)}
.hero-subtitle{font-size:clamp(1rem,2.2vw,1.25rem);font-weight:300;line-height:1.8;color:var(--cream);max-width:640px;margin:0 auto 2.5rem;opacity:.9;animation:fadeUp .9s var(--ease) .7s both}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fadeUp .9s var(--ease) .9s both}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;opacity:.4;animation:fadeUp 1s var(--ease) 1.2s both}
.hero-scroll span{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--cream)}
.hero-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--primary-light),transparent)}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* --- Buttons --- */
.btn{display:inline-block;font-family:'Inter',system-ui,sans-serif;font-size:.85rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:none;border-radius:4px;transition:background .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease)}
.btn-primary{background:var(--primary);color:#fff;padding:.85rem 2.2rem}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 20px rgba(41,128,185,.3);color:#fff}
.btn-ghost{background:transparent;color:var(--cream);padding:.85rem 2.2rem;border:1px solid rgba(41,128,185,.25)}
.btn-ghost:hover{border-color:var(--primary-light);color:var(--primary-light)}
.btn-accent{background:var(--accent);color:#fff;padding:.85rem 2.2rem}
.btn-accent:hover{background:var(--accent-light);transform:translateY(-2px);color:#fff}
.btn-sm{padding:.55rem 1.4rem;font-size:.78rem}

/* --- Sections --- */
section{padding:var(--section-pad)}
.section-dark{background:var(--dark)}
.section-alt{background:var(--night)}
.section-gradient{background:linear-gradient(180deg,var(--black) 0%,var(--night) 100%)}

/* --- Grids --- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* --- Cards --- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:background .3s var(--ease),transform .3s var(--ease),border-color .3s var(--ease);overflow:hidden}
.card:hover{background:var(--surface-light);transform:translateY(-4px);border-color:var(--border-hover)}
.card-inner{padding:2rem}
.card-icon{width:52px;height:52px;background:rgba(41,128,185,.1);border:1px solid rgba(41,128,185,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;color:var(--primary-light);font-size:1.4rem}
.card h3{font-size:1rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.6rem}
.card p{font-size:.9rem;line-height:1.75;color:var(--cream);opacity:.85}

/* --- Feature Rows --- */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding:4rem 0}
.feature-row.reverse{direction:rtl}
.feature-row.reverse > *{direction:ltr}
.feature-visual{position:relative;border-radius:8px;overflow:hidden;background:var(--surface);border:1px solid var(--border);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.feature-visual .material-icons{font-size:4rem;color:var(--primary);opacity:.3}
.feature-text h3{font-size:1.6rem;margin-bottom:1rem}
.feature-text p{margin-bottom:1.2rem;opacity:.85}

/* --- Testimonials --- */
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.testimonial{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.8rem;position:relative}
.testimonial::before{content:'\201C';font-size:3rem;color:var(--primary);opacity:.3;position:absolute;top:.5rem;left:1rem;line-height:1}
.testimonial p{font-size:.92rem;line-height:1.7;color:var(--cream);padding-top:1rem}
.testimonial-result{display:inline-block;background:rgba(41,128,185,.1);color:var(--primary-light);padding:.3rem .8rem;border-radius:4px;font-size:.78rem;font-weight:600;margin-top:.8rem}

/* --- Stats --- */
.stats-row{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;padding:2rem 0}
.stat{text-align:center}
.stat-number{font-size:2.5rem;font-weight:800;color:var(--primary-light);line-height:1}
.stat-label{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:.4rem}

/* --- CTA Banner --- */
.cta-banner{background:linear-gradient(135deg,var(--primary-darker) 0%,var(--primary-dark) 50%,var(--primary) 100%);text-align:center;padding:4rem 2rem;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(255,255,255,.05) 0%,transparent 70%)}
.cta-banner h2{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin-bottom:1rem;position:relative}
.cta-banner p{color:rgba(255,255,255,.85);font-size:1.05rem;margin-bottom:2rem;position:relative}
.cta-banner .btn{position:relative}

/* --- Timeline --- */
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--primary),var(--primary-dark),transparent)}
.timeline-item{position:relative;padding-bottom:3rem;padding-left:2rem}
.timeline-item::before{content:'';position:absolute;left:-2rem;top:.4rem;width:10px;height:10px;border-radius:50%;background:var(--primary);border:2px solid var(--black);margin-left:-4px}
.timeline-item h3{font-size:1.2rem;margin-bottom:.5rem}
.timeline-item .timeline-year{font-size:.75rem;color:var(--primary-light);letter-spacing:.2em;text-transform:uppercase;margin-bottom:.5rem;display:block}

/* --- FAQ Accordion --- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-question{width:100%;background:none;border:none;padding:1.3rem 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left;color:var(--white);font-size:1rem;font-weight:500;font-family:inherit;transition:color .2s}
.faq-question:hover{color:var(--primary-light)}
.faq-question .material-icons{font-size:1.2rem;transition:transform .3s var(--ease);color:var(--primary)}
.faq-item.open .faq-question .material-icons{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-answer-inner{padding:0 0 1.5rem;color:var(--cream);font-size:.92rem;line-height:1.75;opacity:.85}

/* --- Contact Form --- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.5rem}
.contact-method{display:flex;gap:1rem;align-items:flex-start}
.contact-method .material-icons{color:var(--primary-light);font-size:1.4rem;margin-top:.15rem}
.contact-method h4{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.3rem}
.contact-method p,.contact-method a{font-size:.92rem;color:var(--cream);opacity:.85}
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.8rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--white);font-family:inherit;font-size:.92rem;transition:border-color .2s var(--ease)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-light)}
.form-group textarea{min-height:140px;resize:vertical}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.form-status{padding:.8rem;border-radius:4px;font-size:.88rem;margin-top:1rem;display:none}
.form-status.success{display:block;background:rgba(39,174,96,.15);color:#27ae60;border:1px solid rgba(39,174,96,.3)}
.form-status.error{display:block;background:rgba(231,76,60,.15);color:#e74c3c;border:1px solid rgba(231,76,60,.3)}

/* --- Login --- */
.login-wrapper{max-width:420px;margin:8rem auto 4rem;padding:2.5rem;background:var(--surface);border:1px solid var(--border);border-radius:8px}
.login-wrapper h1{font-size:1.5rem;text-align:center;margin-bottom:2rem}
.login-toggle{text-align:center;margin-top:1.2rem;font-size:.85rem;color:var(--muted)}
.login-toggle a{color:var(--primary-light);cursor:pointer}

/* --- Footer --- */
.site-footer{background:var(--dark);border-top:1px solid var(--border);padding:3rem 2rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem;max-width:var(--container);margin:0 auto}
.footer-brand img{height:36px;margin-bottom:1rem}
.footer-brand p{font-size:.85rem;color:var(--muted);line-height:1.6}
.footer-logo img{height:44px;width:auto;margin-bottom:1rem}
.footer-col h4{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--primary-light);margin-bottom:1rem}
.footer-col a{display:block;font-size:.85rem;color:var(--cream);opacity:.7;padding:.25rem 0;transition:opacity .2s,color .2s}
.footer-col a:hover{opacity:1;color:var(--primary-light)}
.footer-bottom{max-width:var(--container);margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--muted)}
.footer-bottom a{color:var(--muted)}
.footer-bottom a:hover{color:var(--primary-light)}

.volldeklaration{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem 2rem;margin:3rem auto;max-width:800px;text-align:center}
.volldeklaration h4{font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--primary-light);margin-bottom:.5rem}
.volldeklaration p{font-size:.88rem;color:var(--cream);opacity:.8}

/* --- Scroll Reveal --- */
.reveal{opacity:0;transform:translateY(25px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal-stagger.visible > *{opacity:1;transform:translateY(0)}
.reveal-stagger.visible > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.visible > *:nth-child(2){transition-delay:.15s}
.reveal-stagger.visible > *:nth-child(3){transition-delay:.25s}
.reveal-stagger.visible > *:nth-child(4){transition-delay:.35s}
.reveal-stagger.visible > *:nth-child(5){transition-delay:.45s}
.reveal-stagger.visible > *:nth-child(6){transition-delay:.55s}

/* --- Theme Toggle --- */
.theme-toggle{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--cream);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .2s;box-shadow:0 2px 12px rgba(0,0,0,.3)}
.theme-toggle:hover{transform:scale(1.1);border-color:var(--primary-light)}

/* --- Cookie Banner --- */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--dark);border-top:1px solid var(--border);padding:1.2rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;font-size:.85rem;color:var(--cream);transform:translateY(100%);opacity:0;transition:transform .3s ease,opacity .3s ease}
#cookie-banner.cb-visible{transform:translateY(0);opacity:1}
.cb-buttons{display:flex;gap:.6rem;flex-shrink:0}
.cb-btn{padding:.5rem 1.2rem;border:none;border-radius:4px;font-size:.8rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;transition:background .2s}
.cb-accept{background:var(--primary);color:#fff}
.cb-accept:hover{background:var(--primary-dark)}
.cb-decline{background:var(--surface-light);color:var(--cream)}
.cb-decline:hover{background:var(--surface)}

/* --- Page Header --- */
.page-header{padding:8rem 2rem 3rem;text-align:center;position:relative;background:linear-gradient(180deg,var(--dark) 0%,var(--black) 100%)}
.page-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(41,128,185,.08) 0%,transparent 60%)}
.page-header h1{font-size:clamp(2rem,5vw,3rem);position:relative}
.page-header .section-tag,.page-header .section-lead{position:relative}
.page-header .section-lead{margin:1rem auto 0}

/* --- Legal Pages --- */
.legal-content{max-width:800px;margin:0 auto;padding:2rem 0 4rem}
.legal-content h2{font-size:1.3rem;margin:2.5rem 0 1rem;padding-top:1rem;border-top:1px solid var(--border)}
.legal-content h3{font-size:1.1rem;margin:1.5rem 0 .5rem}
.legal-content p{margin-bottom:1rem;opacity:.85}
.legal-content ul,.legal-content ol{margin:1rem 0;padding-left:1.5rem}
.legal-content li{margin-bottom:.5rem;opacity:.85}

/* --- Product Cards --- */
.product-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:transform .3s var(--ease),border-color .3s var(--ease)}
.product-card:hover{transform:translateY(-4px);border-color:var(--border-hover)}
.product-card-body{padding:1.5rem}
.product-card h3{font-size:1rem;margin-bottom:.5rem}
.product-card p{font-size:.88rem;line-height:1.65;color:var(--cream);opacity:.8}
.product-badge{display:inline-block;background:rgba(41,128,185,.12);color:var(--primary-light);padding:.2rem .6rem;border-radius:3px;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.6rem}

/* --- Responsive --- */
@media(max-width:900px){
  .nav-hamburger{display:flex}
  .nav-links{display:none !important}
  .grid-2,.grid-3,.grid-4,.feature-row,.contact-grid{grid-template-columns:1fr;gap:2rem}
  .feature-row.reverse{direction:ltr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .stats-row{gap:2rem}
  .hero-title{font-size:clamp(2.2rem,8vw,4rem)}
  #cookie-banner{flex-direction:column;text-align:center;gap:1rem}
}

@media(max-width:600px){
  section{padding:3.5rem 1.2rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .stats-row{flex-direction:column;gap:1.5rem}
  .testimonial-grid{grid-template-columns:1fr}
}

/* --- Page Hero (Subpages) --- */
.page-hero{padding:8rem 2rem 3rem;text-align:center;position:relative;background:linear-gradient(180deg,var(--dark) 0%,var(--black) 100%)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(41,128,185,.08) 0%,transparent 60%)}
.page-hero h1{font-size:clamp(2rem,5vw,3rem);position:relative}
.page-hero .section-tag,.page-hero .section-lead{position:relative}
.page-hero .section-lead{margin:1rem auto 0}

/* --- Split Layout --- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split img{border-radius:8px;border:1px solid var(--border);width:100%}

/* --- Divider --- */
.divider{width:50px;height:2px;background:var(--primary);margin:1.2rem 0}
.divider-center{margin-left:auto;margin-right:auto}

/* --- Gallery --- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gallery-item{border-radius:8px;overflow:hidden;border:1px solid var(--border);transition:transform .3s var(--ease),border-color .3s var(--ease)}
.gallery-item:hover{transform:translateY(-4px);border-color:var(--border-hover)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block}

/* --- Blockquote --- */
.blockquote{border-left:3px solid var(--primary);padding:1rem 1.5rem;background:var(--surface);border-radius:0 8px 8px 0}
.blockquote p{font-style:italic;color:var(--cream);opacity:.9}
.blockquote cite{display:block;margin-top:.5rem;font-size:.85rem;color:var(--primary-light);font-style:normal}

/* --- Background Variants --- */
.bg-black{background:var(--black)}
.bg-dark{background:var(--dark)}
.bg-alt{background:var(--night)}

/* --- Spacing Utilities --- */
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:2rem}
.mt-4{margin-top:3rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:2rem}

/* --- Card text-center fix --- */
.card.text-center .card-inner{text-align:center}
.card.text-center{text-align:center}
.card p a{color:var(--primary-light)}
.card p a:hover{color:var(--primary-lighter)}

.material-icons{font-size:inherit;vertical-align:middle;line-height:1}
[id]{scroll-margin-top:5rem}

@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:2rem}
  .gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .gallery{grid-template-columns:1fr}
  .page-hero{padding:6rem 1.5rem 2rem}
}
