@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=DM+Sans:wght@300;400;500;600&display=swap');

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

:root{
  --white:#FFFFFF;
  --off-white:#FAF9F6;
  --cream:#F4EFE7;
  --cream-mid:#EEE8DC;
  --gold:#B08D44;
  --gold-light:#C9A968;
  --gold-dark:#8A6A30;
  --gold-bg:#FCF8F1;
  --charcoal:#16161A;
  --charcoal-mid:#2C2C2C;
  --grey-text:#3A3A3D;
  --grey-mid:#6B6B70;
  --grey-light:#9C9CA0;
  --grey-border:#E7E1D6;
  --hairline:#EFEAE0;
  --emerald:#1F6B5C;
  --emerald-light:#E8F3F0;
  --font-serif:'Playfair Display',Georgia,serif;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --shadow-sm:0 1px 3px rgba(22,22,26,.04),0 1px 2px rgba(22,22,26,.03);
  --shadow-md:0 8px 30px -12px rgba(22,22,26,.12),0 2px 8px rgba(22,22,26,.04);
  --shadow-lg:0 30px 60px -20px rgba(22,22,26,.18),0 8px 24px -12px rgba(22,22,26,.10);
  --ease:cubic-bezier(.22,.61,.36,1);
}

html{scroll-behavior:smooth;}
body{font-family:var(--font-sans);background:var(--white);color:var(--grey-text);line-height:1.75;font-size:16.5px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;}
::selection{background:rgba(176,141,68,.18);color:var(--charcoal);}

/* ─── HEADER ─── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--hairline);
  padding:0 2.5rem;
  transition:box-shadow .3s var(--ease),background .3s var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(255,255,255,.92);}
.header-inner{
  max-width:1240px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;height:82px;
}
.logo{display:flex;align-items:center;text-decoration:none;gap:.75rem;}
.logo img{height:48px;width:auto;object-fit:contain;}
.logo-text-fallback{display:none;flex-direction:column;}
.logo-top{font-size:10px;font-weight:500;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;font-family:var(--font-sans);}
.logo-main{font-family:var(--font-serif);font-size:16px;color:var(--charcoal);letter-spacing:.01em;line-height:1.2;}

.main-nav{display:flex;align-items:center;}
.nav-item{position:relative;}
.nav-link{
  display:block;padding:0 1.05rem;height:82px;line-height:82px;
  font-size:14px;font-weight:400;color:var(--grey-text);text-decoration:none;
  letter-spacing:.02em;white-space:nowrap;transition:color .25s var(--ease);position:relative;
}
.nav-link::after{content:'';position:absolute;left:1.05rem;right:1.05rem;bottom:24px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.nav-link:hover{color:var(--gold);}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1);}
.nav-link.active{color:var(--gold);}

.nav-dropdown{
  position:absolute;top:82px;left:0;
  background:var(--white);border:1px solid var(--grey-border);
  border-top:2px solid var(--gold);min-width:240px;
  box-shadow:var(--shadow-md);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s;z-index:200;
}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.nav-dropdown a{
  display:block;padding:.7rem 1.2rem;color:var(--grey-mid);
  text-decoration:none;font-size:13.5px;border-bottom:1px solid var(--grey-border);
  transition:all .15s;
}
.nav-dropdown a:last-child{border-bottom:none;}
.nav-dropdown a:hover{color:var(--gold);background:var(--gold-bg);padding-left:1.5rem;}

.nav-actions{display:flex;align-items:center;gap:.75rem;margin-left:1rem;}

.nav-login{
  font-size:13.5px;color:var(--grey-mid);text-decoration:none;
  padding:.45rem .9rem;border:1px solid var(--grey-border);
  transition:all .2s;white-space:nowrap;
}
.nav-login:hover{border-color:var(--gold);color:var(--gold);}

.header-cta{
  background:var(--charcoal);color:var(--white) !important;
  font-size:13px;font-weight:500;padding:.65rem 1.4rem;
  text-decoration:none;letter-spacing:.04em;white-space:nowrap;
  transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease);
}
.header-cta:hover{background:var(--gold);transform:translateY(-1px);box-shadow:0 6px 18px -8px rgba(176,141,68,.6);}

.hamburger{display:none;cursor:pointer;background:none;border:none;padding:8px;}
.hamburger span{display:block;width:24px;height:2px;background:var(--charcoal);margin:5px 0;transition:all .3s;}

/* ─── MOBILE NAV ─── */
.mobile-nav{
  display:none;position:fixed;inset:0;top:82px;
  background:var(--white);z-index:99;overflow-y:auto;
  border-top:1px solid var(--grey-border);
}
.mobile-nav.open{display:block;}
.mobile-nav a{
  display:block;padding:.9rem 2rem;color:var(--grey-text);text-decoration:none;
  font-size:15px;border-bottom:1px solid var(--grey-border);
}
.mobile-nav a.sub{padding-left:3rem;font-size:13.5px;color:var(--grey-mid);}
.mobile-nav a:hover{color:var(--gold);}

