/* ============================================================
   DoctorLáser v1 — Design System (v2 palette)
   Primary: #BF88B5 (mauve-rose) | Accent: #E8C06A (gold)
   Corregido para Android: dvh, safe-area, backdrop-fallback
   ============================================================ */

/* ── DESIGN TOKENS ────────────────────────────────────────── */
:root {
  --c-p50:   #FAF5F9;
  --c-p100:  #F3E6F1;
  --c-p200:  #E4CCDF;
  --c-p300:  #D1ADCA;
  --c-p400:  #CA97C2;
  --c-p500:  #BF88B5;
  --c-p600:  #A46E9A;
  --c-p700:  #865880;
  --c-p800:  #5C3458;
  --c-p900:  #331730;

  --c-a400:  #E8C06A;
  --c-a500:  #D4A43C;

  --c-white: #FFFFFF;
  --c-n50:   #F8F5F8;
  --c-n100:  #EDE7ED;
  --c-n200:  #D8CDD8;
  --c-n300:  #BEB0BE;
  --c-n400:  #9D8C9D;
  --c-n500:  #796A79;
  --c-n600:  #574D57;
  --c-n700:  #3C3140;
  --c-n800:  #241A28;

  --c-wa:    #25D366;
  --c-wa-dk: #1fbd5c;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-sans:    'DM Sans', system-ui, sans-serif;

  --radius-xs:   4px;
  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-pill: 999px;

  --shadow-sm:  0 1px 4px rgba(51,23,48,.08);
  --shadow-md:  0 4px 16px rgba(51,23,48,.12);
  --shadow-lg:  0 12px 40px rgba(51,23,48,.18);

  --dur-fast: 180ms;
  --dur-mid:  320ms;

  /* Safe area insets (para notch, barra de navegación) */
  --safe-top:    env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left, 0px);
  --safe-right:  env(safe-area-inset-right, 0px);
}

/* ── RESET ────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);font-size:16px;color:var(--c-n700);background:var(--c-white);line-height:1.6;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ── LAYOUT ───────────────────────────────────────────────── */
.container{max-width:1100px;margin-inline:auto;padding:0 1.5rem}
.container--narrow{max-width:780px;margin-inline:auto;padding:0 1.5rem}
section{padding:5rem 0}
.section{padding:5rem 0}
.section--sm{padding:2rem 0}
.bg-light{background:var(--c-n50)}
.bg-teal-light{background:var(--c-p50)}
.text-center{text-align:center}

.grid-2{display:grid;gap:3rem;align-items:center}
.grid-3{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}}

/* ── TYPOGRAPHY ───────────────────────────────────────────── */
.eyebrow{font-family:var(--font-sans);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--c-p600);display:block;margin-bottom:.5rem}
.eyebrow--light{color:var(--c-p300)}

h1{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);line-height:1.15;font-weight:400;color:var(--c-n800)}
h1 em{font-style:italic;color:var(--c-p500)}
h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.2;font-weight:400;color:var(--c-n800)}
h2 em{font-style:italic;color:var(--c-p600)}
h3{font-family:var(--font-sans);font-size:1.0625rem;font-weight:500;color:var(--c-n800)}

.display-md{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:400;line-height:1.15;color:var(--c-n800)}
.display-md em{font-style:italic;color:var(--c-p600)}

.lead{font-size:16px;color:var(--c-n500);line-height:1.75}

.section-divider{width:40px;height:2px;background:linear-gradient(90deg,var(--c-p500),var(--c-p300));border-radius:2px;margin:.75rem 0 1.25rem}
.section-divider--center{margin-left:auto;margin-right:auto}

.section-header{margin-bottom:3rem}
.section-header--center{text-align:center}
.section-header--center .section-divider{margin-left:auto;margin-right:auto}
.section-header__eyebrow{margin-bottom:.5rem}
.section-header__title{font-family:var(--font-display);font-size:clamp(1.9rem,3vw,2.6rem);font-weight:400;color:var(--c-n800);line-height:1.15}
.section-header__title em{font-style:italic;color:var(--c-p600)}
.section-header__text{margin-top:.75rem;font-size:15px;color:var(--c-n500);max-width:540px}
.section-header--center .section-header__text{margin-inline:auto}

