/* =========================================
   HYPNOSE LEBENSENERGIE — Global Styles
   ========================================= */

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

/* ── Variables ── */
:root {
  --cream:       #f7f3ec;
  --warm-white:  #fdfaf5;
  --sage:        #8aab8a;
  --sage-light:  #b8d0b8;
  --sage-dark:   #6b8f6b;
  --forest:      #2e4a2e;
  --forest-mid:  #3d6142;
  --forest-deep: #1e3420;
  --gold:        #c5a55a;
  --gold-light:  #dfc98e;
  --gold-dark:   #a8823a;
  --text:        #2a2a2a;
  --text-soft:   #5a5a5a;
  --border:      rgba(138,171,138,0.22);
  --shadow-sm:   0 4px 16px rgba(46,74,46,.07);
  --shadow-md:   0 12px 40px rgba(46,74,46,.12);
  --shadow-lg:   0 28px 72px rgba(46,74,46,.18);
  --r-sm: .75rem; --r-md: 1.5rem; --r-lg: 2.5rem; --r-xl: 4rem;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'DM Sans', system-ui, sans-serif;
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; -webkit-font-smoothing:antialiased; }
body { font-family:var(--sans); background:var(--warm-white); color:var(--text); overflow-x:hidden; }
img  { max-width:100%; display:block; }
a    { color:inherit; text-decoration:none; }
ul   { list-style:none; }
button,input,textarea,select { font-family:inherit; }

/* ── Page Transition ── */
.page-transition {
  position:fixed; inset:0; background:var(--forest);
  z-index:99999; pointer-events:none;
  transform:translateY(100%);
  transition:transform .55s var(--ease);
}
.page-transition.out { transform:translateY(0); }
.page-transition.in  { transform:translateY(-100%); }

/* ── Grain Overlay ── */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9998; opacity:.45;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
}

/* ── Typography ── */
h1,h2,h3,h4 { font-family:var(--serif); font-weight:400; line-height:1.12; color:var(--forest); }
h1 { font-size:clamp(2.6rem,7vw,5.8rem); letter-spacing:-.02em; }
h2 { font-size:clamp(1.8rem,4vw,3rem); }
h3 { font-size:clamp(1.25rem,2.5vw,1.75rem); }
h4 { font-size:1.15rem; }
p  { line-height:1.8; color:var(--text-soft); font-weight:300; }
.serif { font-family:var(--serif); }
.italic { font-style:italic; }