/* ─── HERO (LIGHT) ─── */
.hero{
  background:linear-gradient(180deg,var(--off-white) 0%,var(--white) 100%);
  padding:8rem 2.5rem 7rem;
  border-bottom:1px solid var(--hairline);
  position:relative;overflow:hidden;
}
.hero::after{
  content:'';position:absolute;top:-15%;right:-120px;width:620px;height:130%;
  background:radial-gradient(ellipse at right,rgba(176,141,68,.10) 0%,transparent 62%);
  pointer-events:none;
}
.hero::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,rgba(176,141,68,.25),transparent);
  margin-left:max(2.5rem,calc((100% - 1240px)/2));pointer-events:none;
}
.hero-inner{max-width:1240px;margin:0 auto;position:relative;z-index:1;}

.eyebrow{
  font-size:11px;font-weight:500;letter-spacing:.28em;
  color:var(--gold);text-transform:uppercase;margin-bottom:1.6rem;
  font-family:var(--font-sans);display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:'';width:28px;height:1px;background:var(--gold);display:inline-block;}
.hero h1{
  font-family:var(--font-serif);font-weight:500;
  font-size:clamp(2.4rem,5.2vw,4rem);
  color:var(--charcoal);line-height:1.1;letter-spacing:-.01em;
  max-width:780px;margin-bottom:1.5rem;
}
.hero .subline{
  font-size:clamp(1.05rem,1.8vw,1.2rem);color:var(--grey-mid);
  max-width:620px;font-weight:300;line-height:1.8;margin-bottom:2.75rem;
}
.hero-tagline{
  font-family:var(--font-serif);font-style:italic;color:var(--gold);
  font-size:1.1rem;margin-bottom:2.25rem;max-width:560px;
}

/* ─── BUTTONS ─── */
.btn-primary{
  background:var(--charcoal);color:var(--white);
  font-family:var(--font-sans);font-size:14px;font-weight:500;
  padding:.95rem 2rem;text-decoration:none;letter-spacing:.03em;
  display:inline-block;position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);
}
.btn-primary:hover{background:var(--gold);transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(176,141,68,.55);}

.btn-outline{
  color:var(--charcoal);font-family:var(--font-sans);font-size:14px;font-weight:500;
  padding:.95rem 2rem;border:1px solid var(--grey-border);
  text-decoration:none;letter-spacing:.03em;display:inline-block;
  transition:all .35s var(--ease);
}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);}

.btn-secondary{
  color:var(--grey-text);font-family:var(--font-sans);font-size:14px;
  padding:.95rem 2rem;border:1px solid var(--grey-border);
  text-decoration:none;letter-spacing:.02em;display:inline-block;
  transition:all .35s var(--ease);
}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold);}