.mt-4{margin-top:2.5rem}

/* ── SKIP LINK ────────────────────────────────────────────── */
.skip-link{position:absolute;top:-100%;left:.5rem;padding:.5rem 1rem;background:var(--c-p800);color:var(--c-white);border-radius:0 0 var(--radius-md) var(--radius-md);font-weight:600;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ── NAVIGATION ───────────────────────────────────────────── */
/* Fallback sólido si backdrop-filter no es soportado */
.nav{position:sticky;top:0;z-index:100;background:rgba(250,245,249,0.95);border-bottom:1px solid var(--c-p200);height:64px;display:flex;align-items:center;transition:background var(--dur-mid)}
/* Aplicar blur solo si hay soporte */
@supports ((-webkit-backdrop-filter: blur(14px)) or (backdrop-filter: blur(14px))) {
  .nav{background:rgba(250,245,249,0.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
}
.nav.scrolled{background:rgba(250,245,249,0.98)}

.nav-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}

.nav-logo{font-family:var(--font-display);font-size:1.35rem;font-weight:500;color:var(--c-p800);letter-spacing:-.01em;flex-shrink:0;white-space:nowrap;display:flex;flex-direction:column;line-height:1.2}
.nav-logo em{font-style:italic;color:var(--c-p500);font-size:.7em;font-weight:400}

.nav-links{display:flex;align-items:center;gap:1.75rem;list-style:none}
.nav-links a{font-size:13.5px;color:var(--c-n600);font-weight:400;transition:color var(--dur-fast);white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--c-p700)}
.nav-links a.active{font-weight:500}

.nav-cta{flex-shrink:0;display:inline-flex;align-items:center;gap:.5rem;background:var(--c-p500);color:var(--c-white);font-size:13px;font-weight:500;padding:.55rem 1.2rem;border-radius:var(--radius-pill);transition:background var(--dur-fast),transform var(--dur-fast);white-space:nowrap}
.nav-cta:hover{background:var(--c-p700);transform:translateY(-1px)}

.nav-cta-mobile{display:none}
.nav-mobile-btn{display:none;background:none;border:none;font-size:1.75rem;color:var(--c-n700);cursor:pointer;padding:4px;line-height:1}

.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99}
.nav-overlay.active{display:block}

@media(max-width:860px){
  .nav-links{
    position:fixed;top:0;right:-100%;width:280px;
    height:100vh;           /* fallback antiguo */
    height:100dvh;          /* altura dinámica real (Android) */
    background:var(--c-white);flex-direction:column;
    gap:1.5rem;transition:right .3s ease;box-shadow:-4px 0 20px rgba(0,0,0,.1);
    z-index:200;display:flex!important;list-style:none;overflow-y:auto;
    /* Padding con safe-area */
    padding:5rem 2rem 2rem;
    padding-top:calc(5rem + var(--safe-top));
    padding-bottom:calc(2rem + var(--safe-bottom));
    padding-left:calc(2rem + var(--safe-left));
    padding-right:calc(2rem + var(--safe-right));
  }
  .nav-links.active{right:0}
  .nav-cta-mobile{display:block;margin-top:auto}
  .nav-mobile-btn{display:block}
  .nav-cta.desktop-only{display:none}

  /* Ajustar overlay para cubrir áreas seguras */
  .nav-overlay{
    top:calc(0px - var(--safe-top));
    bottom:calc(0px - var(--safe-bottom));
    left:calc(0px - var(--safe-left));
    right:calc(0px - var(--safe-right));
  }
}

/* ── HERO ─────────────────────────────────────────────────── */
.hero{position:relative;display:flex;align-items:center;overflow:hidden;color:var(--c-white)}
.hero--full{min-height:100svh}
.hero--compact{min-height:min(72vh,640px)}

