/* ==========================================================================
   Iacademix · main.css
   Design system + all sections styling
   Mobile-first, responsive, accessible, fluid
   ========================================================================== */

/* Easing tokens */
:root{
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-smooth:cubic-bezier(.4,0,.2,1);
}

/* Global polish: smoother default transitions */
a, button{transition:color .2s var(--ease-out), background .25s var(--ease-out), border-color .25s var(--ease-out)}

/* Sections base */
.section{padding:clamp(3.5rem,8vw,7rem) 0;position:relative}
.section .lead{font-size:clamp(1.0625rem,1.4vw,1.25rem);color:var(--color-text-muted);max-width:60ch;margin:0 auto 2.5rem;text-align:center}
.section h2{text-align:center;max-width:24ch;margin-left:auto;margin-right:auto}
.container-narrow{max-width:820px}

/* Counter inline */
.counter{color:var(--color-accent);font-weight:900;display:inline-block}

/* Soft floating orbs (decorative background) */
.section-solution::before,
.section-pricing::after{
  content:"";position:absolute;border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,150,.08) 0%,transparent 70%);
  pointer-events:none;z-index:0;
}
.section-solution::before{width:600px;height:600px;top:-200px;right:-200px}
.section-pricing::after{width:500px;height:500px;bottom:-150px;left:-150px}
.section > .container{position:relative;z-index:1}

/* Logo polish: subtle hover lift */
.logo{transition:transform .25s var(--ease-spring)}
.logo:hover{transform:translateX(2px)}
.logo-mark{transition:transform .35s var(--ease-spring), box-shadow .25s ease}
.logo:hover .logo-mark{transform:rotate(-4deg) scale(1.05);box-shadow:0 6px 18px rgba(0,200,150,.25)}

/* Button shine effect on primary CTA */
.btn-primary{position:relative;overflow:hidden;isolation:isolate}
.btn-primary::after{
  content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);
  transition:left .65s var(--ease-out);
  pointer-events:none;
}
.btn-primary:hover::after{left:100%}

/* ==========================================================================
   HERO POLISH
   ========================================================================== */
/* Floating animation on hero mockup */
.hero-mockup{animation:float 6s ease-in-out infinite;transition:transform .4s var(--ease-out), box-shadow .4s var(--ease-out)}
.hero-mockup:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 25px 60px rgba(0,0,0,.18)}
@keyframes float{
  0%, 100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@media (prefers-reduced-motion:reduce){.hero-mockup{animation:none}}

/* Subtle background gradient blob in hero */
.hero{position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;width:800px;height:800px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,150,.12) 0%,transparent 60%);
  top:-300px;right:-300px;
  pointer-events:none;
  z-index:0;
}
.hero-inner{position:relative;z-index:1}

/* Subtle pulse on hero-eyebrow */
.hero-eyebrow{transition:transform .3s var(--ease-spring)}
.hero-eyebrow:hover{transform:scale(1.02)}

/* ==========================================================================
   PROBLEM SECTION
   ========================================================================== */