.btn-stripe{
  background:#635BFF;color:var(--white);
  font-family:var(--font-sans);font-size:15px;font-weight:500;
  padding:.85rem 2rem;text-decoration:none;letter-spacing:.02em;
  transition:background .2s;display:inline-flex;align-items:center;gap:.5rem;
  cursor:pointer;border:none;
}
.btn-stripe:hover{background:#7B74FF;}

.cta-group{display:flex;gap:.875rem;flex-wrap:wrap;align-items:center;}

/* ─── SECTIONS ─── */
.section{padding:7rem 2.5rem;}
.section-white{background:var(--white);}
.section-off-white{background:var(--off-white);}
.section-cream{background:var(--cream);}
.section-dark{background:var(--charcoal);color:var(--white);}
.section-gold-bg{background:var(--gold-bg);}
.section-light{background:var(--off-white);}

/* ─── DARK CARDS (auf section-dark) ─── */
.cards-grid-dark{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.75rem;}
.card-dark{
  background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);
  padding:2.25rem 2rem;position:relative;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease);
}
.card-dark::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease);}
.card-dark:hover{transform:translateY(-5px);background:rgba(255,255,255,.06);border-color:rgba(184,146,74,.4);}
.card-dark:hover::before{transform:scaleY(1);}
.card-dark h3{font-family:var(--font-serif);font-weight:500;font-size:1.3rem;color:var(--white);margin-bottom:.7rem;}
.card-dark p{font-size:14px;color:rgba(255,255,255,.62);line-height:1.7;}

/* ─── DARK / VARIANT BUTTONS ─── */
.btn-primary-dark{
  background:var(--charcoal);color:var(--white);
  font-family:var(--font-sans);font-size:14px;font-weight:500;
  padding:.95rem 2rem;text-decoration:none;letter-spacing:.03em;display:inline-block;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);
}
.btn-primary-dark:hover{background:var(--gold);transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(176,141,68,.55);}
.btn-ghost{
  color:var(--white);font-family:var(--font-sans);font-size:14px;font-weight:500;
  padding:.95rem 2rem;border:1px solid rgba(255,255,255,.28);text-decoration:none;
  letter-spacing:.03em;display:inline-block;transition:all .35s var(--ease);
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);}
.btn-outline-dark{
  color:var(--gold-light);font-family:var(--font-sans);font-size:14px;font-weight:500;
  padding:.95rem 2rem;border:1px solid var(--gold);text-decoration:none;
  letter-spacing:.03em;display:inline-block;transition:all .35s var(--ease);
}
.btn-outline-dark:hover{background:var(--gold);color:var(--charcoal);transform:translateY(-2px);}

.section-inner{max-width:1240px;margin:0 auto;}
.section-label{font-size:11px;font-weight:500;letter-spacing:.28em;color:var(--gold);text-transform:uppercase;margin-bottom:1.1rem;font-family:var(--font-sans);display:inline-flex;align-items:center;gap:.7rem;}
.section-label::before{content:'';width:24px;height:1px;background:var(--gold);display:inline-block;}
.section-title{font-family:var(--font-serif);font-weight:500;font-size:clamp(1.9rem,3.2vw,2.7rem);color:var(--charcoal);line-height:1.18;letter-spacing:-.01em;margin-bottom:1.1rem;}
.section-title-light{font-family:var(--font-serif);font-weight:500;font-size:clamp(1.9rem,3.2vw,2.7rem);color:var(--white);line-height:1.18;letter-spacing:-.01em;margin-bottom:1.1rem;}
.section-subtitle{font-size:1.05rem;color:var(--grey-mid);max-width:640px;margin-bottom:2.5rem;line-height:1.75;}
.section-subtitle-light{font-size:1.05rem;color:rgba(255,255,255,.6);max-width:640px;margin-bottom:2.5rem;line-height:1.75;}

/* ─── STATS BAR ─── */
.stats-bar{background:var(--charcoal);padding:3rem 2.5rem;}
.stats-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;}
.stat-item{text-align:center;padding:1rem 1.5rem;position:relative;}
.stat-item:not(:last-child)::after{content:'';position:absolute;right:0;top:18%;bottom:18%;width:1px;background:rgba(255,255,255,.1);}
.stat-number{font-family:var(--font-serif);font-weight:500;font-size:3rem;color:var(--gold-light);line-height:1;display:block;margin-bottom:.5rem;}
.stat-label{font-size:12.5px;color:rgba(255,255,255,.55);letter-spacing:.06em;}

