/* ============================================================
   REGENERA CYPRUS — Mediterranean medical-wellness identity
   Palette: deep cypress teal + warm limestone/sand + soft gold
   Type: Fraunces (display serif) + Hanken Grotesk (body sans)
   ============================================================ */

/* ---------- Tokens ---------- */
:root, [data-theme="light"] {
  /* Type scale (fluid) */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.6vw, 1.4rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2rem, 1.3rem + 2.4vw, 3.4rem);
  --text-3xl: clamp(2.6rem, 1.4rem + 3.6vw, 4.4rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem;
  --space-4: 1rem; --space-5: 1.25rem; --space-6: 1.5rem;
  --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem;
  --space-16: 4rem; --space-20: 5rem; --space-24: 6rem; --space-32: 8rem;

  /* Surfaces — warm limestone / sand */
  --color-bg: #f6f1e9;
  --color-surface: #fbf8f2;
  --color-surface-2: #ffffff;
  --color-surface-offset: #efe7d9;
  --color-border: #ddd2bf;
  --color-divider: #e6dccb;

  /* Text — deep warm charcoal */
  --color-text: #232a27;
  --color-text-muted: #5f655e;
  --color-text-faint: #9a9b90;
  --color-text-inverse: #f6f1e9;

  /* Primary — deep cypress teal */
  --color-primary: #0d5b54;
  --color-primary-hover: #0a4843;
  --color-primary-deep: #06322f;
  --color-primary-soft: #e0ece7;

  /* Accent — soft Mediterranean gold */
  --color-gold: #b78a3c;
  --color-gold-soft: #efe3cf;

  /* WhatsApp */
  --color-wa: #1f8a5b;
  --color-wa-hover: #176c47;

  --radius-sm: 0.4rem;
  --radius-md: 0.65rem;
  --radius-lg: 1rem;
  --radius-xl: 1.4rem;
  --radius-full: 9999px;

  --shadow-sm: 0 1px 2px rgba(35,42,39,.06);
  --shadow-md: 0 6px 24px rgba(35,42,39,.09);
  --shadow-lg: 0 20px 50px rgba(35,42,39,.14);

  --content-narrow: 680px;
  --content-default: 1000px;
  --content-wide: 1200px;

  --transition: 220ms cubic-bezier(0.16,1,0.3,1);

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Hanken Grotesk', 'Helvetica Neue', Arial, sans-serif;
}

[data-theme="dark"] {
  --color-bg: #11201d;
  --color-surface: #16302b;
  --color-surface-2: #1c3a34;
  --color-surface-offset: #173531;
  --color-border: #2c4b45;
  --color-divider: #234440;
  --color-text: #e8e3d6;
  --color-text-muted: #9fb0aa;
  --color-text-faint: #6e827c;
  --color-text-inverse: #0d2421;
  --color-primary: #7fc4b6;
  --color-primary-hover: #9ad4c8;
  --color-primary-deep: #cfeae3;
  --color-primary-soft: #1d3d38;
  --color-gold: #d8b164;
  --color-gold-soft: #2a382f;
  --color-wa: #2faa70;
  --color-wa-hover: #4cc189;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.3);
  --shadow-md: 0 6px 24px rgba(0,0,0,.4);
  --shadow-lg: 0 20px 50px rgba(0,0,0,.5);
}