.section-problem{background:var(--color-bg-alt)}
.section-problem h2{text-align:left;max-width:none;margin-bottom:2.5rem}
.pain-list{list-style:none;padding:0;margin:0 0 3rem;display:grid;gap:1rem;max-width:840px}
.pain-list li{display:flex;align-items:flex-start;gap:.875rem;padding:1.125rem 1.25rem;background:#fff;border:1px solid var(--color-border);border-left:4px solid var(--color-error);border-radius:8px;font-size:1.0625rem;line-height:1.5;transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out)}
.pain-list li:hover{transform:translateX(4px);box-shadow:var(--shadow-sm)}
.pain-list .cross{flex-shrink:0;color:var(--color-error);font-weight:900;font-size:1.25rem;line-height:1}
.stat-callout{background:var(--color-primary);color:#fff;padding:2rem;border-radius:16px;display:flex;align-items:flex-start;gap:1.5rem;max-width:840px;box-shadow:var(--shadow-lg)}
.stat-callout .stat-icon{font-size:2.5rem;line-height:1;flex-shrink:0}
.stat-callout p{margin:0;font-size:1.0625rem;line-height:1.6;color:rgba(255,255,255,.92)}
.stat-callout strong{color:var(--color-accent)}
@media (max-width:640px){
  .stat-callout{flex-direction:column;gap:1rem;padding:1.5rem}
  .stat-callout .stat-icon{font-size:2rem}
}

/* ==========================================================================
   SOLUTION SECTION
   ========================================================================== */
.section-solution h2 .counter{font-size:inherit}
.pillars-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:1rem}
@media (min-width:768px){.pillars-grid{grid-template-columns:repeat(3,1fr);gap:2rem}}
.pillar-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:2rem;text-align:center;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s var(--ease-out);position:relative;overflow:hidden}
.pillar-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-accent),var(--color-primary));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.pillar-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.pillar-card:hover::before{transform:scaleX(1)}
.pillar-icon{font-size:3rem;line-height:1;margin-bottom:1rem;transition:transform .35s var(--ease-spring)}
.pillar-card:hover .pillar-icon{transform:scale(1.1) rotate(-5deg)}
.pillar-card h3{font-size:1.25rem;margin-bottom:.75rem}
.pillar-card p{color:var(--color-text-muted);margin:0;font-size:1rem}

/* ==========================================================================
   CURRICULUM SECTION
   ========================================================================== */
.section-curriculum{background:var(--color-bg-alt)}
.modules{max-width:820px;margin:0 auto 2.5rem;display:grid;gap:.75rem}
.module{background:#fff;border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:box-shadow .2s ease}
.module:hover{box-shadow:var(--shadow-md)}
.module[open]{box-shadow:var(--shadow-md);border-color:var(--color-accent)}
.module summary{display:flex;align-items:flex-start;gap:1rem;padding:1.125rem 1.25rem;cursor:pointer;font-weight:600;list-style:none;user-select:none}
.module summary::-webkit-details-marker{display:none}
.module-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-primary);color:var(--color-accent);border-radius:10px;font-weight:800;font-size:.9375rem;flex-shrink:0;font-variant-numeric:tabular-nums;margin-top:2px;transition:transform .25s ease, background .25s ease}
.module[open] .module-num{transform:scale(1.05);background:var(--color-accent);color:#fff}
.module-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}
.module-title{color:var(--color-primary);font-size:1.0625rem;font-weight:700;line-height:1.35}
.module-subtitle{font-size:.875rem;font-weight:400;color:var(--color-text-muted);line-height:1.45}
.module-toggle{font-size:1.5rem;line-height:1;color:var(--color-text-muted);font-weight:300;flex-shrink:0;transition:transform .3s cubic-bezier(.34,1.56,.64,1);margin-top:6px}
.module[open] .module-toggle{transform:rotate(45deg);color:var(--color-accent)}
.module-body{padding:0 1.25rem 1.25rem calc(40px + 1.25rem + 1rem);border-top:1px solid var(--color-border);animation:fadeInUp .35s ease}
.module-body ul{list-style:none;padding:1rem 0 0;margin:0;display:grid;gap:.5rem}
.module-body li{position:relative;padding-left:1rem;color:var(--color-text-muted);font-size:.9375rem;line-height:1.55}
.module-body li::before{content:"";position:absolute;left:0;top:.625rem;width:5px;height:5px;background:var(--color-accent);border-radius:50%}
@keyframes fadeInUp{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:640px){
  .module summary{padding:1rem;gap:.75rem}
  .module-num{width:36px;height:36px;font-size:.875rem}
  .module-title{font-size:.9375rem}
  .module-subtitle{font-size:.8125rem}
  .module-body{padding:0 1rem 1rem 1rem}
}