/* ─── CARDS ─── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.75rem;}

.card{
  background:var(--white);border:1px solid var(--hairline);
  padding:2.5rem 2.25rem;position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:box-shadow .4s var(--ease),transform .4s var(--ease),border-color .4s var(--ease);
}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:var(--grey-border);}
.card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease);}
.card:hover::before{transform:scaleY(1);}
.card h3{font-family:var(--font-serif);font-weight:500;font-size:1.35rem;color:var(--charcoal);margin-bottom:.75rem;}
.card p{font-size:14px;color:var(--grey-mid);line-height:1.7;margin-bottom:1.1rem;}
.card-link{font-size:13px;color:var(--gold-dark);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(184,146,74,.35);padding-bottom:2px;}
.card-link:hover{color:var(--gold);border-color:var(--gold);}

/* PRODUCT CARD — Diagnostic purchase */
.product-card{
  background:var(--white);border:1px solid var(--hairline);
  box-shadow:var(--shadow-lg);max-width:460px;
  overflow:hidden;transition:transform .4s var(--ease);
}
.product-card:hover{transform:translateY(-4px);}
.product-card-header{background:var(--charcoal);padding:2rem;position:relative;overflow:hidden;}
.product-card-header::after{content:'';position:absolute;top:-40%;right:-10%;width:200px;height:200px;background:radial-gradient(circle,rgba(176,141,68,.25),transparent 70%);}
.product-card-header h3{font-family:var(--font-serif);font-weight:500;color:var(--white);font-size:1.5rem;margin-bottom:.35rem;position:relative;}
.product-card-header p{font-size:12px;color:var(--gold-light);letter-spacing:.14em;text-transform:uppercase;position:relative;}
.product-card-body{padding:2.25rem;}
.price-display{margin-bottom:1.5rem;}
.price-amount{font-family:var(--font-serif);font-weight:500;font-size:2.8rem;color:var(--charcoal);}
.price-currency{font-size:1.1rem;color:var(--grey-mid);vertical-align:super;}
.price-note{font-size:12px;color:var(--grey-light);margin-top:.25rem;}

/* ─── AUDIENCE GRID ─── */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);}
.audience-card{
  padding:3rem 2.25rem;border:1px solid var(--hairline);border-right:none;
  background:var(--white);position:relative;transition:background .35s var(--ease),transform .35s var(--ease);
}
.audience-card:last-child{border-right:1px solid var(--hairline);}
.audience-card:hover{background:var(--gold-bg);}
.audience-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.audience-card:hover::before{transform:scaleX(1);}
.audience-card h3{font-family:var(--font-serif);font-weight:500;font-size:1.3rem;color:var(--charcoal);margin:1.4rem 0 .7rem;}
.audience-card p{font-size:13.5px;color:var(--grey-mid);line-height:1.7;margin-bottom:1.25rem;}
.audience-card a{font-size:13px;color:var(--gold-dark);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(184,146,74,.35);padding-bottom:2px;}

/* ─── OFFER BLOCKS ─── */
.offer-block{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:4rem;}
.offer-block.reverse{direction:rtl;}
.offer-block.reverse>*{direction:ltr;}
.offer-content h2{font-family:var(--font-serif);font-size:clamp(1.5rem,2.5vw,2rem);color:var(--charcoal);margin-bottom:1rem;line-height:1.25;}
.offer-content h2.light{color:var(--white);}
.offer-content p{color:var(--grey-mid);margin-bottom:1.25rem;line-height:1.75;font-size:15px;}
.offer-visual{background:var(--cream);border:1px solid var(--hairline);border-left:3px solid var(--gold);padding:2.75rem;box-shadow:var(--shadow-sm);}
.offer-visual.dark{background:rgba(255,255,255,.05);border-color:rgba(184,146,74,.2);}

/* ─── METHODIK ─── */
.methodik-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1px;background:var(--grey-border);margin-top:2rem;}
.methodik-item{background:var(--white);padding:1.5rem 1.25rem;}
.methodik-item::before{content:'';display:block;width:24px;height:2px;background:var(--gold);margin-bottom:.875rem;}
.methodik-item h4{font-family:var(--font-serif);font-size:.95rem;color:var(--charcoal);margin-bottom:.35rem;}
.methodik-item p{font-size:13px;color:var(--grey-mid);line-height:1.6;}

/* ─── STEPS ─── */
.steps{counter-reset:step;}
.step-item{display:flex;gap:1.25rem;margin-bottom:1.75rem;align-items:flex-start;}
.step-num{width:42px;height:42px;flex-shrink:0;border:1.5px solid var(--gold);color:var(--gold);font-family:var(--font-serif);font-size:1rem;display:flex;align-items:center;justify-content:center;background:var(--gold-bg);}
.step-content h4{font-size:15px;font-weight:500;color:var(--charcoal);margin-bottom:.2rem;}
.step-content p{font-size:14px;color:var(--grey-mid);}