/* ---------- Base ---------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html {
  -webkit-text-size-adjust:none; text-size-adjust:none;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility; scroll-behavior:smooth;
  scroll-padding-top:5rem;
}
body {
  min-height:100dvh; line-height:1.62;
  font-family:var(--font-body); font-size:var(--text-base);
  color:var(--color-text); background:var(--color-bg);
  overflow-x:hidden;
}
img,picture,svg,video { display:block; max-width:100%; height:auto; }
ul[role="list"] { list-style:none; }
input,button,textarea,select { font:inherit; color:inherit; }
h1,h2,h3,h4 { text-wrap:balance; line-height:1.12; font-family:var(--font-display); font-weight:500; }
p { text-wrap:pretty; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; background:none; border:none; }
::selection { background:rgba(13,91,84,.18); }
:focus-visible { outline:2px solid var(--color-primary); outline-offset:3px; border-radius:var(--radius-sm); }
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
}
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

a,button,[role="button"]{
  transition: color var(--transition), background var(--transition),
    border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--content-wide); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2.5rem); }
.narrow{ max-width:var(--content-narrow); }
.section{ padding-block:clamp(var(--space-16),9vw,var(--space-32)); }
.eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:var(--text-xs); font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--color-primary);
}
.eyebrow::before{ content:""; width:1.6rem; height:1px; background:var(--color-gold); }
.section-head{ max-width:46rem; margin-bottom:clamp(var(--space-8),5vw,var(--space-16)); }
.section-head h2{ font-size:var(--text-2xl); margin-top:var(--space-3); letter-spacing:-.01em; }
.section-head p{ color:var(--color-text-muted); margin-top:var(--space-4); font-size:var(--text-lg); }

/* ---------- Blog / SEO pages ---------- */
.blog-hero{ padding-block:clamp(var(--space-16),9vw,var(--space-24)); }
.blog-hero .wrap{ max-width:var(--content-default); }
.blog-hero h1{ font-size:var(--text-2xl); margin-top:var(--space-4); max-width:16ch; }
.blog-hero p{ margin-top:var(--space-5); color:var(--color-text-muted); max-width:62ch; font-size:var(--text-lg); }
.blog-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.blog-card{
  background:var(--color-surface-2); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); padding:var(--space-6); min-height:100%;
}
.blog-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--color-primary); }
.blog-card .meta{ color:var(--color-gold); font-size:var(--text-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.blog-card h2{ font-size:var(--text-xl); margin-top:var(--space-3); }
.blog-card p{ margin-top:var(--space-3); color:var(--color-text-muted); font-size:var(--text-sm); }
.article{ padding-block:clamp(var(--space-12),7vw,var(--space-20)); }
.article .wrap{ max-width:820px; }
.article h1{ font-size:var(--text-2xl); margin-top:var(--space-4); }
.article .article-meta{ color:var(--color-gold); font-size:var(--text-xs); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.article .lead{ margin-top:var(--space-5); color:var(--color-text-muted); font-size:var(--text-lg); }
.article-body{ margin-top:var(--space-10); }
.article-body h2{ font-size:var(--text-xl); margin-top:var(--space-10); }
.article-body p{ margin-top:var(--space-4); color:var(--color-text-muted); }
.article-body ul{ margin-top:var(--space-4); padding-left:1.2rem; color:var(--color-text-muted); }
.article-body li{ margin-top:.55rem; }
.article-cta{
  margin-top:var(--space-10); padding:var(--space-6); border-radius:var(--radius-lg);
  background:var(--color-primary); color:#fff; display:flex; gap:var(--space-5);
  justify-content:space-between; align-items:center; flex-wrap:wrap;
}
.article-cta p{ color:rgba(255,255,255,.82); margin-top:var(--space-2); }
.article-cta .btn{ background:#fff; color:var(--color-primary); }
.article-cta .btn:hover{ background:var(--color-gold-soft); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.85rem 1.5rem; border-radius:var(--radius-full);
  font-weight:600; font-size:var(--text-sm); line-height:1; letter-spacing:.01em;
  border:1.5px solid transparent; white-space:nowrap;
}
.btn svg{ width:1.15em; height:1.15em; flex:none; }
.btn-wa{ background:var(--color-wa); color:#fff; box-shadow:var(--shadow-sm); }
.btn-wa:hover{ background:var(--color-wa-hover); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-primary{ background:var(--color-primary); color:#fff; }
.btn-primary:hover{ background:var(--color-primary-hover); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-ghost{ border-color:var(--color-border); color:var(--color-text); background:var(--color-surface-2); }
.btn-ghost:hover{ border-color:var(--color-primary); color:var(--color-primary); }
.btn-lg{ padding:1.05rem 1.9rem; font-size:var(--text-base); }

/* ---------- Header ---------- */
.header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in oklab, var(--color-bg) 88%, transparent);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent; transition:border-color var(--transition), box-shadow var(--transition);
}
.header.scrolled{ border-color:var(--color-divider); box-shadow:var(--shadow-sm); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:4.6rem; gap:var(--space-4); }
.brand{ display:inline-flex; align-items:center; gap:.65rem; color:var(--color-text); }
.brand .logo{ width:2.3rem; height:2.3rem; color:var(--color-primary); flex:none; }
.brand-name{ display:flex; flex-direction:column; line-height:1; }
.brand-name strong{ font-family:var(--font-display); font-weight:600; font-size:1.18rem; letter-spacing:.01em; }
.brand-name span{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--color-text-muted); margin-top:.28rem; }
.nav-links{ display:flex; align-items:center; gap:var(--space-6); }
.nav-links a{ font-size:var(--text-sm); color:var(--color-text-muted); font-weight:500; }
.nav-links a:hover{ color:var(--color-primary); }
.nav-actions{ display:flex; align-items:center; gap:var(--space-3); }
.icon-btn{
  display:inline-grid; place-items:center; width:2.4rem; height:2.4rem;
  border-radius:var(--radius-full); border:1px solid var(--color-border);
  color:var(--color-text-muted); background:var(--color-surface-2);
}
.icon-btn:hover{ color:var(--color-primary); border-color:var(--color-primary); }
.lang-toggle{
  display:inline-flex; align-items:center; border:1px solid var(--color-border);
  border-radius:var(--radius-full); overflow:hidden; background:var(--color-surface-2);
}
.lang-toggle button{
  padding:.42rem .7rem; font-size:var(--text-xs); font-weight:700; letter-spacing:.06em;
  color:var(--color-text-faint);
}
.lang-toggle button.active{ background:var(--color-primary); color:#fff; }
.menu-btn{ display:none; }

/* Bilingual visibility */
[data-lang="tr"] .en{ display:none; }
[data-lang="en"] .tr{ display:none; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-block:clamp(var(--space-16),8vw,var(--space-24)); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.hero-copy .eyebrow{ margin-bottom:var(--space-5); }
.hero h1{ font-size:var(--text-3xl); letter-spacing:-.02em; font-weight:500; }
.hero h1 em{ font-style:italic; color:var(--color-primary); }
.hero-lede{ margin-top:var(--space-6); font-size:var(--text-lg); color:var(--color-text-muted); max-width:34rem; }
.hero-cta{ margin-top:var(--space-8); display:flex; flex-wrap:wrap; gap:var(--space-3); }
.hero-meta{ margin-top:var(--space-8); display:flex; flex-wrap:wrap; gap:var(--space-5) var(--space-8); }
.hero-meta div{ display:flex; align-items:center; gap:.55rem; font-size:var(--text-sm); color:var(--color-text-muted); }
.hero-meta svg{ width:1.15rem; height:1.15rem; color:var(--color-primary); flex:none; }
.hero-figure{ position:relative; }
.hero-figure img{ border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); width:100%; object-fit:cover; aspect-ratio:4/5; }
.hero-badge{
  position:absolute; left:-1.2rem; bottom:1.6rem; background:var(--color-surface-2);
  border:1px solid var(--color-border); border-radius:var(--radius-lg);
  padding:.9rem 1.1rem; box-shadow:var(--shadow-md); max-width:14rem;
}
.hero-badge strong{ display:block; font-family:var(--font-display); font-size:1.05rem; color:var(--color-primary); }
.hero-badge span{ font-size:var(--text-xs); color:var(--color-text-muted); }

/* ---------- Trust strip ---------- */
.trust{ background:var(--color-primary-deep); color:var(--color-text-inverse); }
[data-theme="dark"] .trust{ background:var(--color-surface-2); }
.trust .wrap{ padding-block:var(--space-10); }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-6); }
.trust-item{
  display:grid; grid-template-columns:auto 1fr; gap:.9rem; align-items:flex-start;
  min-width:0;
}
.trust-item svg{ width:1.6rem; height:1.6rem; color:var(--color-gold); flex:none; margin-top:.15rem; }
.trust-item div{ min-width:0; }
.trust-item strong{
  display:block; font-family:var(--font-body); font-weight:700; font-size:var(--text-sm);
  line-height:1.25; letter-spacing:.01em; color:#fff;
}
.trust-item p{
  margin-top:.35rem; font-size:var(--text-xs); line-height:1.45;
  color:rgba(255,255,255,.76); max-width:18rem;
}
[data-theme="dark"] .trust-item strong{ color:var(--color-text); }
[data-theme="dark"] .trust-item p{ color:var(--color-text-muted); }

/* ---------- Safety first ---------- */
.safety{ background:var(--color-surface); }
.safety-grid{ display:grid; grid-template-columns:.9fr 1.2fr; gap:var(--space-10); align-items:start; }
.safety h2{ font-size:var(--text-2xl); margin-top:var(--space-3); }
.safety p{ margin-top:var(--space-4); color:var(--color-text-muted); }
.safety-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4); }
.safety-card{
  background:var(--color-surface-2); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); padding:var(--space-5); min-height:100%;
}
.safety-card strong{
  display:inline-block; color:var(--color-gold); font-size:var(--text-xs);
  letter-spacing:.1em; text-transform:uppercase; margin-bottom:var(--space-3);
}
.safety-card h3{ font-size:var(--text-lg); font-family:var(--font-display); }
.safety-card p{ font-size:var(--text-sm); margin-top:var(--space-3); }

/* ---------- Treatments ---------- */
.treatments{ background:var(--color-bg); }
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.card{
  background:var(--color-surface-2); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); padding:var(--space-6); position:relative;
  display:flex; flex-direction:column; min-height:100%;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--color-primary); }