/* Expert exclusive modules block */
.expert-modules-block{max-width:820px;margin:3rem auto 2.5rem;position:relative}
.expert-modules-block::before{content:"";position:absolute;top:-1.5rem;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent)}
.expert-modules-header{text-align:center;margin-bottom:1.5rem}
.expert-badge{display:inline-block;background:linear-gradient(135deg,var(--color-premium),#daa520);color:#fff;font-size:.6875rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1rem;border-radius:999px;margin-bottom:1rem;box-shadow:0 4px 14px rgba(184,134,11,.3)}
.expert-modules-header h3{font-size:clamp(1.25rem,2.5vw,1.625rem);margin-bottom:.625rem;color:var(--color-primary)}
.expert-modules-lead{font-size:1rem;color:var(--color-text-muted);max-width:50ch;margin:0 auto;line-height:1.55}
.module-expert{border-color:rgba(184,134,11,.35);background:linear-gradient(180deg,#fff,#fffbf0)}
.module-expert:hover{border-color:var(--color-premium);box-shadow:0 6px 20px rgba(184,134,11,.12)}
.module-expert[open]{border-color:var(--color-premium);box-shadow:0 8px 24px rgba(184,134,11,.18)}
.module-num-expert{background:var(--color-premium);color:#fff}
.module-expert[open] .module-num-expert{background:#daa520;color:#fff}
.recap-box{max-width:820px;margin:0 auto;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-radius:16px;padding:2rem;box-shadow:var(--shadow-lg)}
.recap-title{font-size:1.125rem;font-weight:800;margin-bottom:1rem;color:#fff}
.recap-list{list-style:none;padding:0;margin:0;display:grid;gap:.625rem}
.recap-list li{font-size:1rem;color:rgba(255,255,255,.92)}
@media (min-width:640px){.recap-list{grid-template-columns:1fr 1fr;gap:.625rem 1.5rem}}

/* ==========================================================================
   TESTIMONIALS SECTION
   ========================================================================== */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:.5rem;align-items:start}
@media (min-width:640px){.testimonials-grid{grid-template-columns:1fr 1fr}}
@media (min-width:992px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:1.75rem;display:flex;flex-direction:column;gap:1rem;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease,border-color .3s ease;position:relative}
.testimonial-card::before{content:"\201C";position:absolute;top:.5rem;right:1.25rem;font-size:3rem;font-family:Georgia,serif;color:var(--color-accent);opacity:.12;line-height:1;font-weight:700;pointer-events:none}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(0,200,150,.3)}
.testimonial-short{padding:1.5rem 1.75rem;background:linear-gradient(135deg,#fff,#f0f9f6)}
.testimonial-short p{font-size:1.0625rem;font-weight:600;color:var(--color-primary);font-style:italic}
.testimonial-long p{font-size:.9375rem}
.testimonial-medium p{font-size:.9375rem}
.testimonial-header{display:flex;align-items:center;gap:.875rem}
.avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0}
.testimonial-name{font-weight:700;color:var(--color-primary);font-size:1rem;line-height:1.2}
.testimonial-role{font-size:.8125rem;color:var(--color-text-muted);margin-top:.125rem}
.testimonial-stars{font-size:.75rem;margin-top:.25rem;letter-spacing:1px}
.testimonial-card p{font-size:.9375rem;line-height:1.6;color:var(--color-text);margin:0;flex:1}
.testimonial-badge{font-size:.75rem;font-weight:600;color:var(--color-accent);padding:.375rem .625rem;background:rgba(0,200,150,.08);border-radius:6px;align-self:flex-start}
.testimonials-stat{margin-top:3rem;padding:1.5rem 2rem;background:var(--color-bg-alt);border-radius:12px;text-align:center;font-size:1rem;color:var(--color-text);line-height:1.7}
.testimonials-stat strong{color:var(--color-primary)}
@media (max-width:480px){
  .testimonials-stat{font-size:.9375rem;padding:1.25rem}
}

/* ==========================================================================
   PRICING SECTION (CŒUR DE CONVERSION)
   ========================================================================== */
.section-pricing{background:var(--color-bg-alt);position:relative}
.section-pricing::before{content:"";position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(180deg,var(--color-bg-alt) 0%,transparent 100%);pointer-events:none}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:2rem;align-items:start}
@media (min-width:992px){
  .pricing-grid{grid-template-columns:1fr 1.1fr 1fr;gap:1.5rem;align-items:center}
}

.price-card{position:relative;background:#fff;border:1px solid var(--color-border);border-radius:20px;padding:2rem 1.75rem;display:flex;flex-direction:column;gap:1rem;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s var(--ease-out)}
.price-card:hover{transform:scale(1.015) translateY(-2px);box-shadow:var(--shadow-lg)}

.price-badge{display:inline-block;align-self:flex-start;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.375rem .625rem;border-radius:6px;margin-bottom:.25rem}
.price-badge-gray{background:#f1f5f9;color:#475569}
.price-badge-accent{background:rgba(0,200,150,.12);color:var(--color-accent)}
.price-badge-premium{background:rgba(184,134,11,.12);color:var(--color-premium)}

.price-name{font-size:1.75rem;margin:0;color:var(--color-primary)}
.price-tagline{color:var(--color-text-muted);font-size:.9375rem;margin:0 0 .5rem}

.price-amount{padding:1rem 0;border-bottom:1px solid var(--color-border)}
.price-strike{font-size:1rem;color:var(--color-text-muted);margin-bottom:.25rem}
.price-strike s{opacity:.7}
.price-now{font-size:3rem;font-weight:900;color:var(--color-primary);line-height:1;letter-spacing:-0.03em}
.price-now span{font-size:1.25rem;font-weight:700;color:var(--color-text-muted);margin-left:.25rem}
.price-now-large{font-size:3.5rem;color:var(--color-accent)}
.price-vat{font-size:.8125rem;color:var(--color-text-muted);margin-top:.5rem}
.price-installment{font-size:.875rem;color:var(--color-success);font-weight:600;margin-top:.5rem}

.price-saving{display:inline-block;align-self:flex-start;background:rgba(0,200,150,.12);color:var(--color-accent);font-weight:700;font-size:.875rem;padding:.5rem .75rem;border-radius:8px}
.price-saving-premium{background:rgba(184,134,11,.12);color:var(--color-premium)}

.price-features{list-style:none;padding:0;margin:0;display:grid;gap:.625rem;flex:1}
.price-features li{font-size:.9375rem;line-height:1.5;color:var(--color-text)}
.price-features-muted li{opacity:.45;color:var(--color-text-muted)}

.price-scarcity{font-size:.875rem;font-weight:600;color:#b45309;background:#fef3c7;padding:.75rem .875rem;border-radius:8px;border-left:3px solid #f59e0b;line-height:1.45}

.btn-block{display:flex;width:100%;justify-content:center}
.btn-outline-premium{border-color:var(--color-premium);color:var(--color-premium)}
.btn-outline-premium:hover{background:var(--color-premium);color:#fff}

.price-footnote{font-size:.75rem;color:var(--color-text-muted);text-align:center;margin:.25rem 0 0}

.price-payments{display:flex;flex-wrap:wrap;justify-content:center;gap:.375rem;margin-top:.5rem}
.price-payments span{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);padding:.25rem .5rem;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:4px}

/* PRO card emphasis */
.price-pro{border:2px solid var(--color-accent);box-shadow:var(--shadow-xl);transform:scale(1.02);position:relative}
.price-pro::after{content:"";position:absolute;inset:-2px;border-radius:20px;background:linear-gradient(135deg,var(--color-accent),#00e6a8);z-index:-1;opacity:0;transition:opacity .4s ease}
.price-pro:hover{transform:scale(1.04) translateY(-2px)}
.price-pro:hover::after{opacity:.4;filter:blur(12px)}
@media (min-width:992px){
  .price-pro{transform:scale(1.06) translateY(-12px)}
  .price-pro:hover{transform:scale(1.07) translateY(-16px)}
}
.price-popular{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--color-accent);color:#fff;font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.5rem 1rem;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-md)}

/* Mobile reorder: PRO first */
@media (max-width:991px){
  .pricing-grid{display:flex;flex-direction:column}
  .price-pro{order:-1}
  .price-essential{order:1}
  .price-expert{order:2}
}

/* ==========================================================================
   GUARANTEE
   ========================================================================== */
.section-guarantee{padding:clamp(2rem,5vw,4rem) 0}
.guarantee-box{background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border:2px solid var(--color-accent);border-radius:20px;padding:2.5rem;display:flex;align-items:flex-start;gap:2rem;max-width:920px;margin:0 auto;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.guarantee-box::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.5),transparent 65%);top:-100px;right:-100px;pointer-events:none}
.guarantee-icon{font-size:4.5rem;line-height:1;flex-shrink:0;animation:guarantee-pulse 3s ease-in-out infinite}
@keyframes guarantee-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@media (prefers-reduced-motion:reduce){.guarantee-icon{animation:none}}
.guarantee-text h2{font-size:clamp(1.5rem,3vw,2rem);text-align:left;max-width:none;margin:0 0 1rem;color:var(--color-primary)}
.guarantee-text p{font-size:1.0625rem;line-height:1.6;color:var(--color-text);margin:0 0 .75rem}
.guarantee-text p:last-child{margin-bottom:0}
@media (max-width:640px){
  .guarantee-box{flex-direction:column;gap:1.25rem;padding:1.75rem;text-align:left}
  .guarantee-icon{font-size:3.5rem}
}

/* ==========================================================================
   FOR WHOM
   ========================================================================== */
.forwhom-grid{display:grid;grid-template-columns:1fr;gap:2rem}
@media (min-width:768px){.forwhom-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
.forwhom-col{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:2rem;box-shadow:var(--shadow-sm)}
.forwhom-col h2{text-align:left;max-width:none;font-size:clamp(1.375rem,2.5vw,1.75rem);margin-bottom:1.5rem}
.forwhom-yes{border-left:4px solid var(--color-accent)}
.forwhom-no{border-left:4px solid var(--color-error);background:var(--color-bg-alt)}
.forwhom-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.875rem}
.forwhom-col li{font-size:1rem;line-height:1.5;padding-left:.25rem}
.forwhom-yes li{color:var(--color-text)}
.forwhom-no li{color:var(--color-text-muted)}

/* ==========================================================================
   FAQ
   ========================================================================== */
.section-faq{background:var(--color-bg-alt)}
.faq{display:grid;gap:.75rem;margin-top:1rem}
.faq-item{background:#fff;border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:box-shadow .3s var(--ease-out),border-color .3s var(--ease-out)}
.faq-item:hover{box-shadow:var(--shadow-sm);border-color:#d4d8de}
.faq-item[open]{box-shadow:var(--shadow-md);border-color:var(--color-accent)}
.faq-item[open] .faq-body{animation:fadeInUp .3s var(--ease-out)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.25rem;cursor:pointer;font-weight:700;list-style:none;color:var(--color-primary);font-size:1.0625rem;line-height:1.4}
.faq-item summary::-webkit-details-marker{display:none}
.faq-toggle{font-size:1.5rem;font-weight:300;color:var(--color-text-muted);line-height:1;flex-shrink:0;transition:transform .25s ease}
.faq-item[open] .faq-toggle{transform:rotate(45deg);color:var(--color-accent)}
.faq-body{padding:0 1.25rem 1.25rem;border-top:1px solid var(--color-border)}
.faq-body p{margin:1rem 0 0;color:var(--color-text-muted);font-size:1rem;line-height:1.65}
@media (max-width:640px){
  .faq-item summary{padding:1rem;font-size:.9375rem}
  .faq-body{padding:0 1rem 1rem}
}

/* ==========================================================================
   CLOSER
   ========================================================================== */
.section-closer{padding:0;background:transparent}
.closer-box{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;padding:clamp(3rem,6vw,5rem) clamp(1.5rem,4vw,3rem);text-align:center;border-radius:0;position:relative;overflow:hidden}
.closer-box::before{content:"";position:absolute;top:-50%;left:-10%;width:120%;height:200%;background:radial-gradient(circle at 50% 50%,rgba(0,200,150,.15) 0%,transparent 60%);pointer-events:none}
.closer-box>*{position:relative;z-index:1}
.closer-box h2{color:#fff;text-align:center;margin:0 auto 1rem;max-width:24ch;font-size:clamp(1.75rem,4vw,2.75rem)}
.closer-sub{font-size:1.0625rem;color:rgba(255,255,255,.85);max-width:46ch;margin:0 auto 2.5rem;line-height:1.55}
.closer-timer{display:flex;justify-content:center;gap:.75rem;margin:0 auto 1rem;flex-wrap:wrap;max-width:520px}
.closer-timer>div{background:rgba(255,255,255,.08);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:1rem .875rem;min-width:88px;display:flex;flex-direction:column;align-items:center;gap:.25rem}
.closer-timer strong{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:900;line-height:1;font-variant-numeric:tabular-nums;color:#fff}
.closer-timer span{font-size:.75rem;font-weight:500;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.05em}
.closer-warn{font-size:.9375rem;color:#fbbf24;margin:1rem 0 2rem;font-weight:600}
.closer-mini-prices{display:flex;justify-content:center;gap:.75rem;margin:0 auto 2rem;flex-wrap:wrap;max-width:560px}
.mini-price{flex:1;min-width:140px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:1rem .75rem;text-align:center;color:#fff;text-decoration:none;transition:background .3s var(--ease-out),transform .3s var(--ease-spring),border-color .3s var(--ease-out)}
.mini-price:hover{background:rgba(255,255,255,.14);transform:translateY(-4px);text-decoration:none;border-color:rgba(255,255,255,.28)}
.mini-price-pro{background:var(--color-accent);border-color:var(--color-accent)}
.mini-price-pro:hover{background:var(--color-accent-hover)}
.mini-price-name{font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:.25rem}
.mini-price-amount{font-size:1.25rem;font-weight:800;color:#fff}
.closer-cta{margin:.5rem auto 2rem;font-size:1.125rem}
.closer-trust{display:flex;justify-content:center;gap:1rem 2rem;flex-wrap:wrap;font-size:.875rem;color:rgba(255,255,255,.8)}
@media (max-width:480px){
  .closer-timer{gap:.5rem}
  .closer-timer>div{min-width:0;flex:1;padding:.75rem .5rem}
  .closer-timer strong{font-size:1.5rem}
  .mini-price{min-width:0;flex:1 0 calc(33% - .5rem)}
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--color-primary-dark);color:rgba(255,255,255,.75);padding:clamp(3rem,5vw,4rem) 0 1.5rem;font-size:.9375rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:2.5rem}
@media (min-width:768px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.logo-light{color:#fff;margin-bottom:1rem}
.logo-light .logo-mark{background:var(--color-accent);color:var(--color-primary-dark)}
.footer-brand p{font-size:.9375rem;line-height:1.6;color:rgba(255,255,255,.65);max-width:34ch}
.footer-nav h4,.footer-badges h4{color:#fff;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0 0 1rem}
.footer-nav ul{list-style:none;padding:0;margin:0;display:grid;gap:.625rem}
.footer-nav a{color:rgba(255,255,255,.75);text-decoration:none;font-size:.9375rem;transition:color .2s ease}
.footer-nav a:hover{color:var(--color-accent);text-decoration:none}
.badges{display:flex;flex-direction:column;gap:.625rem;font-size:.875rem;color:rgba(255,255,255,.7)}
.footer-disclaimer{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;margin-bottom:1.5rem}
.footer-disclaimer p{font-size:.8125rem;color:rgba(255,255,255,.5);line-height:1.6;margin:0;max-width:920px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.25rem;font-size:.8125rem;color:rgba(255,255,255,.5)}
.footer-bottom p{margin:0}

/* ==========================================================================
   MOBILE STICKY CTA
   ========================================================================== */
.mobile-sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:40;background:#fff;border-top:1px solid var(--color-border);padding:.75rem 1rem;display:none;align-items:center;justify-content:space-between;gap:.75rem;box-shadow:0 -4px 12px rgba(0,0,0,0.08)}
.mobile-sticky-cta .btn{flex-shrink:0;min-height:44px;padding:.75rem 1.125rem;font-size:.9375rem}
.mobile-sticky-text{font-size:.9375rem;color:var(--color-text-muted)}
.mobile-sticky-text strong{color:var(--color-primary);font-size:1.0625rem}
@media (max-width:768px){
  .mobile-sticky-cta{display:flex}
  body{padding-bottom:80px}
}
.mobile-sticky-cta.is-hidden{transform:translateY(100%);transition:transform .25s ease}

/* ==========================================================================
   EXIT POPUP
   ========================================================================== */
.exit-popup{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .25s ease}
.exit-popup.is-visible{opacity:1;pointer-events:auto}
.exit-popup[hidden]{display:none}
.exit-popup-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);cursor:pointer}
.exit-popup-card{position:relative;background:#fff;border-radius:20px;padding:2.5rem 2rem;max-width:480px;width:100%;text-align:center;box-shadow:var(--shadow-xl);transform:translateY(20px);transition:transform .3s ease}
.exit-popup.is-visible .exit-popup-card{transform:translateY(0)}
.exit-popup-close{position:absolute;top:.75rem;right:.75rem;width:36px;height:36px;border-radius:50%;background:var(--color-bg-alt);color:var(--color-text);font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s ease}
.exit-popup-close:hover{background:var(--color-border)}
.exit-popup-icon{font-size:3.5rem;line-height:1;margin-bottom:1rem}
.exit-popup-card h3{font-size:1.375rem;margin-bottom:.75rem;line-height:1.3}
.exit-popup-card p{color:var(--color-text-muted);font-size:.9375rem;line-height:1.55;margin-bottom:1.5rem}
.exit-popup-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.exit-popup-form input{padding:.875rem 1rem;border:2px solid var(--color-border);border-radius:10px;font-size:1rem;font-family:inherit;transition:border-color .2s ease}
.exit-popup-form input:focus{outline:none;border-color:var(--color-accent)}
.exit-popup-form .btn{width:100%}
.exit-popup-dismiss{font-size:.8125rem;color:var(--color-text-muted);text-decoration:underline;background:none;border:none;cursor:pointer}
.exit-popup-dismiss:hover{color:var(--color-text)}

/* ==========================================================================
   COOKIE BANNER
   ========================================================================== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:60;background:#fff;border-top:1px solid var(--color-border);box-shadow:0 -4px 16px rgba(0,0,0,.08);padding:1rem 0;font-size:.875rem;animation:slideUp .35s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-banner-inner{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;justify-content:space-between}
.cookie-banner p{margin:0;color:var(--color-text-muted);max-width:60ch;line-height:1.5}
.cookie-banner a{color:var(--color-primary);font-weight:600}
.cookie-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.btn-small{padding:.625rem 1rem;font-size:.875rem;min-height:40px}
.btn-link{background:none;color:var(--color-text-muted);font-size:.875rem;text-decoration:underline;padding:.5rem;cursor:pointer;border:none}
.btn-link:hover{color:var(--color-text)}
@media (max-width:640px){
  .cookie-banner{padding:.875rem 0;font-size:.8125rem}
  .cookie-banner-inner{gap:.75rem}
  .cookie-actions{width:100%;justify-content:flex-end}
  body.cookie-visible{padding-bottom:140px}
}
@media (min-width:769px){
  body.cookie-visible .mobile-sticky-cta{display:none!important}
}

/* When mobile sticky needs to avoid the cookie banner */
body.cookie-visible .mobile-sticky-cta{bottom:auto;display:none}

/* ==========================================================================
   ACCESSIBILITY
   ========================================================================== */
:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px;border-radius:4px}
.btn:focus-visible{outline-offset:4px}
@media (prefers-color-scheme:dark){
  /* Light theme only by choice, no dark variant */
}

/* ==========================================================================
   PRINT
   ========================================================================== */
@media print{
  .sticky-bar,.mobile-sticky-cta,.exit-popup,.cookie-banner,.btn{display:none!important}
  body{padding:0}
}