.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform 6s ease}
.hero:hover .hero__bg{transform:scale(1)}

.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(51,23,48,.82) 0%,rgba(92,52,88,.65) 55%,rgba(164,110,154,.3) 100%)}

.hero__content{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:6rem 1.5rem 4rem;width:100%}

.hero__tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(191,136,181,.18);border:1px solid rgba(209,173,202,.35);color:var(--c-p200);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.45rem 1rem;border-radius:var(--radius-pill);margin-bottom:1.5rem}

.hero__title{font-family:var(--font-display);font-size:clamp(2.4rem,5.5vw,4.8rem);font-weight:300;line-height:1.08;color:var(--c-white);margin-bottom:1.25rem;max-width:780px}
.hero__title em{font-style:italic;color:var(--c-p300)}

.hero__sub{font-size:16px;color:rgba(255,255,255,.7);line-height:1.75;max-width:560px;margin-bottom:2.25rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem}

/* old v1 hero compat */
.hero__bg-gradient{position:absolute;inset:0;background:linear-gradient(135deg,var(--c-p900),var(--c-p700));z-index:-1}

/* ── STATS STRIP ──────────────────────────────────────────── */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat-item{text-align:center;padding:1.25rem .5rem}
.stat-num{font-family:var(--font-display);font-size:3rem;font-weight:300;color:var(--c-white);line-height:1;margin-bottom:.35rem}
.stat-label{font-size:13px;color:rgba(255,255,255,.55)}
@media(max-width:720px){.stats-strip{grid-template-columns:repeat(2,1fr)}}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--font-sans);font-size:14px;font-weight:500;padding:.7rem 1.5rem;border-radius:var(--radius-pill);cursor:pointer;border:none;transition:background var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast),transform var(--dur-fast),box-shadow var(--dur-fast);white-space:nowrap;text-decoration:none;touch-action:manipulation} /* evita zoom accidental en Android */
.btn:hover{transform:translateY(-2px)}
.btn--lg{font-size:15px;padding:.85rem 2rem}

.btn--primary{background:var(--c-p500);color:var(--c-white);box-shadow:0 2px 14px rgba(191,136,181,.4)}
.btn--primary:hover{background:var(--c-p700);box-shadow:0 6px 24px rgba(134,88,128,.45)}

.btn--outline{background:transparent;color:var(--c-white);border:1.5px solid rgba(255,255,255,.45)}
.btn--outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.75)}

.btn--teal{background:var(--c-p800);color:var(--c-white);box-shadow:0 2px 12px rgba(92,52,88,.35)}
.btn--teal:hover{background:var(--c-p900);box-shadow:0 6px 20px rgba(51,23,48,.4)}

.btn--wa{background:var(--c-wa);color:var(--c-white);box-shadow:0 2px 14px rgba(37,211,102,.35)}
.btn--wa:hover{background:var(--c-wa-dk);box-shadow:0 6px 24px rgba(37,211,102,.45)}

.link-arrow{display:inline-flex;align-items:center;gap:.25rem;font-weight:600;color:var(--c-p500)}
.link-arrow:hover{text-decoration:underline}

/* ── CARDS ────────────────────────────────────────────────── */
.card{background:var(--c-white);border:1px solid var(--c-n100);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:box-shadow var(--dur-mid),transform var(--dur-mid),border-color var(--dur-mid)}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--c-p200)}
.card i{font-size:2rem;color:var(--c-p500);margin-bottom:1rem;display:block}

.benefit-card{background:var(--c-white);border:1px solid var(--c-n100);border-radius:var(--radius-lg);padding:1.75rem;display:flex;flex-direction:column;gap:.6rem;transition:box-shadow var(--dur-mid),transform var(--dur-mid),border-color var(--dur-mid)}
.benefit-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--c-p200)}
.benefit-card__num{font-family:var(--font-display);font-size:2.5rem;font-weight:300;color:var(--c-p200);line-height:1}
.benefit-card__title{font-size:16px;font-weight:500;color:var(--c-n800);line-height:1.3}
.benefit-card__text{font-size:14px;color:var(--c-n500);line-height:1.7}

