/*
Theme Name: Curls & Crowns
Theme URI: https://curlsandcrowns.in/
Author: Dr. Prashant Raktade
Author URI: https://curlsandcrowns.in/
Description: Ultra-modern, conversion-focused single-page theme for Curls & Crowns Aesthetics Studio — premium hair transplant clinic by Dr. Prashant Raktade in Chhatrapati Sambhajinagar (Aurangabad), Marathwada. Apple/Tesla-inspired UI with glassmorphism, before/after slider, filterable gallery, graft calculator, and AI hairline preview concept. Mobile-first, dark-mode adaptive, schema.org Physician + MedicalClinic markup.
Version: 1.3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: curls-and-crowns
Tags: medical, single-page, custom-colors, custom-logo, full-width-template, sticky-post, footer-widgets, threaded-comments
*/

:root{
  --bg:#fafbfc;
  --bg-2:#f4f7fb;
  --ink:#0a0e14;
  --ink-2:#1f2937;
  --muted:#6b7280;
  --line:rgba(10,14,20,0.08);
  --primary:#0b2447;
  --primary-2:#143864;
  --accent:#2c8d8d;
  --accent-2:#5cb8b2;
  --gold:#c4a96e;
  --glass:rgba(255,255,255,0.65);
  --glass-strong:rgba(255,255,255,0.85);
  --shadow-sm:0 2px 8px rgba(11,36,71,0.06);
  --shadow-md:0 12px 40px rgba(11,36,71,0.10);
  --shadow-lg:0 30px 80px rgba(11,36,71,0.16);
  --radius:18px;
  --radius-lg:28px;
  --grad-soft:linear-gradient(135deg,#eaf4fb 0%,#ffffff 45%,#e9f7f5 100%);
  --grad-cinema:linear-gradient(180deg, rgba(7,15,28,0.05) 0%, rgba(7,15,28,0.55) 60%, rgba(7,15,28,0.85) 100%);
  --grad-button:linear-gradient(135deg,#0b2447 0%,#143864 60%,#2c8d8d 100%);
  --grad-gold:linear-gradient(135deg,#c4a96e,#e9d8a6);
}

@media (prefers-color-scheme: dark){
  :root{
    --bg:#070a10;
    --bg-2:#0d1320;
    --ink:#f3f5f8;
    --ink-2:#cbd2dc;
    --muted:#8b94a4;
    --line:rgba(255,255,255,0.08);
    --glass:rgba(20,26,40,0.55);
    --glass-strong:rgba(20,26,40,0.78);
    --shadow-sm:0 2px 10px rgba(0,0,0,0.4);
    --shadow-md:0 12px 40px rgba(0,0,0,0.45);
    --shadow-lg:0 30px 80px rgba(0,0,0,0.55);
    --grad-soft:linear-gradient(135deg,#0b1320 0%,#070a10 50%,#0a161c 100%);
  }
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* NAV */
.nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  z-index:100;width:min(1180px,calc(100% - 28px));
  background:var(--glass);backdrop-filter:saturate(180%) blur(22px);
  -webkit-backdrop-filter:saturate(180%) blur(22px);
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 16px 10px 18px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  box-shadow:var(--shadow-sm);
  transition:all .35s cubic-bezier(.2,.7,.2,1);
}
.nav.scrolled{background:var(--glass-strong);box-shadow:var(--shadow-md)}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em}
.nav-logo img{height:80px;width:auto;display:block}
.nav-logo .nl-name{font-size:15px;line-height:1.1}
.nav-logo .nl-sub{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.06em;text-transform:uppercase}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{padding:9px 14px;font-size:14px;font-weight:500;color:var(--ink-2);border-radius:999px;transition:.2s}
.nav-links a:hover{background:rgba(11,36,71,0.06);color:var(--ink)}
.nav-cta{
  background:var(--grad-button);color:#fff;padding:11px 20px;border-radius:999px;
  font-size:14px;font-weight:600;letter-spacing:.01em;
  box-shadow:0 8px 22px rgba(11,36,71,0.25);
  transition:transform .2s, box-shadow .25s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(11,36,71,0.35)}
.nav-burger{display:none;background:none;border:0;color:var(--ink);padding:8px;cursor:pointer}

@media (max-width: 880px){
  .nav-links{display:none}
  .nav-burger{display:inline-flex}
  .nav{padding:6px 10px 6px 12px}
  .nav-logo img{height:56px}
  .nav-logo .nl-sub{display:none}
}

/* HERO */
.hero{
  position:relative;min-height:100vh;
  background:#070a10;
  color:#fff;overflow:hidden;
  display:flex;align-items:center;
  padding:140px 0 120px;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center 28%;
  filter:saturate(1.05) contrast(1.04);
  transform:scale(1.04);
  animation: heroZoom 14s ease-out forwards;
}
@keyframes heroZoom { from{transform:scale(1.12)} to{transform:scale(1.0)} }
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(7,10,16,0.10) 0%, rgba(7,10,16,0.55) 55%, rgba(7,10,16,0.92) 100%),
    radial-gradient(900px 500px at 80% 20%, rgba(44,141,141,0.18), transparent 60%);
}
.hero-grid{
  position:absolute;inset:0;opacity:.18;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 75%);
}
.hero-content{position:relative;z-index:2;max-width:920px}
.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.18);
  font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  color:#e8eef7;margin-bottom:24px;
}
.hero-pill .dot{width:7px;height:7px;border-radius:50%;background:#5cb8b2;box-shadow:0 0 12px #5cb8b2}
.hero h1{
  font-family:'Fraunces','Inter',serif;
  font-size:clamp(40px,6.4vw,84px);
  line-height:1.02;letter-spacing:-0.025em;
  margin:0 0 22px;font-weight:500;
  color:#fff;
}
.hero h1 .accent{
  background:linear-gradient(120deg,#7ad9d3,#c4a96e 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;font-weight:400;
}
.hero p.lede{
  font-size:clamp(16px,1.6vw,20px);line-height:1.55;
  color:#dbe2ec;max-width:600px;margin:0 0 36px;
  font-weight:400;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:999px;font-weight:600;font-size:15px;
  cursor:pointer;border:0;transition:transform .2s, box-shadow .25s, background .25s;
  letter-spacing:.005em;
}
.btn-primary{
  background:linear-gradient(135deg,#fff 0%,#e8eef7 100%);
  color:#0b2447;box-shadow:0 14px 40px rgba(255,255,255,0.18);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 60px rgba(255,255,255,0.32)}
.btn-ghost{
  background:rgba(255,255,255,0.06);color:#fff;
  border:1px solid rgba(255,255,255,0.22);backdrop-filter:blur(8px);
}
.btn-ghost:hover{background:rgba(255,255,255,0.12);transform:translateY(-2px)}
.btn-arrow{transition:transform .25s}
.btn:hover .btn-arrow{transform:translateX(3px)}
.hero-stats{
  display:flex;gap:36px;margin-top:60px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,0.12);padding-top:28px;
}
.hero-stat{display:flex;flex-direction:column}
.hero-stat .num{font-family:'Fraunces',serif;font-size:38px;font-weight:500;letter-spacing:-.02em;color:#fff}
.hero-stat .label{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:#9aa6b6;margin-top:4px}

.hero-marquee{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  background:rgba(255,255,255,0.04);backdrop-filter:blur(14px);
  border-top:1px solid rgba(255,255,255,0.08);
  padding:16px 0;overflow:hidden;
}
.hero-marquee-track{display:flex;gap:48px;animation:marquee 28s linear infinite;white-space:nowrap}
.hero-marquee-track span{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#a8b2c4;font-weight:500;display:flex;align-items:center;gap:48px}
.hero-marquee-track span::after{content:"\25CF";color:#2c8d8d;margin-left:48px}
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* SECTIONS */
.section{padding:120px 0;position:relative}
.section-soft{background:var(--grad-soft)}
.eyebrow{
  font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:14px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
h2.section-title{
  font-family:'Fraunces',serif;
  font-size:clamp(32px,4.4vw,56px);font-weight:500;letter-spacing:-.02em;line-height:1.05;
  margin:0 0 18px;color:var(--ink);
}
h2.section-title em{font-style:italic;font-weight:400;background:linear-gradient(120deg,var(--accent),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.section-lede{font-size:18px;color:var(--muted);max-width:680px;margin:0 0 56px}

/* BEFORE / AFTER */
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.ba-stage{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio: 4 / 3;
  box-shadow:var(--shadow-lg);
  user-select:none;cursor:ew-resize;
  background:#000;
}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-img-after{clip-path:inset(0 0 0 50%);transition:clip-path .05s linear}
.ba-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 22px rgba(255,255,255,0.6);transform:translateX(-1px);pointer-events:none}
.ba-handle{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,0.95);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 40px rgba(0,0,0,0.4);
  pointer-events:none;
}
.ba-handle svg{width:24px;height:24px;color:#0b2447}
.ba-tag{
  position:absolute;top:18px;
  padding:8px 14px;border-radius:999px;
  background:rgba(7,10,16,0.6);backdrop-filter:blur(10px);
  color:#fff;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,0.18);pointer-events:none;
}
.ba-tag.before{left:18px}
.ba-tag.after{right:18px;background:rgba(44,141,141,0.85);}
.ba-meta{
  position:absolute;left:18px;right:18px;bottom:18px;
  display:flex;justify-content:space-between;align-items:flex-end;
  color:#fff;font-size:13px;pointer-events:none;
}
.ba-meta .ba-grafts{
  background:rgba(7,10,16,0.65);padding:10px 14px;border-radius:14px;backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.15);
}
.ba-meta .ba-grafts strong{display:block;font-family:'Fraunces',serif;font-size:22px;letter-spacing:-.01em;font-weight:500}
.ba-meta .ba-grafts span{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#cdd6e2}
.ba-thumbs{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.ba-thumb{
  width:84px;height:62px;border-radius:12px;overflow:hidden;
  border:2px solid transparent;cursor:pointer;transition:.2s;
  position:relative;background:#000;
}
.ba-thumb img{width:100%;height:100%;object-fit:cover;opacity:.7;transition:.2s}
.ba-thumb.active{border-color:var(--accent);box-shadow:0 6px 20px rgba(44,141,141,0.4)}
.ba-thumb.active img,.ba-thumb:hover img{opacity:1}

.ba-info h2.section-title{margin-bottom:20px}
.ba-info .ba-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px}
.ba-info .ba-stat{padding:22px;background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);backdrop-filter:blur(20px)}
.ba-info .ba-stat .num{font-family:'Fraunces',serif;font-size:34px;font-weight:500;letter-spacing:-.02em;color:var(--primary);line-height:1}
.ba-info .ba-stat .lbl{font-size:13px;color:var(--muted);margin-top:6px;letter-spacing:.04em}

@media (max-width: 900px){
  .ba-wrap{grid-template-columns:1fr}
  .section{padding:80px 0}
}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:0.95fr 1.15fr;gap:80px;align-items:center}
.about-photo{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio: 4/5;box-shadow:var(--shadow-lg);
}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo .photo-tag{
  position:absolute;left:24px;bottom:24px;
  padding:14px 18px;border-radius:18px;
  background:var(--glass-strong);backdrop-filter:blur(22px);
  border:1px solid var(--line);
  display:flex;flex-direction:column;
}
.about-photo .photo-tag .pt-name{font-weight:700;font-size:15px;color:var(--ink)}
.about-photo .photo-tag .pt-cred{font-size:12px;color:var(--muted);letter-spacing:.04em}
.about-photo .photo-frame{
  position:absolute;inset:-1px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(196,169,110,0.5),transparent 60%);
  pointer-events:none;
}
.timeline{margin-top:32px;border-left:2px solid var(--line);padding-left:24px;position:relative}
.tl-item{padding:14px 0;position:relative}
.tl-item::before{content:"";position:absolute;left:-31px;top:22px;width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--bg)}
.tl-year{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.tl-role{font-weight:600;color:var(--ink);margin-top:2px}
.tl-place{font-size:14px;color:var(--muted)}
.about-cred-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}
.cred-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:999px;
  background:var(--glass);border:1px solid var(--line);backdrop-filter:blur(14px);
  font-size:13px;font-weight:500;color:var(--ink-2);
}
.cred-pill svg{width:14px;height:14px;color:var(--accent)}

@media (max-width: 900px){
  .about-grid{grid-template-columns:1fr;gap:48px}
}

/* TECHNIQUE */
.tech-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px;margin-bottom:56px}
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tech-card{
  position:relative;padding:36px 32px 32px;border-radius:var(--radius-lg);
  background:var(--glass);backdrop-filter:blur(22px);
  border:1px solid var(--line);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
  overflow:hidden;
}
.tech-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(44,141,141,0.05),transparent 60%);
  opacity:0;transition:.4s;
}
.tech-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.tech-card:hover::before{opacity:1}
.tech-icon{
  width:56px;height:56px;border-radius:18px;
  background:linear-gradient(135deg,#e8f7f5,#d6efef);
  display:flex;align-items:center;justify-content:center;color:var(--accent);
  margin-bottom:24px;
}
.tech-icon svg{width:26px;height:26px}
.tech-card h3{font-family:'Fraunces',serif;font-size:24px;font-weight:500;letter-spacing:-.01em;margin:0 0 10px;color:var(--ink)}
.tech-card p{font-size:15px;color:var(--muted);margin:0;line-height:1.6}
.tech-card .tech-num{position:absolute;right:24px;top:24px;font-family:'Fraunces',serif;font-size:14px;color:var(--accent);font-weight:600;letter-spacing:.08em}
@media (max-width: 880px){.tech-grid{grid-template-columns:1fr}}

/* GALLERY */
.gal-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.gal-filter{
  padding:10px 18px;border-radius:999px;border:1px solid var(--line);
  background:var(--glass);font-size:13.5px;font-weight:500;color:var(--ink-2);
  cursor:pointer;transition:.25s;backdrop-filter:blur(12px);
}
.gal-filter:hover{border-color:var(--accent);color:var(--accent)}
.gal-filter.active{background:var(--ink);color:#fff;border-color:var(--ink)}
@media (prefers-color-scheme: dark){
  .gal-filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}
}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio: 4/3;cursor:pointer;
  background:#000;
}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.gal-card:hover img{transform:scale(1.06)}
.gal-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(7,10,16,0.85));
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;
  color:#fff;opacity:0;transition:.35s;
}
.gal-card:hover .gal-overlay{opacity:1}
.gal-overlay h4{margin:0;font-family:'Fraunces',serif;font-size:20px;font-weight:500}
.gal-overlay span{font-size:12.5px;color:#bcc6d4;margin-top:4px;letter-spacing:.04em}
.gal-overlay .gal-tags{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.gal-overlay .gal-tags small{padding:4px 9px;background:rgba(255,255,255,0.12);border-radius:999px;font-size:11px;letter-spacing:.05em;border:1px solid rgba(255,255,255,0.18)}
@media (max-width: 880px){.gal-grid{grid-template-columns:1fr 1fr}}
@media (max-width: 580px){.gal-grid{grid-template-columns:1fr}}

/* CALCULATOR */
.calc-wrap{
  display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center;
  background:var(--glass-strong);backdrop-filter:blur(22px);
  border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:60px;box-shadow:var(--shadow-md);
}
.calc-form{display:flex;flex-direction:column;gap:20px}
.calc-field label{display:block;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--muted);margin-bottom:8px}
.calc-field select,.calc-field input{
  width:100%;padding:14px 16px;border-radius:14px;
  border:1px solid var(--line);background:var(--bg);
  font-size:15px;color:var(--ink);font-family:inherit;
  transition:.2s;
}
.calc-field select:focus,.calc-field input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px rgba(44,141,141,0.15)}
.calc-output{
  border-radius:var(--radius);padding:30px;
  background:linear-gradient(135deg,#0b2447,#143864);
  color:#fff;position:relative;overflow:hidden;
}
.calc-output::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px 200px at 80% 20%, rgba(44,141,141,0.35), transparent 60%);
}
.calc-output > *{position:relative}
.calc-output .lbl{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:#a8b8cc}
.calc-output .grafts{font-family:'Fraunces',serif;font-size:54px;font-weight:500;letter-spacing:-.025em;line-height:1;margin:8px 0 4px}
.calc-output .grafts small{font-size:18px;color:#a8b8cc;font-family:'Inter',sans-serif;font-weight:500;margin-left:8px}
.calc-output .price{font-size:14.5px;color:#cdd9ea;margin-top:18px;line-height:1.6}
.calc-output .price strong{color:#fff;font-weight:600}
.calc-output .calc-cta{margin-top:20px;display:inline-flex}
@media (max-width: 880px){.calc-wrap{grid-template-columns:1fr;padding:32px;gap:32px}}

/* AI HAIRLINE */
.ai-wrap{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:#070a10;color:#fff;
  display:grid;grid-template-columns:1.2fr 1fr;min-height:520px;
}
.ai-text{padding:64px 56px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2}
.ai-text .eyebrow{color:var(--accent-2)}
.ai-text .eyebrow::before{background:var(--accent-2)}
.ai-text h2{font-family:'Fraunces',serif;font-size:clamp(28px,3.4vw,46px);font-weight:500;letter-spacing:-.02em;margin:0 0 16px;line-height:1.05}
.ai-text p{color:#bcc6d4;max-width:480px;margin:0 0 24px}
.ai-badge{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.18);
  font-size:12px;color:#fff;letter-spacing:.06em;text-transform:uppercase;font-weight:600;width:fit-content;
  margin-bottom:18px;
}
.ai-badge .pulse{width:8px;height:8px;border-radius:50%;background:#7ad9d3;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
.ai-img{position:relative;overflow:hidden}
.ai-img img{width:100%;height:100%;object-fit:cover;opacity:.85}
.ai-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,#070a10 0%,transparent 30%,transparent 70%,rgba(7,10,16,0.5));
}
.ai-scan{
  position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#7ad9d3,transparent);
  top:0;animation: scan 3.4s ease-in-out infinite;z-index:3;
}
@keyframes scan{0%,100%{top:0;opacity:0}10%{opacity:1}50%{top:100%;opacity:1}90%{opacity:0}}
@media (max-width: 880px){.ai-wrap{grid-template-columns:1fr}.ai-text{padding:40px 28px}.ai-img{min-height:280px}}

/* TESTIMONIALS */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.test-card{
  padding:34px 30px;border-radius:var(--radius-lg);
  background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid var(--line);transition:.35s;
  display:flex;flex-direction:column;
  position:relative;
}
.test-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.test-quote{font-size:16.5px;line-height:1.65;color:var(--ink-2);margin:0 0 24px;font-style:italic}
.test-quote::before{content:"\201C";font-family:'Fraunces',serif;font-size:54px;color:var(--accent);line-height:0;margin-right:6px;vertical-align:-12px}
.test-author{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.test-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--gold));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}
.test-name{font-weight:600;color:var(--ink);font-size:14.5px}
.test-loc{font-size:12.5px;color:var(--muted);letter-spacing:.04em}
.test-stars{display:flex;gap:2px;margin-bottom:14px;color:var(--gold)}
.test-stars svg{width:14px;height:14px}
@media (max-width: 880px){.test-grid{grid-template-columns:1fr}}

/* LOCATION */
.loc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:stretch}
.loc-info{display:flex;flex-direction:column;justify-content:center}
.loc-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.loc-card{
  padding:22px;border-radius:var(--radius);background:var(--glass);
  border:1px solid var(--line);backdrop-filter:blur(18px);
}
.loc-card .lc-icon{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#e8f7f5,#d6efef);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:14px}
.loc-card .lc-icon svg{width:18px;height:18px}
.loc-card .lc-title{font-weight:600;font-size:14px;color:var(--ink);margin-bottom:4px}
.loc-card .lc-detail{font-size:13.5px;color:var(--muted);line-height:1.5}
.loc-map{
  border-radius:var(--radius-lg);overflow:hidden;min-height:480px;
  box-shadow:var(--shadow-md);border:1px solid var(--line);position:relative;
}
.loc-map iframe{width:100%;height:100%;min-height:480px;border:0;display:block}
.loc-served{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.loc-served .lc-pill{padding:8px 14px;border-radius:999px;background:var(--bg-2);font-size:12.5px;color:var(--ink-2);border:1px solid var(--line)}
@media (max-width: 900px){.loc-wrap{grid-template-columns:1fr}.loc-cards{grid-template-columns:1fr 1fr}}

/* CTA BAND */
.cta-band{
  margin:0 28px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#0b2447 0%,#143864 50%,#1f5f5f 100%);
  color:#fff;padding:80px 60px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
  box-shadow:var(--shadow-lg);
}
.cta-band::before{
  content:"";position:absolute;right:-100px;bottom:-100px;width:400px;height:400px;
  background:radial-gradient(circle,rgba(196,169,110,0.32),transparent 60%);
}
.cta-band h2{font-family:'Fraunces',serif;font-size:clamp(28px,3.6vw,46px);font-weight:500;letter-spacing:-.02em;margin:0 0 8px;max-width:560px;line-height:1.05}
.cta-band p{color:#cdd9ea;margin:0;max-width:460px}
.cta-band-actions{display:flex;gap:14px;flex-wrap:wrap;position:relative;z-index:2}
.cta-band-actions .btn-primary{background:#fff;color:#0b2447}
.cta-band-actions .btn-ghost{border-color:rgba(255,255,255,0.4)}

/* FOOTER */
.foot{padding:80px 0 32px;background:var(--bg-2);border-top:1px solid var(--line);margin-top:80px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.foot-brand{display:flex;flex-direction:column;gap:18px;max-width:340px}
.foot-brand .fb-logo{display:flex;align-items:center;gap:12px}
.foot-brand .fb-logo img{height:64px;border-radius:12px}
.foot-brand .fb-logo strong{font-family:'Fraunces',serif;font-size:20px;letter-spacing:-.01em;font-weight:500}
.foot-brand p{font-size:14px;color:var(--muted);line-height:1.6;margin:0}
.foot-col h5{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin:0 0 18px;font-weight:700}
.foot-col a{display:block;font-size:14px;color:var(--muted);padding:5px 0;transition:.2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{margin-top:60px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--muted)}
@media (max-width: 880px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .foot-brand{grid-column:1/-1}
  .cta-band{padding:48px 32px;margin:0 14px}
}

/* STICKY */
.sticky-cta{position:fixed;right:22px;bottom:22px;z-index:90;display:flex;flex-direction:column;gap:12px}
.sticky-btn{
  width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;border:0;color:#fff;
  box-shadow:0 14px 40px rgba(0,0,0,0.25);
  transition:transform .25s, box-shadow .25s;
  position:relative;
}
.sticky-btn:hover{transform:translateY(-3px);box-shadow:0 20px 60px rgba(0,0,0,0.35)}
.sticky-btn.wa{background:#25D366}
.sticky-btn.book{background:var(--grad-button)}
.sticky-btn svg{width:26px;height:26px}
.sticky-btn .pulse-ring{
  position:absolute;inset:-6px;border-radius:50%;border:2px solid currentColor;opacity:0;
  animation:pulseRing 2.2s ease-out infinite;
}
@keyframes pulseRing{0%{opacity:.6;transform:scale(.9)}100%{opacity:0;transform:scale(1.4)}}

/* REVEAL */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:translateY(0)}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}

/* MOBILE MENU */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--glass-strong);backdrop-filter:blur(28px);
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  opacity:0;pointer-events:none;transition:.4s;
}
.mobile-menu.open{display:flex;opacity:1;pointer-events:auto}
.mobile-menu a{font-family:'Fraunces',serif;font-size:32px;font-weight:500;color:var(--ink)}
.mobile-menu .close{position:absolute;top:24px;right:24px;background:none;border:0;color:var(--ink);font-size:34px;cursor:pointer;line-height:1}

:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}
::selection{background:rgba(44,141,141,0.25);color:var(--ink)}

/* WP admin bar fix */
body.admin-bar .nav{top:calc(18px + 32px)}
@media (max-width:782px){body.admin-bar .nav{