/* ─── TABLE ─── */
.program-table{width:100%;border-collapse:collapse;font-size:14.5px;}
.program-table th{background:var(--charcoal);color:var(--gold);padding:.85rem 1.2rem;text-align:left;font-weight:500;font-size:12px;letter-spacing:.08em;text-transform:uppercase;}
.program-table td{padding:.95rem 1.2rem;border-bottom:1px solid var(--grey-border);color:var(--grey-text);vertical-align:top;}
.program-table tr:nth-child(even) td{background:var(--off-white);}

/* ─── FAQ ─── */
.faq-list{max-width:820px;}
.faq-item{border-bottom:1px solid var(--grey-border);}
.faq-question{
  width:100%;background:none;border:none;text-align:left;
  padding:1.15rem 0;font-family:var(--font-sans);font-size:15.5px;font-weight:500;
  color:var(--charcoal);cursor:pointer;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;
}
.faq-question span{font-size:20px;color:var(--gold);flex-shrink:0;transition:transform .2s;}
.faq-question:hover{color:var(--gold);}
.faq-question.open span{transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-answer-inner{padding:0 0 1.1rem;font-size:14.5px;color:var(--grey-mid);line-height:1.75;}

/* ─── BLOCKQUOTE ─── */
.blockquote{border-left:3px solid var(--gold);padding:1.25rem 1.5rem;margin:2rem 0;background:var(--gold-bg);}
.blockquote p{font-family:var(--font-serif);font-style:italic;font-size:1.1rem;color:var(--charcoal);line-height:1.6;}

/* ─── CHECK LIST ─── */
.check-list{list-style:none;}
.check-list li{padding:.4rem 0;font-size:14.5px;color:var(--grey-mid);display:flex;gap:.7rem;align-items:flex-start;}
.check-list li::before{content:'—';color:var(--gold);flex-shrink:0;font-weight:600;margin-top:1px;}
.check-list.dark li{color:rgba(255,255,255,.65);}
.check-list.dark li::before{color:var(--gold);}

/* ─── CTA SECTION ─── */
.cta-section{background:var(--charcoal);padding:5rem 2rem;text-align:center;position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(184,146,74,.07) 0%,transparent 70%);pointer-events:none;}
.cta-section h2{font-family:var(--font-serif);font-size:clamp(1.7rem,3vw,2.4rem);color:var(--white);margin-bottom:.875rem;position:relative;}
.cta-section p{font-size:1.05rem;color:rgba(255,255,255,.55);max-width:540px;margin:0 auto 2.5rem;line-height:1.75;position:relative;}

/* ─── FORM ─── */
.contact-form{max-width:640px;}
.form-group{margin-bottom:1.1rem;}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--charcoal);margin-bottom:.35rem;letter-spacing:.02em;}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:.7rem 1rem;border:1px solid var(--grey-border);background:var(--white);
  font-family:var(--font-sans);font-size:14.5px;color:var(--charcoal);outline:none;
  transition:border-color .2s;appearance:none;border-radius:0;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);}