.treatment-card{background:var(--c-white);border:1px solid var(--c-n100);border-radius:var(--radius-lg);padding:1.75rem;display:flex;flex-direction:column;gap:.75rem;transition:box-shadow var(--dur-mid),border-color var(--dur-mid),transform var(--dur-mid)}
.treatment-card:hover{box-shadow:var(--shadow-lg);border-color:var(--c-p200);transform:translateY(-2px)}
.treatment-card__icon{width:48px;height:48px;background:var(--c-p50);border:1px solid var(--c-p100);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--c-p600);flex-shrink:0}
.treatment-card__title{font-size:17px;font-weight:500;color:var(--c-n800);line-height:1.3}
.treatment-card__desc{font-size:14px;color:var(--c-n500);line-height:1.7}
.treatment-card__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}

/* ── TAGS / PILLS ─────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--radius-pill);background:var(--c-p50);color:var(--c-p700);border:1px solid var(--c-p100);letter-spacing:.04em}
.tag--new{background:linear-gradient(135deg,var(--c-p600),var(--c-p800));color:var(--c-white);border-color:transparent}

.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--c-p200);background:rgba(191,136,181,.15);border:1px solid rgba(191,136,181,.25);padding:4px 12px;border-radius:var(--radius-pill)}

/* ── COMPARISON TABLE ─────────────────────────────────────── */
.comparison-table{width:100%;border-collapse:collapse;background:var(--c-white);border:1px solid var(--c-n100);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);font-size:14px}
.comparison-table thead tr{background:var(--c-p900);color:var(--c-white)}
.comparison-table th{padding:.9rem 1.25rem;text-align:left;font-weight:500;font-size:13px;letter-spacing:.04em}
.comparison-table th:nth-child(3){color:var(--c-p300)}
.comparison-table td{padding:.85rem 1.25rem;border-bottom:1px solid var(--c-n100);color:var(--c-n600);vertical-align:middle}
.comparison-table tbody tr:last-child td{border-bottom:none}
.comparison-table tbody tr:nth-child(even){background:var(--c-n50)}
.comparison-table tbody tr:hover{background:var(--c-p50)}
.comparison-table td:nth-child(3){color:var(--c-p700);font-weight:500}
.icon-check{color:var(--c-p500);margin-right:.4rem}

/* ── INFO BOX ─────────────────────────────────────────────── */
.info-box{background:var(--c-p50);border-left:3px solid var(--c-p400);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:1rem 1.25rem;font-size:14px;color:var(--c-n600);line-height:1.7}
.info-box strong{color:var(--c-p800)}

/* ── EVIDENCE ITEMS ───────────────────────────────────────── */
.evidence-item{display:flex;gap:1.25rem;align-items:flex-start;padding:1.5rem;background:var(--c-white);border:1px solid var(--c-n100);border-radius:var(--radius-lg);transition:box-shadow var(--dur-mid),border-color var(--dur-mid)}
.evidence-item:hover{box-shadow:var(--shadow-md);border-color:var(--c-p200)}
.evidence-icon{width:44px;height:44px;flex-shrink:0;background:var(--c-p50);border:1px solid var(--c-p100);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--c-p600)}
.evidence-item__title{font-size:15px;font-weight:500;color:var(--c-n800);margin-bottom:.4rem}
.evidence-item__text{font-size:13.5px;color:var(--c-n500);line-height:1.7;margin-bottom:.5rem}
.evidence-item__source{font-size:11.5px;color:var(--c-p600);font-style:italic;letter-spacing:.02em}

