/* ─── FULL CIRCLE FUNCTION — SHARED STYLES ─── */
:root {
  --cream: #faf7f2;
  --warm-white: #fff9f4;
  --navy: #1a1a2e;
  --purple: #6b3fa0;
  --magenta: #c2185b;
  --teal: #0097a7;
  --gold: #e6a817;
  --text-dark: #1a1820;
  --text-mid: #3d3a4a;
  --text-light: #6e6a7c;
  --border: rgba(107,63,160,0.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--text-dark);overflow-x:hidden;line-height:1.6}
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;line-height:1.15;font-weight:600}
h1{font-size:clamp(2.2rem,4vw,3.4rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}
h3{font-size:clamp(1.3rem,2vw,1.8rem)}
h4{font-size:1.15rem}
p{line-height:1.75}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ─── TOP BANNER ─── */
#top-banner{position:sticky;top:0;z-index:1000;padding:10px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,var(--navy) 0%,#2d1b5e 30%,#1a3a4a 60%,var(--navy) 100%);background-size:200% 200%;animation:bannerGrad 6s ease infinite}
@keyframes bannerGrad{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.banner-left{display:flex;align-items:center;gap:10px;color:#fff;font-size:.85rem;font-weight:500}
.pulse-dot{width:9px;height:9px;border-radius:50%;background:#4ade80;flex-shrink:0;animation:pulse 2s ease infinite;box-shadow:0 0 0 0 rgba(74,222,128,.6)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,222,128,.6)}70%{box-shadow:0 0 0 8px rgba(74,222,128,0)}100%{box-shadow:0 0 0 0 rgba(74,222,128,0)}}
.banner-ctas{display:flex;gap:10px;align-items:center}
.btn-call{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:50px;background:linear-gradient(135deg,var(--magenta),var(--purple));color:#fff;font-weight:600;font-size:.88rem;transition:transform .2s,box-shadow .2s;white-space:nowrap}
.btn-call:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(194,24,91,.4)}
.btn-book{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:50px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;font-weight:500;font-size:.88rem;transition:background .2s,transform .2s;white-space:nowrap}
.btn-book:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}

/* ─── MAIN NAV ─── */
#main-nav{position:sticky;top:49px;z-index:999;background:rgba(250,247,242,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s;padding:0 32px}
#main-nav.scrolled{box-shadow:0 4px 30px rgba(26,26,46,.1)}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.nav-logo-text{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.05rem;color:var(--navy);line-height:1.2}
.nav-logo-text span{display:block;font-family:'DM Sans',sans-serif;font-size:.63rem;font-weight:500;color:var(--text-light);letter-spacing:.08em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--text-mid);position:relative;padding-bottom:2px;transition:color .2s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:linear-gradient(90deg,var(--purple),var(--magenta));transition:width .3s}
.nav-links a:hover,.nav-links a.nav-active{color:var(--navy)}
.nav-links a:hover::after,.nav-links a.nav-active::after{width:100%}
.nav-phone{font-size:.85rem;font-weight:600;color:var(--purple);white-space:nowrap;transition:color .2s}
.nav-phone:hover{color:var(--magenta)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.hamburger span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(26,26,46,.5);z-index:998;opacity:0;transition:opacity .3s}
.mobile-overlay.active{display:block;opacity:1}
.mobile-menu{position:fixed;top:0;right:-100%;width:min(320px,85vw);height:100vh;background:var(--warm-white);z-index:999;padding:80px 32px 40px;display:flex;flex-direction:column;gap:8px;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 40px rgba(26,26,46,.15)}
.mobile-menu.open{right:0}
.mobile-menu a{font-size:1.1rem;font-weight:500;color:var(--text-dark);padding:12px 0;border-bottom:1px solid var(--border);transition:color .2s,padding-left .2s}
.mobile-menu a:hover{color:var(--purple);padding-left:8px}
.mobile-menu-cta{margin-top:24px!important;padding:14px 24px!important;border-radius:50px!important;text-align:center;background:linear-gradient(135deg,var(--purple),var(--magenta))!important;color:#fff!important;font-weight:600!important;border:none!important}

/* ─── PAGE HERO (inner pages) ─── */
.page-hero{
  padding:80px 40px 72px;
  background:var(--warm-white);
  position:relative;overflow:hidden;
}
.page-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(107,63,160,.08),transparent 60%);pointer-events:none}
.page-hero-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.page-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-light);margin-bottom:16px}
.page-breadcrumb a{color:var(--purple);transition:color .2s}
.page-breadcrumb a:hover{color:var(--magenta)}
.page-breadcrumb span{color:var(--text-light)}
.page-hero h1{color:var(--navy);margin-bottom:14px}
.page-hero-sub{font-size:1.05rem;color:var(--text-mid);max-width:640px;line-height:1.8}