.form-group textarea{resize:vertical;min-height:130px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-check{display:flex;gap:.65rem;align-items:flex-start;margin-bottom:1.5rem;}
.form-check input[type=checkbox]{margin-top:3px;flex-shrink:0;}
.form-check label{font-size:13px;color:var(--grey-mid);line-height:1.5;}
.form-check a{color:var(--gold-dark);}

/* ─── STRIPE CHECKOUT MODAL ─── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:5000;
  display:flex;align-items:center;justify-content:center;padding:1rem;
  opacity:0;visibility:hidden;transition:all .25s;
}
.modal-overlay.open{opacity:1;visibility:visible;}
.modal{
  background:var(--white);max-width:520px;width:100%;
  box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;
}
.modal-header{
  background:var(--charcoal);padding:1.5rem 2rem;
  display:flex;justify-content:space-between;align-items:center;
}
.modal-header h3{font-family:var(--font-serif);color:var(--white);font-size:1.3rem;}
.modal-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:1.5rem;line-height:1;padding:0;}
.modal-close:hover{color:var(--white);}
.modal-body{padding:2rem;}

/* ─── AUTH PAGES ─── */
.auth-wrapper{min-height:calc(100vh - 76px);background:var(--off-white);display:flex;align-items:center;justify-content:center;padding:3rem 1rem;}
.auth-box{background:var(--white);max-width:420px;width:100%;padding:2.5rem;border:1px solid var(--grey-border);box-shadow:var(--shadow-md);}
.auth-box h1{font-family:var(--font-serif);font-size:1.7rem;color:var(--charcoal);margin-bottom:.5rem;}
.auth-box p{font-size:14px;color:var(--grey-mid);margin-bottom:1.75rem;}
.auth-divider{text-align:center;margin:1.5rem 0;position:relative;}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--grey-border);}
.auth-divider span{background:var(--white);padding:0 .75rem;font-size:12px;color:var(--grey-light);position:relative;}
.auth-link{font-size:13.5px;color:var(--gold-dark);text-decoration:none;}
.auth-link:hover{color:var(--gold);}

/* ─── ACCOUNT DASHBOARD ─── */
.dashboard-grid{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:start;}
.dashboard-nav{background:var(--white);border:1px solid var(--grey-border);padding:1.5rem;}
.dashboard-nav h4{font-size:11px;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem;}
.dashboard-nav a{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;font-size:14px;color:var(--grey-text);text-decoration:none;transition:all .15s;border-left:2px solid transparent;}
.dashboard-nav a:hover,.dashboard-nav a.active{color:var(--gold);background:var(--gold-bg);border-left-color:var(--gold);}
.dashboard-content{background:var(--white);border:1px solid var(--grey-border);padding:2rem;}
.purchase-item{border:1px solid var(--grey-border);padding:1.25rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;}
.purchase-badge{font-size:11.5px;font-weight:500;padding:.25rem .65rem;background:var(--emerald-light);color:var(--emerald);}

/* ─── SOCIAL ICONS ─── */
.social-bar{display:flex;gap:.75rem;align-items:center;}
.social-icon{
  width:36px;height:36px;border:1px solid var(--grey-border);
  display:flex;align-items:center;justify-content:center;
  color:var(--grey-mid);transition:all .2s;text-decoration:none;
}
.social-icon:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}
.social-icon svg{width:16px;height:16px;}

/* ─── LEGAL ─── */
.legal-content{max-width:820px;}
.legal-content h2{font-family:var(--font-serif);font-size:1.35rem;color:var(--charcoal);margin:2.25rem 0 .65rem;}
.legal-content p,.legal-content li{font-size:14.5px;color:var(--grey-mid);line-height:1.8;margin-bottom:.7rem;}
.legal-content ul{padding-left:1.5rem;}
.legal-content a{color:var(--gold-dark);}

/* ─── DISCLAIMER ─── */
.disclaimer-box{background:var(--cream);border:1px solid var(--grey-border);border-left:3px solid var(--gold);padding:.875rem 1.2rem;font-size:12.5px;color:var(--grey-mid);line-height:1.6;margin-top:1.5rem;}

/* ─── FOOTER ─── */
.site-footer{background:var(--charcoal);padding:4rem 2rem 2rem;border-top:3px solid var(--gold);}
.footer-inner{max-width:1200px;margin:0 auto;}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.4);line-height:1.65;margin-bottom:.875rem;}
.footer-brand .social-bar{margin-top:1rem;}
.footer-brand .social-icon{border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.4);}
.footer-brand .social-icon:hover{border-color:var(--gold);color:var(--gold);background:rgba(184,146,74,.1);}
.footer-col h5{font-size:11px;font-weight:500;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;margin-bottom:.875rem;}
.footer-col a{display:block;font-size:13.5px;color:rgba(255,255,255,.45);text-decoration:none;margin-bottom:.45rem;transition:color .15s;}
.footer-col a:hover{color:rgba(255,255,255,.9);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.3);line-height:1.6;}
.footer-legal{display:flex;gap:1.5rem;flex-wrap:wrap;}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.3);text-decoration:none;transition:color .15s;}
.footer-legal a:hover{color:rgba(255,255,255,.7);}