/* ── CTA SECTION ──────────────────────────────────────────── */
.cta-section{background:var(--c-p900);padding:5rem 0}
.cta-section__inner{display:flex;align-items:center;justify-content:space-between;gap:2.5rem;flex-wrap:wrap}
.cta-section__title{font-family:var(--font-display);font-size:clamp(1.9rem,3vw,2.6rem);font-weight:400;color:var(--c-white);line-height:1.15;margin-bottom:.6rem}
.cta-section__title em{font-style:italic;color:var(--c-p300)}
.cta-section__sub{font-size:15px;color:rgba(255,255,255,.55);max-width:460px;line-height:1.65}
.cta-section__actions{display:flex;flex-wrap:wrap;gap:.85rem;flex-shrink:0}

/* ── FOOTER ───────────────────────────────────────────────── */
.footer{background:var(--c-n800);color:rgba(255,255,255,.55);padding:4rem 0 2rem}
.footer-inner{display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:space-between;max-width:1100px;margin-inline:auto;padding:0 1.5rem}
.footer a:hover{color:var(--c-white)}
.footer-logo{font-family:var(--font-display);font-size:1.35rem;color:var(--c-white);margin-bottom:.75rem}
.footer-logo em{font-style:italic;color:var(--c-p400)}
.footer-tagline{font-size:13px;line-height:1.65;color:rgba(255,255,255,.5)}
.footer-heading{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--c-p300);margin-bottom:1rem;display:block}
.footer-links{display:flex;flex-direction:column;gap:.5rem}
.footer-links a{font-size:13.5px;color:rgba(255,255,255,.5);transition:color var(--dur-fast)}
.footer-links a:hover{color:var(--c-p300)}
.footer-copy{max-width:1100px;margin:1.5rem auto 0;padding:1rem 1.5rem 0;border-top:1px solid rgba(255,255,255,.08);font-size:12.5px;color:var(--c-n500);display:flex;justify-content:center;flex-wrap:wrap;gap:1rem;text-align:center}
.footer-copy a{color:rgba(255,255,255,.4)}
.footer-copy a:hover{color:var(--c-white)}

.footer-hour-row{display:flex;justify-content:space-between;padding:3px 0;gap:1rem;font-size:12px;color:rgba(255,255,255,.4)}
.footer-hour-row--closed span:last-child{opacity:.4}

/* ── WHATSAPP FLOAT ───────────────────────────────────────── */
#wa-float,.wa-float{position:fixed;z-index:150;
  bottom:calc(1.75rem + var(--safe-bottom));
  right:calc(1.75rem + var(--safe-right));
}
#wa-float a,.wa-float a{display:flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--c-wa);border-radius:50%;color:var(--c-white);font-size:26px;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:transform var(--dur-fast),box-shadow var(--dur-fast);touch-action:manipulation}
#wa-float a:hover,.wa-float a:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,.6)}

/* ── FORM STYLES ──────────────────────────────────────────── */
.agenda-form,.form-card{background:var(--c-white);border:1px solid var(--c-n100);padding:2.25rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}
.form-group,.form-field{margin-bottom:1.25rem}
.form-group label,.form-label{display:block;font-size:13px;font-weight:500;color:var(--c-n700);margin-bottom:.4rem}
.form-label span{color:var(--c-p500);margin-left:2px}
.form-group input,.form-group select,.form-group textarea,
.form-input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--c-n200);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:14px;color:var(--c-n800);background:var(--c-white);transition:border-color var(--dur-fast),box-shadow var(--dur-fast);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.form-input:focus{border-color:var(--c-p400);box-shadow:0 0 0 3px rgba(191,136,181,.15)}
.form-group input::placeholder,.form-input::placeholder{color:var(--c-n300)}
.form-group textarea,.form-input[type="textarea"],textarea.form-input{resize:vertical;min-height:100px}
.form-group input[aria-invalid="true"],.form-group select[aria-invalid="true"]{border-color:#dc2626;background:#fef2f2}
.form-group label:has(input[type="checkbox"]){display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;font-size:.9rem;line-height:1.5}
.form-group input[type="checkbox"]{width:auto;min-width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--c-p500)}
.form-note{font-size:12px;color:var(--c-n400);text-align:center;margin-top:.75rem}