/* ── Layout ── */
.container { max-width:1160px; margin:0 auto; padding:0 clamp(1rem,4vw,2.5rem); }
.section { padding:clamp(4rem,8vw,7rem) 0; }
.section-sm { padding:clamp(2.5rem,5vw,4rem) 0; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.flex   { display:flex; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.text-center { text-align:center; }
.text-white  { color:#fff !important; }

/* ── Tag / Label ── */
.tag {
  display:inline-block; font-size:.7rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold-light);
  border-radius:2rem; padding:.3rem 1.1rem; margin-bottom:1.2rem;
}
.tag.light { color:var(--sage-light); border-color:rgba(184,208,184,.4); }

/* ── Section Header ── */
.section-header { text-align:center; margin-bottom:clamp(2.5rem,5vw,4.5rem); }
.section-header p { max-width:540px; margin:.8rem auto 0; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.85rem 2rem; border-radius:3rem;
  font-size:.88rem; font-weight:500; cursor:pointer;
  transition:all .3s var(--ease); border:none; white-space:nowrap;
  position:relative; overflow:hidden;
}
.btn::before {
  content:''; position:absolute; inset:0; opacity:0;
  background:rgba(255,255,255,.12);
  transition:opacity .25s;
}
.btn:hover::before { opacity:1; }
.btn-primary { background:var(--forest); color:var(--cream); }
.btn-primary:hover { background:var(--forest-mid); transform:translateY(-2px); box-shadow:0 10px 32px rgba(46,74,46,.28); }
.btn-outline { background:transparent; color:var(--forest); border:1.5px solid var(--forest); }
.btn-outline:hover { background:var(--forest); color:var(--cream); transform:translateY(-2px); }
.btn-gold { background:var(--gold); color:#fff; }
.btn-gold:hover { background:var(--gold-dark); transform:translateY(-2px); box-shadow:0 10px 32px rgba(197,165,90,.4); }
.btn-ghost { background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(6px); }
.btn-ghost:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }
.btn-lg { padding:1.1rem 2.6rem; font-size:1rem; }
.btn-sm { padding:.6rem 1.4rem; font-size:.8rem; }
.btn-group { display:flex; gap:1rem; flex-wrap:wrap; }

/* ── Card Base ── */
.card {
  background:var(--warm-white); border-radius:var(--r-md);
  border:1px solid var(--border); transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  overflow:hidden; position:relative;
}
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.card-body { padding:2rem 2rem; }

/* ── Divider ── */
.divider {
  width:48px; height:2px;
  background:linear-gradient(to right, var(--sage), var(--gold));
  margin:1.2rem 0; border-radius:2px;
}
.divider.center { margin:1.2rem auto; }

/* ═══════════════════════════════
   NAVIGATION
═══════════════════════════════ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.4rem 0;
  transition:background .4s var(--ease), backdrop-filter .4s, padding .35s var(--ease), box-shadow .4s;
}
#navbar.scrolled {
  background:rgba(253,250,245,.93);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 1px 0 var(--border), var(--shadow-sm);
  padding:.9rem 0;
}
#navbar.dark-bg:not(.scrolled) .nav-logo,
#navbar.dark-bg:not(.scrolled) .nav-link { color:var(--cream); }
#navbar.dark-bg:not(.scrolled) .nav-link::after { background:var(--gold-light); }
#navbar.dark-bg:not(.scrolled) .hamburger span { background:var(--cream); }

.nav-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.nav-logo {
  font-family:var(--serif); font-size:1.3rem; font-weight:500;
  color:var(--forest); white-space:nowrap; transition:color .3s;
}
.nav-logo em { font-style:normal; color:var(--gold); }
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-link {
  font-size:.82rem; font-weight:400; color:var(--text-soft);
  position:relative; transition:color .3s; padding:.2rem 0;
}
.nav-link::after {
  content:''; position:absolute; bottom:-3px; left:0;
  width:0; height:1.5px; background:var(--gold);
  transition:width .3s var(--ease);
}
.nav-link:hover,
.nav-link.active { color:var(--forest); }
.nav-link:hover::after,
.nav-link.active::after { width:100%; }
.nav-cta { margin-left:.5rem; }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:.3rem; z-index:10;
}
.hamburger span {
  display:block; width:22px; height:1.5px;
  background:var(--forest); transition:all .3s var(--ease);
  transform-origin:center;
}
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile menu */
.mobile-nav {
  position:fixed; top:0; left:0; right:0; bottom:0;
  background:var(--warm-white); z-index:999;
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  gap:2rem; padding:2rem;
  transform:translateX(100%); transition:transform .45s var(--ease);
  pointer-events:none;
}
.mobile-nav.open { transform:translateX(0); pointer-events:all; }
.mobile-nav .nav-link {
  font-family:var(--serif); font-size:2.2rem; font-weight:300; color:var(--forest);
}
.mobile-nav .nav-link::after { height:2px; }

/* ═══════════════════════════════
   PAGE HERO (inner pages)
═══════════════════════════════ */
.page-hero {
  min-height:48vh; display:flex; align-items:flex-end;
  padding-bottom:4rem; padding-top:10rem;
  position:relative; overflow:hidden;
  background:linear-gradient(150deg, var(--forest-deep) 0%, var(--forest-mid) 100%);
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background-image:url('https://static.wixstatic.com/media/28269c_97b2e37b08844b75a71a3fe27b2a8a96~mv2.png');
  background-size:cover; background-position:center;
  opacity:.08; mix-blend-mode:luminosity;
}
.page-hero-bg-leaf {
  position:absolute; right:-80px; top:-60px;
  width:480px; opacity:.07;
  transform:rotate(30deg);
}
.page-hero-content { position:relative; z-index:1; }
.page-hero h1 { color:var(--cream); margin-bottom:1rem; }
.page-hero p { color:rgba(255,255,255,.65); font-size:1.1rem; max-width:560px; }
.breadcrumb {
  display:flex; align-items:center; gap:.5rem;
  font-size:.75rem; color:rgba(255,255,255,.5);
  margin-bottom:1.5rem; letter-spacing:.08em; text-transform:uppercase;
}
.breadcrumb a:hover { color:var(--gold-light); }
.breadcrumb-sep { opacity:.4; }

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
.site-footer {
  background:var(--forest-deep); color:rgba(255,255,255,.6);
  padding:5rem 0 2rem;
}
.footer-grid {
  display:grid; grid-template-columns:1.6fr 1fr 1fr;
  gap:4rem; margin-bottom:3.5rem;
}
.footer-brand h3 {
  font-family:var(--serif); font-size:1.6rem; color:var(--cream);
  margin-bottom:.8rem;
}
.footer-brand p { font-size:.88rem; line-height:1.8; max-width:280px; margin-bottom:1.5rem; }
.footer-social { display:flex; gap:.8rem; }
.footer-social a {
  width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(255,255,255,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; transition:all .3s;
}
.footer-social a:hover { background:var(--gold); border-color:var(--gold); color:#fff; }
.footer-col h4 {
  font-family:var(--sans); font-size:.72rem; font-weight:500;
  color:var(--cream); text-transform:uppercase; letter-spacing:.14em; margin-bottom:1.4rem;
}
.footer-col li { margin-bottom:.8rem; }
.footer-col a { font-size:.85rem; transition:color .3s; }
.footer-col a:hover { color:var(--sage-light); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.07);
  padding-top:2rem; display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:1rem; font-size:.78rem;
}
.footer-bottom-links { display:flex; gap:1.5rem; }
.footer-bottom-links a:hover { color:var(--sage-light); }

/* ═══════════════════════════════
   SCROLL ANIMATIONS
═══════════════════════════════ */
[data-reveal] {
  opacity:0; transition:opacity .75s var(--ease), transform .75s var(--ease);
}
[data-reveal="up"]    { transform:translateY(36px); }
[data-reveal="left"]  { transform:translateX(-40px); }
[data-reveal="right"] { transform:translateX(40px); }
[data-reveal="scale"] { transform:scale(.94); }
[data-reveal="fade"]  { transform:none; }
[data-reveal].revealed { opacity:1; transform:none; }
[data-delay="1"] { transition-delay:.1s; }
[data-delay="2"] { transition-delay:.2s; }
[data-delay="3"] { transition-delay:.3s; }
[data-delay="4"] { transition-delay:.4s; }
[data-delay="5"] { transition-delay:.5s; }
[data-delay="6"] { transition-delay:.6s; }

/* ═══════════════════════════════
   FORM ELEMENTS
═══════════════════════════════ */
.form-group { margin-bottom:1.25rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-label {
  display:block; font-size:.72rem; font-weight:500;
  color:var(--forest); text-transform:uppercase; letter-spacing:.1em; margin-bottom:.5rem;
}
.form-input, .form-textarea {
  width:100%; padding:.9rem 1.1rem;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm); background:var(--cream);
  font-family:var(--sans); font-size:.9rem; color:var(--text);
  outline:none; transition:border-color .3s, box-shadow .3s, background .3s;
}
.form-input:focus, .form-textarea:focus {
  border-color:var(--sage); background:var(--warm-white);
  box-shadow:0 0 0 4px rgba(138,171,138,.14);
}
.form-input.error { border-color:#d97070; box-shadow:0 0 0 4px rgba(217,112,112,.1); }
.form-input.valid { border-color:var(--sage); }
.form-textarea { resize:vertical; min-height:120px; line-height:1.6; }
.form-check { display:flex; align-items:flex-start; gap:.8rem; margin-bottom:1.5rem; }
.form-check input[type=checkbox] { margin-top:2px; accent-color:var(--sage); width:16px; height:16px; flex-shrink:0; }
.form-check label { font-size:.8rem; color:var(--text-soft); line-height:1.55; }
.form-check a { color:var(--sage-dark); text-decoration:underline; }
.form-error-msg { font-size:.75rem; color:#c05050; margin-top:.35rem; display:none; }
.form-error-msg.show { display:block; }
.form-success-msg {
  text-align:center; padding:3rem 2rem; display:none;
}
.form-success-msg.show { display:block; }
.success-icon {
  width:64px; height:64px; border-radius:50%;
  background:linear-gradient(135deg, var(--sage), var(--forest));
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1.5rem;
}
.success-icon svg { stroke:white; }

/* ═══════════════════════════════
   PRICING TABLE
═══════════════════════════════ */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.pricing-card {
  background:var(--warm-white); border:1.5px solid var(--border);
  border-radius:var(--r-md); padding:2.5rem 2rem;
  text-align:center; position:relative;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.pricing-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.pricing-card.featured {
  background:var(--forest); border-color:transparent;
  transform:scale(1.04);
}
.pricing-card.featured:hover { transform:scale(1.04) translateY(-5px); }
.pricing-badge {
  position:absolute; top:-1rem; left:50%; transform:translateX(-50%);
  background:var(--gold); color:#fff;
  font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  padding:.35rem 1.1rem; border-radius:2rem; white-space:nowrap;
}
.pricing-label { font-size:.75rem; font-weight:500; text-transform:uppercase; letter-spacing:.12em; color:var(--text-soft); margin-bottom:.8rem; }
.pricing-card.featured .pricing-label { color:rgba(255,255,255,.6); }
.pricing-amount { font-family:var(--serif); font-size:3.2rem; color:var(--forest); line-height:1; margin-bottom:.4rem; }
.pricing-card.featured .pricing-amount { color:var(--gold-light); }
.pricing-unit { font-size:.8rem; color:var(--text-soft); margin-bottom:1.5rem; }
.pricing-card.featured .pricing-unit { color:rgba(255,255,255,.5); }
.pricing-features { list-style:none; text-align:left; margin-bottom:2rem; }
.pricing-features li {
  font-size:.88rem; padding:.6rem 0; border-bottom:1px solid var(--border);
  display:flex; align-items:flex-start; gap:.6rem; color:var(--text-soft);
}
.pricing-card.featured .pricing-features li { border-color:rgba(255,255,255,.1); color:rgba(255,255,255,.7); }
.pricing-features li::before { content:'✓'; color:var(--sage); font-weight:600; flex-shrink:0; margin-top:1px; }
.pricing-card.featured .pricing-features li::before { color:var(--gold-light); }

/* ═══════════════════════════════
   FAQ ACCORDION
═══════════════════════════════ */
.faq-list { display:flex; flex-direction:column; gap:.8rem; }
.faq-item {
  background:var(--warm-white); border:1.5px solid var(--border);
  border-radius:var(--r-sm); overflow:hidden;
  transition:border-color .3s, box-shadow .3s;
}
.faq-item.open { border-color:var(--sage); box-shadow:var(--shadow-sm); }
.faq-trigger {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:1.3rem 1.6rem; cursor:pointer; gap:1rem;
  background:none; border:none; text-align:left;
}
.faq-trigger h4 { font-size:1rem; color:var(--forest); font-family:var(--serif); font-weight:500; }
.faq-icon {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:var(--cream); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  transition:background .3s, transform .4s var(--ease);
  font-size:.9rem; color:var(--forest);
}
.faq-item.open .faq-icon { background:var(--forest); color:var(--cream); transform:rotate(45deg); }
.faq-body { max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-body-inner { padding:0 1.6rem 1.4rem; }
.faq-body-inner p { font-size:.92rem; line-height:1.75; }

/* ═══════════════════════════════
   LIGHTBOX
═══════════════════════════════ */
.lightbox {
  position:fixed; inset:0; z-index:10000;
  background:rgba(0,0,0,.92); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:2rem;
  opacity:0; pointer-events:none; transition:opacity .35s var(--ease);
}
.lightbox.open { opacity:1; pointer-events:all; }
.lightbox-img { max-width:90vw; max-height:88vh; border-radius:var(--r-sm); object-fit:contain; }
.lightbox-close {
  position:absolute; top:1.5rem; right:1.5rem;
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.12); border:none; cursor:pointer;
  color:#fff; font-size:1.4rem; display:flex; align-items:center; justify-content:center;
  transition:background .3s;
}
.lightbox-close:hover { background:rgba(255,255,255,.25); }
.lightbox-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  width:48px; height:48px; border-radius:50%;
  background:rgba(255,255,255,.12); border:none; cursor:pointer;
  color:#fff; font-size:1.4rem; display:flex; align-items:center; justify-content:center;
  transition:background .3s;
}
.lightbox-nav:hover { background:rgba(255,255,255,.25); }
.lightbox-prev { left:1rem; }
.lightbox-next { right:1rem; }

/* ═══════════════════════════════
   TOOLTIP / BADGE
═══════════════════════════════ */
.badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--warm-white); border-radius:2rem;
  padding:.6rem 1.1rem; box-shadow:var(--shadow-md);
  border:1px solid var(--border); font-size:.82rem; font-weight:500; color:var(--forest);
}
.badge-dot {
  width:8px; height:8px; border-radius:50%; background:#6abf6a;
  box-shadow:0 0 0 3px rgba(106,191,106,.22);
  animation:pulseDot 2s infinite;
}
@keyframes pulseDot {
  0%,100% { box-shadow:0 0 0 3px rgba(106,191,106,.22); }
  50%      { box-shadow:0 0 0 7px rgba(106,191,106,.08); }
}

/* ═══════════════════════════════
   TABS
═══════════════════════════════ */
.tabs-nav {
  display:flex; gap:.5rem; padding:.35rem;
  background:var(--cream); border-radius:3rem; width:fit-content; margin:0 auto 3rem;
}
.tab-btn {
  padding:.7rem 1.8rem; border-radius:3rem; border:none; cursor:pointer;
  font-family:var(--sans); font-size:.85rem; font-weight:400; color:var(--text-soft);
  background:transparent; transition:all .3s var(--ease);
}
.tab-btn.active { background:var(--forest); color:var(--cream); box-shadow:var(--shadow-sm); }
.tab-panel { display:none; animation:tabIn .4s var(--ease); }
.tab-panel.active { display:block; }
@keyframes tabIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:none; } }

/* ═══════════════════════════════
   STAT COUNTER
═══════════════════════════════ */
.stats-bar {
  background:var(--forest); padding:3.5rem 0;
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.stat-item {}
.stat-num {
  font-family:var(--serif); font-size:3.2rem; font-weight:300;
  color:var(--gold-light); line-height:1; margin-bottom:.4rem;
  display:block;
}
.stat-label { font-size:.78rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.12em; }
.stat-div { width:1px; background:rgba(255,255,255,.12); }

/* ═══════════════════════════════
   TIMELINE
═══════════════════════════════ */
.timeline { position:relative; padding-left:3rem; }
.timeline::before {
  content:''; position:absolute; left:1rem; top:0; bottom:0;
  width:1px; background:linear-gradient(to bottom, var(--sage-light), var(--gold-light), transparent);
}
.timeline-item { position:relative; padding-bottom:3rem; }
.timeline-item:last-child { padding-bottom:0; }
.timeline-dot {
  position:absolute; left:-2.3rem; top:.3rem;
  width:2rem; height:2rem; border-radius:50%;
  background:var(--warm-white); border:2px solid var(--sage-light);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:.9rem; color:var(--forest);
  transition:all .4s var(--ease);
}
.timeline-item:hover .timeline-dot {
  background:var(--forest); color:var(--cream); border-color:var(--forest);
  box-shadow:0 0 0 4px rgba(46,74,46,.15);
}
.timeline-item h3 { margin-bottom:.6rem; }
.timeline-item p { font-size:.92rem; }

/* ═══════════════════════════════
   PARALLAX HOST
═══════════════════════════════ */
.parallax-wrap { overflow:hidden; }
.parallax-img { will-change:transform; transition:transform .1s linear; }

/* ═══════════════════════════════
   CURSOR (subtle glow on desktop)
═══════════════════════════════ */
@media (hover:hover) {
  .cursor-glow {
    width:200px; height:200px; border-radius:50%;
    background:radial-gradient(circle, rgba(197,165,90,.08) 0%, transparent 70%);
    position:fixed; pointer-events:none; z-index:9997;
    transform:translate(-50%,-50%);
    transition:transform .15s linear;
  }
}

/* ═══════════════════════════════
   SCROLL INDICATOR
═══════════════════════════════ */
.scroll-progress {
  position:fixed; top:0; left:0; height:2px; z-index:1001;
  background:linear-gradient(to right, var(--sage), var(--gold));
  width:0%; transition:width .1s linear;
}

/* ═══════════════════════════════
   TOAST NOTIFICATION
═══════════════════════════════ */
.toast {
  position:fixed; bottom:2rem; right:2rem; z-index:10001;
  background:var(--forest); color:var(--cream); border-radius:var(--r-sm);
  padding:1rem 1.5rem; font-size:.88rem; box-shadow:var(--shadow-lg);
  transform:translateY(100px); opacity:0;
  transition:transform .4s var(--ease), opacity .4s;
  display:flex; align-items:center; gap:.8rem; max-width:320px;
}
.toast.show { transform:translateY(0); opacity:1; }

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media (max-width:900px) {
  .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr 1fr; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2.5rem; }
  .footer-brand { grid-column:1/-1; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .pricing-grid { grid-template-columns:1fr; }
  .pricing-card.featured { transform:none; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  .grid-3 { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-bottom-links { flex-wrap:wrap; justify-content:center; }
  .btn-group { flex-direction:column; align-items:flex-start; }
  .tabs-nav { flex-direction:column; border-radius:var(--r-sm); width:100%; }
}