.card-ico{
  width:3rem; height:3rem; border-radius:var(--radius-md); display:grid; place-items:center;
  background:var(--color-primary-soft); color:var(--color-primary); margin-bottom:var(--space-4);
}
.card-ico svg{ width:1.5rem; height:1.5rem; }
.card h3{ font-size:var(--text-lg); font-family:var(--font-display); font-weight:600; }
.card p{ margin-top:var(--space-2); font-size:var(--text-sm); color:var(--color-text-muted); }
.card .tag{
  margin-top:var(--space-4); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--color-gold); font-weight:700;
}
.card.featured{ background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.card.featured .card-ico{ background:rgba(255,255,255,.14); color:#fff; }
.card.featured p{ color:rgba(255,255,255,.85); }
.card.featured .tag{ color:var(--color-gold-soft); color:#e7d3a8; }
.catalogue-note{
  margin-top:var(--space-8); padding:var(--space-6); border-radius:var(--radius-lg);
  background:var(--color-surface); border:1px dashed var(--color-border);
  display:flex; gap:var(--space-4); align-items:flex-start;
}
.catalogue-note svg{ width:1.6rem; height:1.6rem; color:var(--color-primary); flex:none; }
.catalogue-note p{ font-size:var(--text-sm); color:var(--color-text-muted); }

/* ---------- Who it's for ---------- */
.who{ background:var(--color-surface); }
.who-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-5); }
.who-item{ padding:var(--space-5); border-left:2px solid var(--color-gold); background:var(--color-surface-2); border-radius:0 var(--radius-md) var(--radius-md) 0; }
.who-item h3{ font-family:var(--font-body); font-weight:600; font-size:var(--text-base); }
.who-item p{ font-size:var(--text-sm); color:var(--color-text-muted); margin-top:var(--space-1); }

/* ---------- Why (split) ---------- */
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.why-list{ display:flex; flex-direction:column; gap:var(--space-6); margin-top:var(--space-6); }
.why-list li{ display:flex; gap:var(--space-4); }
.why-list .n{
  flex:none; width:2.5rem; height:2.5rem; border-radius:var(--radius-full);
  background:var(--color-primary-soft); color:var(--color-primary);
  display:grid; place-items:center; font-family:var(--font-display); font-weight:600; font-size:1.1rem;
}
.why-list h3{ font-family:var(--font-body); font-weight:600; font-size:var(--text-base); }
.why-list p{ font-size:var(--text-sm); color:var(--color-text-muted); margin-top:.15rem; }
.why-figure img{ border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); aspect-ratio:4/5; object-fit:cover; width:100%; }