.form-submit{width:100%;padding:.85rem;background:var(--c-wa);color:var(--c-white);border:none;border-radius:var(--radius-pill);font-size:15px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:background var(--dur-fast),transform var(--dur-fast),box-shadow var(--dur-fast);box-shadow:0 2px 16px rgba(37,211,102,.3);font-family:var(--font-sans);touch-action:manipulation}
.form-submit:hover{background:var(--c-wa-dk);transform:translateY(-2px);box-shadow:0 6px 24px rgba(37,211,102,.4)}
.form-submit i{font-size:20px}

/* ── FAQ ──────────────────────────────────────────────────── */
.faq-item{border-bottom:1px solid var(--c-n100);overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 0;font-size:15px;font-weight:500;color:var(--c-n800);cursor:pointer;user-select:none;transition:color var(--dur-fast);gap:1rem}
.faq-question:hover{color:var(--c-p700)}
.faq-question .ti-chevron-down{font-size:16px;flex-shrink:0;color:var(--c-p400);transition:transform var(--dur-mid)}
.faq-item.open .faq-question{color:var(--c-p700)}
.faq-item.open .ti-chevron-down{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;font-size:14px;color:var(--c-n500);line-height:1.75;transition:max-height var(--dur-mid) ease,padding var(--dur-mid) ease;padding:0}
.faq-item.open .faq-answer{max-height:600px;padding-bottom:1.1rem}

/* ── TESTIMONY ────────────────────────────────────────────── */
.testimony-strip{background:linear-gradient(145deg,var(--c-p900),var(--c-p800));border-radius:var(--radius-xl);padding:2.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;border:1px solid rgba(191,136,181,.12)}
.testimony-card{background:rgba(255,255,255,.06);border:1px solid rgba(191,136,181,.15);border-radius:var(--radius-lg);padding:1.5rem;transition:background var(--dur-mid),border-color var(--dur-mid)}
.testimony-card:hover{background:rgba(255,255,255,.1);border-color:rgba(191,136,181,.3)}
.testimony-stars{color:var(--c-a400);font-size:14px;margin-bottom:.75rem;letter-spacing:2px}
.testimony-text{font-size:14px;color:rgba(255,255,255,.68);line-height:1.75;margin-bottom:1rem;font-style:italic}
.testimony-author{font-size:13px;color:var(--c-p300);font-weight:500}
.testimony-treatment{font-size:11px;color:rgba(255,255,255,.3);margin-top:3px;letter-spacing:.06em;text-transform:uppercase}

/* ── EMAIL POPUP / BANNER ─────────────────────────────────── */
.email-banner{position:fixed;bottom:0;left:0;right:0;background:var(--c-white);border-top:2px solid var(--c-p500);box-shadow:0 -4px 20px rgba(0,0,0,.1);padding:1.5rem;z-index:300;transform:translateY(100%);transition:transform .3s ease}
.email-banner.visible{transform:translateY(0)}
.email-banner__content{max-width:600px;margin:0 auto;text-align:center;position:relative}
.email-banner__close{position:absolute;top:-.5rem;right:0;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--c-n500)}
.email-banner__form{display:flex;gap:.5rem;margin:1rem 0;flex-wrap:wrap;justify-content:center}
.email-banner__form input{flex:1 1 200px;padding:.5rem 1rem;border:1px solid var(--c-n200);border-radius:var(--radius-md);font-size:14px}
.email-banner__note{font-size:12px;color:var(--c-n400)}