/* ─── COOKIE BANNER ─── */
.cookie-banner-wrap{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--white);border-top:2px solid var(--gold);box-shadow:0 -4px 20px rgba(0,0,0,.1);padding:1.25rem 2rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;font-family:var(--font-sans);font-size:13.5px;color:var(--grey-text);}
.cookie-banner-wrap p{flex:1;min-width:260px;margin:0;line-height:1.55;}
.cookie-banner-wrap a{color:var(--gold-dark);}

/* ─── NOTIFICATION TOAST ─── */
.toast{position:fixed;bottom:2rem;right:2rem;z-index:9998;background:var(--charcoal);color:var(--white);padding:1rem 1.5rem;font-size:14px;box-shadow:var(--shadow-lg);transform:translateY(20px);opacity:0;transition:all .3s;pointer-events:none;max-width:320px;}
.toast.show{transform:translateY(0);opacity:1;}
.toast.success::before{content:'✓  ';}

/* ─── RESPONSIVE ─── */
/* ─── BILDWELT / MEDIA ─── */
.media-frame{position:relative;overflow:hidden;border-radius:2px;box-shadow:var(--shadow-lg);}
.media-frame::after{content:'';position:absolute;inset:0;border:1px solid rgba(255,255,255,.5);pointer-events:none;}
.media-frame img{display:block;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);filter:saturate(.92);}
.media-frame:hover img{transform:scale(1.04);}
.media-accent{position:absolute;z-index:-1;border:1px solid var(--gold);border-radius:2px;}

/* Hero with image */
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:4.5rem;align-items:center;}
.hero-media{position:relative;aspect-ratio:4/5;}
.hero-media .media-accent{inset:24px -24px -24px 24px;}

/* Offer block image */
.offer-media{aspect-ratio:4/3;}

/* Section image band */
.media-band{aspect-ratio:21/9;margin-top:2.5rem;}
.media-band img{filter:saturate(.9) brightness(.98);}

/* Image-backed CTA */
.cta-section.has-image{background:var(--charcoal);}
.cta-bg{position:absolute;inset:0;z-index:0;overflow:hidden;}
.cta-bg img{width:100%;height:100%;object-fit:cover;opacity:.28;filter:grayscale(.2);}
.cta-section.has-image::before{background:linear-gradient(180deg,rgba(22,22,26,.72),rgba(22,22,26,.86));z-index:1;}

@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem;}
  .hero-media{aspect-ratio:16/10;max-width:520px;}
  .hero-media .media-accent{inset:16px -16px -16px 16px;}
}

/* ─── SCROLL REVEAL ─── */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease);will-change:opacity,transform;}
[data-reveal].in{opacity:1;transform:none;}
@media(max-width:760px){.optin-band{grid-template-columns:1fr !important;}}
[data-reveal].d1{transition-delay:.08s;}
[data-reveal].d2{transition-delay:.16s;}
[data-reveal].d3{transition-delay:.24s;}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1 !important;transform:none !important;}}

/* ─── REFINED LINKS ─── */
.card-link,.audience-card a{transition:all .25s var(--ease);}
.card-link:hover,.audience-card a:hover{color:var(--gold);}

@media(max-width:960px){
  .main-nav,.nav-actions{display:none;}
  .hamburger{display:block;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}
  .stats-inner,.audience-grid{grid-template-columns:1fr;}
  .stat-item:not(:last-child)::after{display:none;}
  .stats-item{padding:1.25rem 0;}
  .section{padding:4.5rem 1.75rem;}
  .hero{padding:5.5rem 1.75rem 4.5rem;}
  .audience-card{border-right:1px solid var(--grey-border) !important;border-top:none;}
  .audience-card:first-child::before{display:none;}
  .offer-block{grid-template-columns:1fr;}
  .offer-block.reverse{direction:ltr;}
  .dashboard-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .hero{padding:3.5rem 1.5rem;}
  .section{padding:3.5rem 1.5rem;}
  .footer-grid{grid-template-columns:1fr;}
  .cta-group{flex-direction:column;}
  .cta-group .btn-primary,.cta-group .btn-outline,.cta-group .btn-secondary{width:100%;text-align:center;}
  .cards-grid{grid-template-columns:1fr;}
}