/* ─── SECTION UTILITIES ─── */
.section-label{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--purple);margin-bottom:10px;display:block}
.section-title{color:var(--navy);margin-bottom:14px}
.section-sub{color:var(--text-mid);max-width:580px;font-size:1.02rem}

/* ─── BUTTONS ─── */
.btn-primary{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:50px;background:linear-gradient(135deg,var(--purple),var(--magenta));color:#fff;font-weight:600;font-size:.95rem;transition:transform .25s,box-shadow .25s;box-shadow:0 4px 20px rgba(107,63,160,.3)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(107,63,160,.45)}
.btn-secondary{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:50px;border:1.5px solid rgba(107,63,160,.3);color:var(--navy);font-weight:500;font-size:.95rem;transition:border-color .2s,background .2s,transform .2s}
.btn-secondary:hover{border-color:var(--purple);background:rgba(107,63,160,.05);transform:translateY(-2px)}
.btn-teal{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:50px;background:linear-gradient(135deg,var(--teal),#005f6b);color:#fff;font-weight:600;font-size:.95rem;transition:transform .25s,box-shadow .25s;box-shadow:0 4px 20px rgba(0,151,167,.3)}
.btn-teal:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,151,167,.45)}

/* ─── STICKY FLOAT BUTTON ─── */
#sticky-book{position:fixed;bottom:28px;right:28px;z-index:990;display:flex;align-items:center;gap:9px;padding:14px 26px;border-radius:50px;background:linear-gradient(135deg,var(--purple),var(--magenta));color:#fff;font-weight:600;font-size:.92rem;box-shadow:0 8px 32px rgba(107,63,160,.45);transition:transform .25s,box-shadow .25s,opacity .3s;opacity:0;pointer-events:none;text-decoration:none}
#sticky-book.visible{opacity:1;pointer-events:auto}
#sticky-book:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(107,63,160,.6)}

/* ─── REVEAL ─── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}

/* ─── FOOTER ─── */
footer{background:#0e0e1e;padding:48px 40px 32px;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-logo{display:flex;align-items:center;gap:12px}
.footer-logo img{width:48px;height:48px;border-radius:50%;object-fit:cover}
.footer-logo-text{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.05rem;color:#fff;line-height:1.25}
.footer-logo-text span{display:block;font-family:'DM Sans',sans-serif;font-size:.68rem;font-weight:400;color:rgba(255,255,255,.4);letter-spacing:.06em}
.footer-links{display:flex;gap:24px;flex-wrap:wrap}
.footer-links a{font-size:.83rem;color:rgba(255,255,255,.5);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-copy{max-width:1280px;margin:24px auto 0;text-align:center;font-size:.76rem;color:rgba(255,255,255,.3)}

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  #main-nav{top:49px}
  .nav-links,.nav-phone{display:none}
  .hamburger{display:flex}
  .page-hero{padding:60px 24px 52px}
  .page-hero h1{font-size:clamp(1.6rem,6vw,2.4rem)}
  .page-hero-sub{font-size:.95rem}
  footer{padding:40px 24px 24px}
  .footer-inner{flex-direction:column;align-items:flex-start}
  .footer-links{flex-wrap:wrap;gap:12px}
  #sticky-book{bottom:20px;right:16px}
}
@media(max-width:480px){
  #top-banner{flex-wrap:wrap;gap:6px;padding:8px 16px;position:static}
  #main-nav{top:0}
  .banner-left{width:100%}
  .banner-ctas{width:100%;justify-content:flex-start}
  .page-hero h1{font-size:clamp(1.4rem,7vw,2rem)}
  .page-hero-breadcrumb{font-size:.75rem}
  .page-hero .btn-primary,.page-hero .btn-secondary{width:100%;justify-content:center;text-align:center}
}