.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.popup-overlay.visible{opacity:1;pointer-events:auto}
.popup-card{background:var(--c-white);border-radius:var(--radius-xl);padding:2.25rem;max-width:480px;width:calc(100% - 2rem);position:relative;box-shadow:var(--shadow-lg)}
.popup-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--c-n500);line-height:1}
.popup-title{font-family:var(--font-display);font-size:1.6rem;font-weight:400;color:var(--c-n800);margin:.75rem 0 .5rem}
.popup-title em{font-style:italic;color:var(--c-p600)}
.popup-sub{font-size:14px;color:var(--c-n500);line-height:1.65;margin-bottom:1.25rem}
.popup-input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--c-n200);border-radius:var(--radius-md);font-size:14px;color:var(--c-n800);margin-bottom:.75rem;outline:none;transition:border-color var(--dur-fast)}
.popup-input:focus{border-color:var(--c-p400)}
.popup-submit{width:100%;padding:.8rem;background:var(--c-p500);color:var(--c-white);border:none;border-radius:var(--radius-pill);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background var(--dur-fast)}
.popup-submit:hover{background:var(--c-p700)}
.popup-note{font-size:12px;color:var(--c-n400);margin-top:.75rem;text-align:center}
.popup-skip{display:block;text-align:center;margin-top:.75rem;font-size:13px;color:var(--c-n400);cursor:pointer;text-decoration:underline}

/* ── 404 ──────────────────────────────────────────────────── */
.error-page{min-height:calc(100vh - 140px);display:flex;align-items:center;justify-content:center;text-align:center;padding:4rem 1rem}
.error-page__code{font-family:var(--font-display);font-size:clamp(5rem,20vw,9rem);font-weight:700;color:var(--c-p200);line-height:1;margin-bottom:.5rem;letter-spacing:-.04em}
.error-page__icon{font-size:3rem;color:var(--c-p500);margin-bottom:1rem;display:block}
.error-page h1{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1rem}
.error-page p{color:var(--c-n500);max-width:480px;margin:0 auto 2rem}
.error-page__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.error-page__links{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--c-n200)}
.error-page__links h2{font-size:1rem;font-weight:600;color:var(--c-n500);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em}
.error-page__links ul{list-style:none;display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.error-page__links a{font-weight:500;color:var(--c-p500)}

/* ── PROCESS CARD ─────────────────────────────────────────── */
.process-card{background:var(--c-white);border:1px solid var(--c-n100);border-radius:var(--radius-xl);padding:2rem 2.25rem;box-shadow:var(--shadow-sm)}
.process-step{display:flex;gap:1.25rem;align-items:flex-start;padding:1.25rem 0;border-bottom:1px solid var(--c-n100)}
.process-step:first-child{padding-top:0}
.process-step:last-child{border-bottom:none;padding-bottom:0}
.ps-num{width:36px;height:36px;flex-shrink:0;background:var(--c-p50);border:1px solid var(--c-p200);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:16px;color:var(--c-p700);font-weight:500;margin-top:2px}
.ps-title{font-size:15px;font-weight:500;color:var(--c-n800);margin-bottom:.3rem}
.ps-text{font-size:13.5px;color:var(--c-n500);line-height:1.65}

/* ── ANIMATIONS ───────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:860px){
  .cta-section__inner{flex-direction:column;text-align:center}
  .cta-section__actions{justify-content:center}
  .cta-section__sub{margin-inline:auto}
  .hero__content{padding:5rem 1.5rem 3.5rem}
  .hero--compact{min-height:min(60vh,520px)}
}
@media(max-width:640px){
  section,.section{padding:3.5rem 0}
  .hero__title{font-size:clamp(2.2rem,8vw,3.2rem)}
  .stats-strip{grid-template-columns:repeat(2,1fr);gap:.5rem}
  .testimony-strip{padding:1.5rem;gap:1rem}
  .comparison-table{font-size:12px}
  .comparison-table th,.comparison-table td{padding:.6rem .75rem}
  .grid-2{grid-template-columns:1fr}
}

/* ── REDUCED MOTION ───────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .fade-up,.fade-up.visible{transition:none;opacity:1;transform:none}
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ── FOCUS ────────────────────────────────────────────────── */
:focus-visible{outline:2px solid var(--c-p500);outline-offset:3px;border-radius:3px}