/* ---------- Doctor / clinic ---------- */
.doctor{ background:var(--color-primary-deep); color:var(--color-text-inverse); }
[data-theme="dark"] .doctor{ background:var(--color-surface-2); }
.doctor-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.doctor-fig img{ border-radius:var(--radius-xl); aspect-ratio:1/1; object-fit:cover; box-shadow:var(--shadow-lg); }
.doctor h2{ font-size:var(--text-2xl); color:#fff; }
.doctor .eyebrow{ color:var(--color-gold); }
.doctor .eyebrow::before{ background:var(--color-gold); }
.doctor p{ color:rgba(255,255,255,.82); margin-top:var(--space-4); }
[data-theme="dark"] .doctor p{ color:var(--color-text-muted); }
.doctor .name{ font-family:var(--font-display); font-size:var(--text-lg); color:#fff; font-weight:600; margin-top:var(--space-6); }
.doctor .role{ font-size:var(--text-sm); color:var(--color-gold); }
[data-theme="dark"] .doctor h2,[data-theme="dark"] .doctor .name{ color:var(--color-text); }

/* ---------- Booking 3-step ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-6); counter-reset:step; }
.step{ position:relative; padding-top:var(--space-6); }
.step .num{
  font-family:var(--font-display); font-size:2.4rem; color:var(--color-gold); font-weight:600; line-height:1;
}
.step h3{ font-family:var(--font-body); font-weight:600; font-size:var(--text-base); margin-top:var(--space-3); }
.step p{ font-size:var(--text-sm); color:var(--color-text-muted); margin-top:var(--space-2); }
.step::after{
  content:""; position:absolute; top:.7rem; left:2.8rem; right:-.8rem; height:1px;
  background:linear-gradient(90deg,var(--color-border),transparent);
}
.step:last-child::after{ display:none; }
.booking-cta{ margin-top:var(--space-12); text-align:center; }

/* ---------- Offer band ---------- */
.offer{ background:var(--color-bg); }
.offer-card{
  background:linear-gradient(135deg,var(--color-primary),var(--color-primary-deep));
  color:#fff; border-radius:var(--radius-xl); padding:clamp(2rem,5vw,3.5rem);
  display:grid; grid-template-columns:1.4fr 1fr; gap:var(--space-8); align-items:center;
  position:relative; overflow:hidden;
}
.offer-card::before{
  content:""; position:absolute; inset:0; opacity:.14;
  background:radial-gradient(circle at 85% 20%, var(--color-gold), transparent 55%);
}
.offer-card > *{ position:relative; }
.offer-card .eyebrow{ color:#e7d3a8; }
.offer-card .eyebrow::before{ background:#e7d3a8; }
.offer-card h2{ color:#fff; font-size:var(--text-xl); margin-top:var(--space-3); }
.offer-card p{ color:rgba(255,255,255,.85); margin-top:var(--space-3); font-size:var(--text-sm); }
.offer-card .price-note{ font-size:var(--text-xs); color:rgba(255,255,255,.6); margin-top:var(--space-4); }
.offer-actions{ display:flex; flex-direction:column; gap:var(--space-3); }
.offer-actions .btn-wa{ background:#fff; color:var(--color-primary); }
.offer-actions .btn-wa:hover{ background:#f0ece2; }

/* ---------- FAQ ---------- */
.faq{ background:var(--color-surface); }
.faq-list{ max-width:var(--content-narrow); margin-inline:auto; }
.faq-item{ border-bottom:1px solid var(--color-divider); }
.faq-q{
  width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:var(--space-4);
  padding:var(--space-5) 0; font-weight:600; font-size:var(--text-base); color:var(--color-text); font-family:var(--font-body);
}
.faq-q svg{ width:1.2rem; height:1.2rem; flex:none; color:var(--color-primary); transition:transform var(--transition); }
.faq-item[open] .faq-q svg{ transform:rotate(45deg); }
.faq-a{ padding:0 0 var(--space-5); color:var(--color-text-muted); font-size:var(--text-sm); max-width:60ch; }
details > summary{ list-style:none; } details > summary::-webkit-details-marker{ display:none; }

/* ---------- Location / contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); }
.contact-info .row{ display:flex; gap:var(--space-4); padding:var(--space-5) 0; border-bottom:1px solid var(--color-divider); }
.contact-info .row svg{ width:1.4rem; height:1.4rem; color:var(--color-primary); flex:none; margin-top:.2rem; }
.contact-info .row strong{ display:block; font-family:var(--font-body); font-weight:600; font-size:var(--text-base); }
.contact-info .row p{ font-size:var(--text-sm); color:var(--color-text-muted); margin-top:.1rem; }
.contact-info .row .soon{ display:inline-block; margin-top:.3rem; font-size:.66rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--color-gold); }
.map-card{
  background:var(--color-surface-2); border:1px solid var(--color-border); border-radius:var(--radius-lg);
  padding:var(--space-6); display:flex; flex-direction:column;
}
.map-area{ aspect-ratio:16/11; border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--color-border); }
.map-area iframe{ width:100%; height:100%; border:0; filter:grayscale(.2) contrast(1.02); }
.map-card .btn{ margin-top:var(--space-5); width:100%; }

/* ---------- Disclaimer ---------- */
.disclaimer{ background:var(--color-surface-offset); }
.disclaimer .wrap{ max-width:var(--content-default); }
.disclaimer-box{ display:flex; gap:var(--space-4); }
.disclaimer-box svg{ width:1.6rem; height:1.6rem; color:var(--color-gold); flex:none; }
.disclaimer h2{ font-size:var(--text-lg); font-family:var(--font-body); font-weight:700; }
.disclaimer p{ font-size:var(--text-sm); color:var(--color-text-muted); margin-top:var(--space-3); }
.disclaimer p + p{ margin-top:var(--space-2); }

/* ---------- Footer ---------- */
.footer{ background:var(--color-primary-deep); color:rgba(246,241,233,.7); }
[data-theme="dark"] .footer{ background:#0c1c19; }
.footer .wrap{ padding-block:var(--space-16) var(--space-8); }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:var(--space-8); padding-bottom:var(--space-10); border-bottom:1px solid rgba(255,255,255,.12); }
.footer .brand{ color:#fff; }
.footer .brand .logo{ color:var(--color-gold); }
.footer .brand-name span{ color:rgba(246,241,233,.6); }
.footer-col h4{ font-family:var(--font-body); font-weight:600; color:#fff; font-size:var(--text-sm); margin-bottom:var(--space-4); }
.footer-col a{ display:block; font-size:var(--text-sm); padding:.25rem 0; color:rgba(246,241,233,.7); }
.footer-col a:hover{ color:var(--color-gold); }
.footer-blurb{ font-size:var(--text-sm); margin-top:var(--space-4); max-width:32ch; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:var(--space-3); padding-top:var(--space-6); font-size:var(--text-xs); }

/* ---------- Floating WhatsApp ---------- */
.fab{
  position:fixed; right:1.1rem; bottom:1.1rem; z-index:70;
  display:inline-flex; align-items:center; gap:.55rem; padding:.85rem 1.2rem;
  background:var(--color-wa); color:#fff; border-radius:var(--radius-full);
  box-shadow:var(--shadow-lg); font-weight:600; font-size:var(--text-sm);
}
.fab:hover{ background:var(--color-wa-hover); transform:translateY(-2px); }
.fab svg{ width:1.4rem; height:1.4rem; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s cubic-bezier(0.16,1,0.3,1); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-figure{ order:-1; max-width:30rem; }
  .why-grid,.doctor-grid,.contact-grid,.offer-card,.safety-grid{ grid-template-columns:1fr; }
  .doctor-fig{ max-width:24rem; }
  .why-figure{ max-width:30rem; }
  .trust-grid{ grid-template-columns:repeat(2,1fr); gap:var(--space-6); }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .safety-cards{ grid-template-columns:1fr; }
  .blog-list{ grid-template-columns:repeat(2,1fr); }
  .who-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 680px){
  .nav-links{ display:none; }
  .nav-links.open{
    display:flex; position:absolute; top:4.6rem; left:0; right:0; flex-direction:column; align-items:flex-start;
    background:var(--color-surface-2); border-bottom:1px solid var(--color-border); padding:var(--space-5);
    gap:var(--space-4); box-shadow:var(--shadow-md);
  }
  .menu-btn{ display:inline-grid; }
  .cards,.who-grid,.steps,.trust-grid,.blog-list{ grid-template-columns:1fr; }
  .step::after{ display:none; }
  .footer-top{ grid-template-columns:1fr; }
  .hero-badge{ left:0; }
  .fab span{ display:none; }
  .fab{ padding:.95rem; }
}
