/* ==========================================================================
   5K Immigration — Design System (glassmorphism, dark hero / light body)
   Concept A "Engineered, not guessed": blueprint grid + journey path + orbs
   ========================================================================== */

:root{
  /* Brand */
  --navy-900:#0b1230; --navy-800:#131c45; --navy-700:#1a2a6b; --navy-500:#213885;
  --purple-600:#5F3475; --purple-400:#8b5cf6; --glow-blue:#4a90ff;
  --cream:#faf9f7; --ink:#131423; --warm-charcoal:#55534e; --muted:#9f9b93;
  --oat:#dad4c8;

  /* Glass — dark surfaces */
  --glass-dark-bg:rgba(255,255,255,0.07);
  --glass-dark-border:rgba(255,255,255,0.16);

  /* Glass — light surfaces */
  --glass-light-bg:rgba(255,255,255,0.55);
  --glass-light-border:rgba(33,56,133,0.12);
  --glass-light-shadow:0 8px 32px rgba(33,56,133,0.10),0 1px 2px rgba(33,56,133,0.06);

  /* Gradients */
  --grad-brand:linear-gradient(120deg,var(--navy-500),var(--purple-600));
  --grad-stat:linear-gradient(90deg,#9db4ff,#c9a8ff);

  /* Spacing scale (kept from v1) */
  --space-8:8px; --space-12:12px; --space-16:16px; --space-20:20px; --space-24:24px;
  --space-32:32px; --space-40:40px; --space-48:48px; --space-64:64px; --space-80:80px;

  /* Radius */
  --radius-sm:4px; --radius-md:8px; --radius-lg:12px; --radius-xl:24px; --radius-2xl:40px; --radius-pill:9999px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Roobert',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
img{max-width:100%}
.mono{font-family:'Space Mono',monospace}

h1,h2,h3,h4{line-height:1.15;letter-spacing:-0.02em;font-weight:600}
.section-heading{font-size:clamp(30px,3.4vw,44px)}
.body-text{font-size:clamp(15.5px,1.25vw,17.5px);line-height:1.7;color:var(--warm-charcoal)}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{display:inline-block;padding:15px 32px;border-radius:var(--radius-pill);font-size:16px;font-weight:600;text-decoration:none;cursor:pointer;border:none;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,background .25s}
.btn-primary{background:var(--grad-brand);color:#fff;border:1px solid rgba(255,255,255,0.2);box-shadow:0 8px 32px rgba(95,52,117,0.4)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 14px 44px rgba(95,52,117,0.6)}
.btn-glass{background:var(--glass-dark-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-dark-border);color:#fff}
.btn-glass:hover{transform:translateY(-3px);background:rgba(255,255,255,0.13)}
.btn-white{background:#fff;color:var(--navy-500);border:1px solid rgba(33,56,133,0.15);box-shadow:0 4px 18px rgba(33,56,133,0.12)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(33,56,133,0.2)}

/* ==========================================================================
   Header / Nav — frosted glass, dark over hero → light after scroll
   ========================================================================== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(11,18,48,0.55);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid rgba(255,255,255,0.08);transition:background .35s,border-color .35s}
.site-header .nav-inner{max-width:1400px;margin:0 auto;padding:12px 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;min-width:0}
.logo img{height:44px;width:44px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(139,92,246,0.35))}
.logo-text{font-weight:600;font-size:17px;letter-spacing:-0.01em;white-space:nowrap;color:#fff;transition:color .35s}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{color:rgba(255,255,255,0.78);text-decoration:none;font-size:15px;font-weight:500;transition:color .2s;padding:4px 0;border-bottom:2px solid transparent}
.nav-links a:hover{color:#fff}
.nav-links .active-li a{color:#fff;border-bottom-color:var(--purple-400)}
.nav-actions{display:flex;align-items:center}
.nav-cta{position:relative;display:inline-flex;align-items:center;padding:7px 18px 7px 30px;background:var(--grad-brand);border-radius:var(--radius-pill);text-decoration:none;border:1px solid rgba(255,255,255,0.18);box-shadow:0 4px 18px rgba(95,52,117,0.45);transition:transform .2s,box-shadow .2s;margin-left:16px}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(95,52,117,0.6)}
.nav-cta img{position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;object-fit:cover;object-position:center top;border:2px solid rgba(255,255,255,0.9);background:#c8dcff}
.nav-cta span{color:#fff;font-weight:600;font-size:14.5px;white-space:nowrap}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:var(--glass-dark-bg);border:1px solid var(--glass-dark-border);border-radius:10px;width:44px;height:44px;padding:0 11px;cursor:pointer}
.hamburger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .25s,opacity .25s,background .35s}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* light-mode nav once scrolled past hero */
.site-header.nav-light{background:rgba(250,249,247,0.78);border-bottom-color:rgba(33,56,133,0.10)}
.site-header.nav-light .logo-text{color:var(--ink)}
.site-header.nav-light .nav-links a{color:var(--warm-charcoal)}
.site-header.nav-light .nav-links a:hover,
.site-header.nav-light .nav-links .active-li a{color:var(--navy-500)}
.site-header.nav-light .hamburger{background:rgba(33,56,133,0.06);border-color:rgba(33,56,133,0.15)}
.site-header.nav-light .hamburger span{background:var(--navy-500)}

/* mobile overlay — full dark glass panel */
.mobile-nav-overlay{position:fixed;inset:0;z-index:2000;background:rgba(11,18,48,0.86);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;pointer-events:none;transition:opacity .3s}
.mobile-nav-overlay.is-open{opacity:1;pointer-events:auto}
.mobile-nav-close{position:absolute;top:18px;right:18px;background:var(--glass-dark-bg);border:1px solid var(--glass-dark-border);border-radius:10px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;color:#fff;line-height:1}
.mobile-nav-links{display:flex;flex-direction:column;align-items:center;gap:6px}
.mobile-nav-links a{color:rgba(255,255,255,0.85);text-decoration:none;font-size:24px;font-weight:600;padding:10px 28px;border-radius:14px;transition:background .2s,color .2s}
.mobile-nav-links a:hover,.mobile-nav-links a.mob-active{color:#fff;background:var(--glass-dark-bg)}
.mobile-nav-cta-row{margin-top:26px}
.mobile-nav-cta-row a{display:inline-flex;align-items:center;padding:14px 30px;background:var(--grad-brand);border-radius:var(--radius-pill);text-decoration:none;color:#fff;font-weight:600;font-size:16px;border:1px solid rgba(255,255,255,0.2)}

/* ==========================================================================
   HERO — Concept A: blueprint grid + journey path + orbs + glass chips
   ========================================================================== */
.hero{position:relative;min-height:74vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:150px 24px 90px;background:linear-gradient(180deg,var(--navy-900) 0%,var(--navy-800) 75%,var(--navy-800) 100%);overflow:hidden;color:#fff}
.hero.hero-compact{min-height:56vh;padding:140px 24px 70px}

.hero::before{content:'';position:absolute;inset:-10%;background-image:
  linear-gradient(rgba(116,150,255,0.055) 1px,transparent 1px),
  linear-gradient(90deg,rgba(116,150,255,0.055) 1px,transparent 1px),
  linear-gradient(rgba(116,150,255,0.022) 1px,transparent 1px),
  linear-gradient(90deg,rgba(116,150,255,0.022) 1px,transparent 1px);
  background-size:96px 96px,96px 96px,24px 24px,24px 24px;
  -webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,#000 30%,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,#000 30%,transparent 75%);
  transform:perspective(900px) rotateX(8deg) scale(1.08)}

.orb{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;will-change:transform}
.orb-purple{width:560px;height:560px;background:radial-gradient(circle,rgba(139,92,246,0.38),transparent 65%);top:-12%;right:-8%;animation:orbFloat1 22s ease-in-out infinite}
.orb-blue{width:480px;height:480px;background:radial-gradient(circle,rgba(74,144,255,0.30),transparent 65%);bottom:-15%;left:-10%;animation:orbFloat2 26s ease-in-out infinite}
@keyframes orbFloat1{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,40px)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,-35px)}}

.glass-chip{position:absolute;border:1px solid var(--glass-dark-border);background:var(--glass-dark-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;pointer-events:none}
.chip-1{width:120px;height:120px;top:20%;left:9%;transform:rotate(-12deg);animation:chipBob 9s ease-in-out infinite}
.chip-2{width:72px;height:72px;top:62%;right:12%;transform:rotate(18deg);animation:chipBob 7s ease-in-out infinite reverse}
.chip-3{width:48px;height:48px;top:30%;right:22%;border-radius:50%;animation:chipBob 11s ease-in-out infinite}
@keyframes chipBob{0%,100%{margin-top:0}50%{margin-top:-22px}}

.jy-scene{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:1440px;pointer-events:none;z-index:1}
.journey{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.9}
.journey path.trail{fill:none;stroke:url(#trailGrad);stroke-width:2.5;stroke-dasharray:8 10;stroke-linecap:round;animation:trailDash 3.2s ease forwards,trailMarch 30s linear 3.2s infinite}
@keyframes trailDash{from{stroke-dashoffset:1400}to{stroke-dashoffset:0}}
@keyframes trailMarch{from{stroke-dashoffset:0}to{stroke-dashoffset:-360}}
.jy{position:absolute;transform:translate(-50%,-50%)}
.jy-plane{left:9.03%;top:93%}
.jy-plane svg{display:block;fill:#dce7ff;transform:rotate(82deg);filter:drop-shadow(0 0 10px rgba(74,144,255,0.85));animation:jyBob 5s ease-in-out infinite}
@keyframes jyBob{0%,100%{translate:0 0}50%{translate:0 -7px}}
.jy-dest{left:90.97%;top:18.75%}
.jy-dest svg{display:block}
.jy-flag svg{filter:drop-shadow(0 4px 18px rgba(232,68,58,0.45))}

.hero-content{position:relative;z-index:5;max-width:880px;width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:10px;max-width:100%;flex-wrap:wrap;justify-content:center;row-gap:4px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.14em;color:rgba(255,255,255,0.85);background:var(--glass-dark-bg);border:1px solid var(--glass-dark-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:9px 20px;border-radius:var(--radius-pill);margin-bottom:30px;text-transform:uppercase}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#3ddc84;box-shadow:0 0 10px #3ddc84;flex-shrink:0}
.display-hero{font-size:clamp(38px,6.4vw,76px);font-weight:600;line-height:1.05;letter-spacing:-0.025em;margin-bottom:26px;background:linear-gradient(118deg,#ffffff 30%,#c1b0ff 75%,#8fb8ff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-description{font-size:clamp(17px,1.6vw,20px);line-height:1.65;color:rgba(255,255,255,0.78);max-width:660px;margin:0 auto 38px}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ==========================================================================
   Stats strip — dark glass cards
   ========================================================================== */
.hero-stats-section{position:relative;background:var(--navy-800);padding:0 24px 84px}
.hero-stats-inner{position:relative;z-index:6;max-width:1180px;margin:-8px auto 0;display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.stat-card{background:var(--glass-dark-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-dark-border);border-radius:18px;padding:22px 12px;text-align:center;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.10),transparent 45%);pointer-events:none}
.stat-number{font-size:30px;font-weight:700;line-height:1;margin-bottom:8px;background:var(--grad-stat);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-label{font-size:12.5px;color:rgba(255,255,255,0.65);letter-spacing:.02em}

/* ==========================================================================
   Dark ↔ light bridges
   ========================================================================== */
.bridge-to-light{height:140px;background:linear-gradient(180deg,var(--navy-800) 0%,#3a3f73 35%,#b9b4c4 75%,var(--cream) 100%)}
.bridge-to-dark{height:140px;background:linear-gradient(180deg,var(--cream) 0%,#b9b4c4 25%,#3a3f73 65%,var(--navy-900) 100%)}

/* ==========================================================================
   Light glass card primitives
   ========================================================================== */
.glass-card{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:20px;box-shadow:var(--glass-light-shadow)}
.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .35s ease,box-shadow .35s ease}
.tilt:hover{box-shadow:0 18px 48px rgba(33,56,133,0.16)}

.feature-title{font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-500)}
.caption{font-size:13px;color:var(--muted)}

/* ==========================================================================
   About section (light)
   ========================================================================== */
.about-section-wrap{background:var(--cream);position:relative;overflow:hidden}
.about-section-wrap::before{content:'';position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,0.10),transparent 65%);filter:blur(50px);top:-10%;right:-8%;pointer-events:none}
.about{max-width:1200px;margin:0 auto;padding:90px 24px}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:56px;align-items:center}
.about-image .image-wrapper{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 24px 64px rgba(33,56,133,0.18);border:1px solid var(--glass-light-border)}
.credential-badge{position:absolute;bottom:16px;left:16px;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,0.72);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,0.7);padding:10px 16px;border-radius:14px;box-shadow:0 8px 24px rgba(33,56,133,0.18)}
.credential-icon{font-size:22px}
.credential-text{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--navy-500)}
.credential-number{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;color:var(--ink)}
.about-content .section-heading{margin:8px 0 18px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.about-content .body-text{margin-bottom:16px}
.about-highlights{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}
.highlight-item{display:flex;align-items:center;gap:12px;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-radius:14px;padding:13px 16px;box-shadow:0 4px 16px rgba(33,56,133,0.06);transition:transform .25s,box-shadow .25s}
.highlight-item:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(33,56,133,0.12)}
.highlight-icon{font-size:20px}
.highlight-text{font-size:14.5px;font-weight:600;color:var(--ink)}

/* ==========================================================================
   Services preview (light glass cards with 3D tilt)
   ========================================================================== */
.services-section-wrap{background:var(--cream);position:relative;overflow:hidden}
.services-section-wrap::before{content:'';position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(74,144,255,0.10),transparent 65%);filter:blur(50px);bottom:-15%;left:-10%;pointer-events:none}
.services{max-width:1200px;margin:0 auto;padding:40px 24px 90px;position:relative}
.services-header{text-align:center;max-width:760px;margin:0 auto 48px}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;perspective:1100px}
.service-card{display:block;text-decoration:none;color:inherit;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:20px;padding:32px 26px;box-shadow:var(--glass-light-shadow);position:relative;overflow:hidden}
.service-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-brand);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.service-card:hover::after{transform:scaleX(1)}
.service-icon{width:52px;height:52px;border-radius:14px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px;box-shadow:0 6px 18px rgba(95,52,117,0.3)}
.service-title{font-size:18px;font-weight:600;text-transform:none;letter-spacing:-0.01em;color:var(--ink);margin-bottom:10px}
.service-description{font-size:14.5px;color:var(--warm-charcoal);line-height:1.6}
.service-link{margin-top:18px;font-size:13px;font-weight:700;color:var(--navy-500)}

/* ==========================================================================
   How we work — 4 steps
   ========================================================================== */
.how-we-work{background:var(--cream);padding:50px 24px 90px}
.how-we-work-inner{max-width:1200px;margin:0 auto}
.how-we-work-header{text-align:center;max-width:720px;margin:0 auto 54px}
.how-we-work-eyebrow{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px}
.how-we-work-line{display:block;width:48px;height:2px;background:var(--grad-brand);border-radius:2px}
.how-we-work-eyebrow .label{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.16em;font-weight:700;color:var(--navy-500)}
.how-we-work-title em{font-style:italic;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.how-we-work-sub{margin-top:14px}
.horiz-steps-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative}
.horiz-steps-row::before{content:'';position:absolute;top:24px;left:6%;right:6%;height:2px;background:repeating-linear-gradient(90deg,rgba(33,56,133,0.35) 0 8px,transparent 8px 18px);z-index:0}
.horiz-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.horiz-step-node{width:48px;height:48px;border-radius:50%;background:var(--grad-brand);color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(95,52,117,0.35),0 0 0 6px var(--cream);margin-bottom:18px}
.horiz-step-box{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:18px;padding:24px 20px;box-shadow:var(--glass-light-shadow);flex:1;transition:transform .3s,box-shadow .3s}
.horiz-step:hover .horiz-step-box{transform:translateY(-5px);box-shadow:0 16px 40px rgba(33,56,133,0.15)}
.horiz-step-label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--purple-400);font-weight:700;margin-bottom:8px}
.horiz-step-title{font-size:17px;margin-bottom:10px}
.horiz-step-desc{font-size:14px;color:var(--warm-charcoal);line-height:1.6}

/* ==========================================================================
   Testimonials — light glass carousel
   ========================================================================== */
.testimonials{background:var(--cream);padding:50px 0 90px;position:relative;overflow:hidden}
.testimonials::before{content:'';position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,0.10),transparent 65%);filter:blur(60px);top:0;left:50%;transform:translateX(-50%);pointer-events:none}
.testimonials-inner{max-width:1400px;margin:0 auto;position:relative}
.testimonials-header{text-align:center;max-width:720px;margin:0 auto 48px;padding:0 24px}
.testimonials-title{font-size:clamp(30px,3.4vw,44px)}
.testimonials-title span{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.testimonials-sub{margin-top:12px;color:var(--warm-charcoal)}
.google-testimonials-wrapper{overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.google-testimonials-scroll{display:flex;gap:20px;width:max-content;animation:scrollTestimonials 60s linear infinite;padding:10px 0}
.google-testimonials-wrapper:hover .google-testimonials-scroll{animation-play-state:paused}
@keyframes scrollTestimonials{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.google-testimonial-card{width:380px;flex-shrink:0;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:20px;padding:24px;box-shadow:var(--glass-light-shadow);display:flex;flex-direction:column}
.google-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.google-stars{color:#fbbd41;font-size:15px;letter-spacing:2px}
.google-review-text{font-size:14px;line-height:1.65;color:var(--warm-charcoal);flex:1}
.google-footer{display:flex;align-items:center;gap:12px;margin-top:16px}
.google-avatar{width:38px;height:38px;border-radius:50%;color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.google-name{font-size:14px;font-weight:600;color:var(--ink)}
.google-date{font-size:12px;color:var(--muted)}

/* ==========================================================================
   Areas we serve (light, glass chips)
   ========================================================================== */
.areas-section{background:var(--cream);padding:50px 24px 90px;text-align:center;position:relative;overflow:hidden}
.areas-inner{max-width:980px;margin:0 auto;position:relative}
.areas-statement{font-size:clamp(15.5px,1.25vw,17.5px);line-height:1.7;color:var(--warm-charcoal);max-width:780px;margin:18px auto 36px}
.areas-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.area-chip{display:inline-flex;align-items:center;gap:8px;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-radius:var(--radius-pill);padding:11px 22px;font-size:15px;font-weight:600;color:var(--ink);box-shadow:0 4px 16px rgba(33,56,133,0.07);transition:transform .25s,box-shadow .25s}
.area-chip:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(33,56,133,0.14)}
.area-chip .pin{color:var(--purple-400)}
.area-chip.area-wide{background:var(--grad-brand);color:#fff;border-color:rgba(255,255,255,0.2)}
.areas-note{margin-top:26px;font-size:14px;color:var(--muted)}

/* ==========================================================================
   Dark CTA section (trust) — bookends the page with the hero
   ========================================================================== */
.colored-section{position:relative;background:linear-gradient(160deg,var(--navy-900) 0%,var(--navy-800) 60%,#1d1640 100%);padding:100px 24px;overflow:hidden;color:#fff}
.colored-section::before{content:'';position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,0.30),transparent 65%);filter:blur(70px);top:-18%;right:-10%;pointer-events:none}
.colored-section::after{content:'';position:absolute;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(74,144,255,0.22),transparent 65%);filter:blur(70px);bottom:-18%;left:-8%;pointer-events:none}
.colored-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:56px;align-items:center}
.colored-text .section-heading{color:#fff;margin-bottom:18px}
.colored-text p{color:rgba(255,255,255,0.78);line-height:1.7}
.trust-badges{display:flex;gap:16px;margin-top:28px;flex-wrap:wrap}
.trust-badge{display:flex;align-items:center;gap:12px;background:var(--glass-dark-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-dark-border);border-radius:16px;padding:14px 20px}
.trust-icon{font-size:22px}
.trust-badge .caption{color:rgba(255,255,255,0.6)}
.trust-badge .feature-title{color:#fff;text-transform:none;letter-spacing:0;font-size:15px}
.why-5k-card{background:var(--glass-dark-bg);-webkit-backdrop-filter:blur(18px) saturate(140%);backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--glass-dark-border);border-radius:var(--radius-xl);padding:40px;position:relative;overflow:hidden}
.why-5k-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.10),transparent 40%);pointer-events:none}
.why-5k-card .card-heading{color:#fff;font-size:21px;margin-bottom:26px;position:relative}
.why-5k-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;position:relative}
.why-5k-item{display:flex;gap:14px;align-items:flex-start}
.why-5k-item .why-icon{font-size:18px;margin-top:2px}
.why-5k-item .feature-title{color:#fff;text-transform:none;letter-spacing:0;font-size:15px;margin-bottom:3px}
.why-5k-item .caption{color:rgba(255,255,255,0.62)}

/* ==========================================================================
   CTA banner overlapping footer
   ========================================================================== */
.cta-banner-wrap{background:var(--navy-900);padding:0 24px;position:relative;z-index:10}
.cta-banner{max-width:900px;margin:0 auto;transform:translateY(50%);background:var(--grad-brand);border-radius:20px;padding:28px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;box-shadow:0 16px 48px rgba(95,52,117,0.45);border:1px solid rgba(255,255,255,0.18)}
.cta-banner-title{font-size:clamp(15px,1.6vw,19px);color:#fff;font-weight:700;letter-spacing:.02em;margin-bottom:4px}
.cta-banner-sub{font-size:14px;font-weight:600;color:rgba(255,255,255,0.72)}
.cta-banner-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;background:#fff;color:var(--navy-500);text-decoration:none;border-radius:12px;font-weight:700;font-size:14px;white-space:nowrap;transition:transform .2s,box-shadow .2s}
.cta-banner-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.25)}

/* ==========================================================================
   Footer — solid navy with gradient top border
   ========================================================================== */
footer{background:var(--navy-900);color:rgba(255,255,255,0.75);padding:120px 24px 32px;position:relative}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy-500),var(--purple-400),var(--navy-500))}
.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.10)}
.footer-brand .footer-logo-row{display:flex;align-items:center;gap:12px;text-decoration:none;margin-bottom:18px}
.footer-brand .footer-logo-row img{width:44px;height:44px;object-fit:contain}
.footer-brand .footer-logo-row span{font-weight:700;font-size:17px;color:#fff;letter-spacing:-0.02em}
.footer-brand p{font-size:14.5px;line-height:1.7;color:rgba(255,255,255,0.6)}
.footer-social-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,0.45)}
.footer-links h4{color:#fff;font-size:15px;margin-bottom:16px}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{color:rgba(255,255,255,0.65);text-decoration:none;font-size:14.5px;transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-areas{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.7;max-width:1200px;margin:18px auto 0;text-align:center}
.footer-bottom{max-width:1200px;margin:24px auto 0;display:flex;justify-content:center;font-size:13.5px;color:rgba(255,255,255,0.5)}
.footer-bottom a{color:rgba(255,255,255,0.7);text-decoration:none}
.footer-bottom a:hover{color:#fff}
footer address{font-style:normal;display:inline}

/* ==========================================================================
   Page nav arrows + messaging widget
   ========================================================================== */
#page-nav-arrows{position:fixed;right:20px;bottom:120px;z-index:900;display:flex;flex-direction:column;gap:10px}
.arrow-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(33,56,133,0.25);background:rgba(255,255,255,0.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(0,0,0,0.12);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}
.arrow-btn:hover{transform:translateY(-2px);background:#fff}
.arrow-btn svg{stroke:var(--navy-500)}

#msg-btn{position:fixed;right:20px;bottom:28px;z-index:901;width:52px;height:52px;border-radius:50%;background:var(--grad-brand);border:1px solid rgba(255,255,255,0.25);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(95,52,117,0.45);transition:transform .2s,box-shadow .2s}
#msg-btn:hover{transform:scale(1.08);box-shadow:0 8px 28px rgba(95,52,117,0.6)}
#msg-popup{display:none;position:fixed;inset:0;z-index:3000;align-items:flex-end;justify-content:flex-end;padding:0 20px 90px 0}
#msg-popup.is-open{display:flex}
.msg-card{background:rgba(255,255,255,0.92);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,0.8);border-radius:18px;box-shadow:0 18px 60px rgba(11,18,48,0.35);width:340px;max-width:calc(100vw - 40px);overflow:hidden;animation:msgSlideUp .22s ease}
@keyframes msgSlideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.msg-head{background:var(--grad-brand);padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.msg-head-title{color:#fff;font-weight:700;font-size:15px}
.msg-head-sub{color:rgba(255,255,255,0.75);font-size:12px;margin-top:2px}
.msg-close{background:rgba(255,255,255,0.15);border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;line-height:1}
.msg-body{padding:20px}

/* ==========================================================================
   Forms — light glass
   ========================================================================== */
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:12.5px;font-weight:600;color:var(--warm-charcoal);margin-bottom:5px}
.form-field label .req{color:var(--navy-500)}
.form-field input,.form-field select,.form-field textarea{width:100%;padding:11px 14px;border:1px solid rgba(33,56,133,0.18);border-radius:10px;font-size:14.5px;font-family:inherit;outline:none;background:rgba(255,255,255,0.75);transition:border-color .2s,box-shadow .2s;color:var(--ink)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px rgba(33,56,133,0.12)}
.form-field textarea{resize:vertical}
.form-field input,.form-field select{height:46px}
.form-field select{-webkit-appearance:none;appearance:none;padding-right:38px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23213885' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.form-submit-btn{width:100%;padding:13px;background:var(--grad-brand);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.3px;transition:opacity .2s,transform .2s}
.form-submit-btn:hover{transform:translateY(-1px)}
.form-submit-btn:disabled{opacity:.7;cursor:wait}
.form-success{padding:32px 20px;text-align:center}
.form-success .emoji{font-size:40px;margin-bottom:12px}
.form-success .title{font-weight:700;font-size:16px;color:var(--ink);margin-bottom:8px}
.form-success .text{color:var(--warm-charcoal);font-size:14px;line-height:1.6}
.form-success .sig{color:var(--muted);font-size:12px;margin-top:12px}
.honeypot{display:none !important}

/* ==========================================================================
   Scroll reveals
   ========================================================================== */
.reveal{opacity:0;transform:translateY(24px) scale(0.985);transition:opacity .6s ease,transform .6s ease}
.reveal.revealed{opacity:1;transform:none}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal-stagger.revealed>*{opacity:1;transform:none}
.reveal-stagger.revealed>*:nth-child(2){transition-delay:.08s}
.reveal-stagger.revealed>*:nth-child(3){transition-delay:.16s}
.reveal-stagger.revealed>*:nth-child(4){transition-delay:.24s}
.reveal-stagger.revealed>*:nth-child(5){transition-delay:.32s}
.reveal-stagger.revealed>*:nth-child(6){transition-delay:.40s}

/* ==========================================================================
   FAQ (details/summary) — shared by about/services
   ========================================================================== */
.faq-list{max-width:820px;margin:0 auto;text-align:left}
.faq-item{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-radius:16px;margin-bottom:12px;box-shadow:0 4px 16px rgba(33,56,133,0.06);overflow:hidden}
.faq-item summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;font-size:16px;font-weight:600;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:22px;font-weight:400;color:var(--navy-500);transition:transform .25s;flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-answer{padding:0 22px 20px;font-size:14.5px;line-height:1.7;color:var(--warm-charcoal)}

/* ==========================================================================
   Fallbacks & accessibility guards
   ========================================================================== */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .site-header{background:rgba(11,18,48,0.93)}
  .site-header.nav-light{background:rgba(250,249,247,0.97)}
  .stat-card,.eyebrow,.btn-glass,.glass-chip,.trust-badge,.why-5k-card,.mobile-nav-overlay{background:rgba(19,28,69,0.93)}
  .glass-card,.service-card,.highlight-item,.horiz-step-box,.google-testimonial-card,.area-chip,.faq-item,.msg-card,.credential-badge{background:rgba(255,255,255,0.95)}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .orb,.glass-chip,.journey path.trail,.jy-plane svg,.google-testimonials-scroll{animation:none !important}
  .journey path.trail{stroke-dashoffset:0}
  .reveal,.reveal-stagger>*{opacity:1 !important;transform:none !important;transition:none !important}
  .tilt,.btn,.service-card,.highlight-item,.area-chip{transition:none !important}
  .parallax-layer{transform:none !important}
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1024px){
  .colored-content{grid-template-columns:1fr;gap:40px}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-image{max-width:440px;margin:0 auto}
  .horiz-steps-row{grid-template-columns:repeat(2,1fr);gap:22px}
  .horiz-steps-row::before{display:none}
}
@media (max-width:900px){
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .eyebrow{font-size:10px;letter-spacing:.09em;padding:8px 14px}
  .hero{min-height:68vh;padding-top:130px}
  .jy-plane{left:11%;top:91%}
  .jy-dest{left:85%;top:17%}
  .jy svg{scale:.72}
  .hero-stats-inner{grid-template-columns:repeat(2,1fr);max-width:520px}
  .hero-stats-inner .stat-card:last-child{grid-column:1/-1}
  .chip-1{display:none}
  .site-header .nav-inner{padding:10px 18px}
  .logo-text{font-size:15px}
  .site-header,.stat-card,.eyebrow,.btn-glass{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
  .why-5k-grid{grid-template-columns:1fr}
  .why-5k-card{padding:28px 22px}
  .google-testimonial-card{width:300px}
  .cta-banner{padding:24px 26px}
  .footer-content{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:560px){
  .horiz-steps-row{grid-template-columns:1fr}
  .about-highlights{grid-template-columns:1fr}
  .footer-content{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .hero{padding-left:18px;padding-right:18px}
  .trust-badges{flex-direction:column}
}

/* ==========================================================================
   Services page
   ========================================================================== */
.disclaimer-banner{background:rgba(33,56,133,0.05);border-bottom:1px solid rgba(33,56,133,0.10);padding:10px 24px}
.disclaimer-banner p{max-width:1200px;margin:0 auto;font-size:12px;color:#6b6560;line-height:1.5;text-align:center}
.disclaimer-banner a{color:var(--navy-500);text-decoration:underline}

.services-container{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:300px 1fr;gap:28px;padding:48px 24px 90px;align-items:start}
.services-sidebar{position:sticky;top:90px;display:flex;flex-direction:column;gap:12px}
.sidebar-category{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:16px;box-shadow:var(--glass-light-shadow);overflow:hidden}
.sidebar-main-tab{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:transparent;border:none;padding:16px 20px;font-family:inherit;font-size:15px;font-weight:700;color:var(--ink);cursor:pointer;transition:background .2s,color .2s}
.sidebar-main-tab:hover{background:rgba(33,56,133,0.05)}
.sidebar-main-tab.active{background:var(--grad-brand);color:#fff}
.sidebar-toggle-arrow{font-size:11px;transition:transform .25s}
.sidebar-main-tab.active .sidebar-toggle-arrow{transform:rotate(180deg)}
.sidebar-submenu{display:none;flex-direction:column;padding:8px}
.sidebar-submenu.active{display:flex}
.sidebar-submenu a{display:block;padding:10px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--warm-charcoal);text-decoration:none;cursor:pointer;transition:background .2s,color .2s}
.sidebar-submenu a:hover{background:rgba(33,56,133,0.06);color:var(--navy-500)}
.sidebar-submenu a.active{background:rgba(139,92,246,0.12);color:var(--navy-500);font-weight:600}

.services-main{min-width:0}
.service-panel{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:24px;box-shadow:var(--glass-light-shadow);padding:40px}
.service-panel[hidden]{display:none}
.detail-header{display:flex;gap:20px;align-items:flex-start;margin-bottom:24px}
.detail-icon{width:64px;height:64px;border-radius:18px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;box-shadow:0 8px 24px rgba(95,52,117,0.3)}
.detail-title-text h2{font-size:clamp(24px,2.6vw,32px);margin-bottom:8px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.detail-tagline{font-size:15px;color:var(--warm-charcoal);line-height:1.65}
.detail-desc{font-size:16px;color:var(--warm-charcoal);line-height:1.8;margin-bottom:28px}
.detail-block{margin-bottom:28px}
.detail-block-title{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.detail-block-title::before{content:'✓';display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--grad-brand);color:#fff;font-size:12px;flex-shrink:0}
.elig-list,.support-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.elig-list li,.support-list li{position:relative;padding-left:24px;font-size:14.5px;color:var(--warm-charcoal);line-height:1.6}
.elig-list li::before,.support-list li::before{content:'';position:absolute;left:4px;top:8px;width:8px;height:8px;border-radius:50%;background:linear-gradient(120deg,var(--glow-blue),var(--purple-400))}
.key-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}
.fact-box{background:rgba(255,255,255,0.7);border:1px solid var(--glass-light-border);border-radius:14px;padding:14px 16px}
.fact-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.fact-value{font-size:15px;font-weight:700;color:var(--navy-500)}
.documents-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}
.document-item{position:relative;background:rgba(255,255,255,0.7);border:1px solid var(--glass-light-border);border-radius:12px;padding:11px 14px 11px 36px;font-size:13.5px;color:var(--warm-charcoal)}
.document-item::before{content:'📄';position:absolute;left:12px;top:10px;font-size:14px}
.panel-cta{margin-top:32px;padding-top:24px;border-top:1px solid rgba(33,56,133,0.10)}

.faq-section{background:var(--cream);padding:60px 24px 90px;text-align:center}
.faq-section .section-heading{margin-bottom:34px}

@media (max-width:1024px){
  .services-container{grid-template-columns:1fr;gap:20px}
  .services-sidebar{position:static}
  .service-panel{padding:28px 22px}
}

/* ==========================================================================
   About page
   ========================================================================== */
.page-about section{padding:46px 24px}
.page-about .container-md{max-width:1000px;margin:0 auto}
.why-became-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start}
.profile-card{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:24px;box-shadow:var(--glass-light-shadow);padding:30px;text-align:center}
.profile-card .avatar{width:150px;height:150px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:4px solid var(--navy-500);box-shadow:0 8px 24px rgba(33,56,133,0.3)}
.profile-card .avatar img{width:100%;height:100%;object-fit:cover;object-position:center top}
.profile-card h3{font-size:18px;color:var(--ink);margin-bottom:4px}
.profile-card .role{color:var(--muted);font-size:13px}
.approach-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:22px}
.approach-card{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-left:4px solid var(--navy-500);border-radius:14px;padding:16px 20px;box-shadow:0 4px 16px rgba(33,56,133,0.06);transition:transform .25s,box-shadow .25s}
.approach-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(33,56,133,0.12)}
.approach-card:nth-child(2){border-left-color:var(--purple-600)}
.approach-card:nth-child(3){border-left-color:var(--purple-400)}
.approach-card:nth-child(4){border-left-color:#fbbd41}
.approach-card h3{font-size:15px;color:var(--navy-500);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.approach-card p{font-size:14px;color:var(--warm-charcoal);line-height:1.55}
.five-tiles-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:18px}
.value-tile{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-top:4px solid var(--navy-500);border-radius:14px;padding:16px 10px;text-align:center;font-size:13.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy-500);box-shadow:0 4px 16px rgba(33,56,133,0.06);transition:transform .25s}
.value-tile:hover{transform:translateY(-3px)}
.value-tile:nth-child(2){border-top-color:var(--purple-600);color:var(--purple-600)}
.value-tile:nth-child(3){border-top-color:var(--purple-400);color:var(--purple-400)}
.value-tile:nth-child(4){border-top-color:#fbbd41;color:#9a7415}
.value-tile:nth-child(5){border-top-color:#893172;color:#893172}
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-radius:20px;padding:24px;box-shadow:var(--glass-light-shadow)}
.who-item{display:flex;gap:14px;align-items:flex-start}
.who-item .tick{width:32px;height:32px;background:var(--grad-brand);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:15px;margin-top:2px}
.who-item p{font-size:15px;line-height:1.55;color:var(--warm-charcoal)}
.who-item strong{color:var(--navy-500)}
.cred-rows{display:flex;flex-direction:column;gap:10px}
.cred-row{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-left:4px solid var(--navy-500);border-radius:14px;padding:14px 18px;display:flex;gap:14px;align-items:flex-start;box-shadow:0 4px 16px rgba(33,56,133,0.05)}
.cred-row:nth-child(2){border-left-color:var(--purple-600)}
.cred-row:nth-child(3){border-left-color:var(--purple-400)}
.cred-row .ic{font-size:18px;margin-top:2px}
.cred-row h3{font-size:16px;color:var(--ink);margin-bottom:4px}
.cred-row p{color:var(--warm-charcoal);font-size:13.5px;line-height:1.55}
@media (max-width:900px){
  .why-became-grid{grid-template-columns:1fr;gap:28px}
  .approach-grid,.who-grid{grid-template-columns:1fr}
  .five-tiles-grid{grid-template-columns:repeat(2,1fr)}
  .five-tiles-grid .value-tile:last-child{grid-column:1/-1}
}

/* ==========================================================================
   Contact page
   ========================================================================== */
.contact-cards-wrap{background:var(--cream);padding:36px 24px 24px}
.contact-cards-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.contact-card{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:18px;padding:24px;box-shadow:var(--glass-light-shadow);transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden}
.contact-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-brand)}
.contact-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(33,56,133,0.14)}
.contact-card .cc-icon{margin-bottom:14px}
.contact-card .cc-icon svg{stroke:var(--navy-500)}
.contact-card h3{font-size:16px;color:var(--ink);margin-bottom:6px}
.contact-card .cc-sub{color:var(--muted);font-size:13px;margin-bottom:12px;line-height:1.5}
.contact-card a{color:var(--navy-500);text-decoration:none;font-weight:600;font-size:14px;line-height:1.5}
.contact-card .cc-hours{color:var(--warm-charcoal);font-size:13px;line-height:1.7}
.contact-card .cc-hours strong{color:var(--navy-500)}
.inquiry-section{background:var(--cream);padding:32px 24px 90px}
.inquiry-card{max-width:900px;margin:0 auto;background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:28px;padding:48px;box-shadow:var(--glass-light-shadow)}
.inquiry-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.inquiry-form .form-field{margin-bottom:0}
.inquiry-form .full{grid-column:1/-1}
.form-privacy{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}
.inquiry-form .form-submit-btn{width:auto;padding:15px 36px;border-radius:12px;display:inline-flex;align-items:center;gap:10px}
@media (max-width:900px){
  .contact-cards-grid{grid-template-columns:repeat(2,1fr)}
  .inquiry-card{padding:28px 20px}
  .inquiry-form{grid-template-columns:1fr}
}
@media (max-width:560px){
  .contact-cards-grid{grid-template-columns:1fr}
}

/* ==========================================================================
   Book page
   ========================================================================== */
.service-boxes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-bottom:36px;perspective:1100px}
.service-box{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:2px solid var(--glass-light-border);border-radius:20px;padding:32px 24px;cursor:pointer;text-align:center;box-shadow:var(--glass-light-shadow);transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;flex-direction:column;align-items:center}
.service-box:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(33,56,133,0.14)}
.service-box.active{border-color:var(--purple-400);box-shadow:0 0 0 4px rgba(139,92,246,0.15),0 14px 36px rgba(33,56,133,0.16)}
.service-box .sb-emoji{font-size:44px;margin-bottom:14px}
.service-box h3{font-size:16px;color:var(--navy-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.service-box .sb-line{color:var(--warm-charcoal);font-size:14px;margin-bottom:8px}
.service-box .sb-desc{font-size:12px;color:#6b6560;line-height:1.5;margin-bottom:0;text-align:center;flex-grow:1}
.service-box .sb-duration{background:var(--grad-brand);color:#fff;padding:8px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;display:inline-block;margin-top:16px}
.inperson-notice{display:flex;align-items:flex-start;gap:10px;background:#f5f3ff;border:1.5px solid #8b5cf6;border-radius:12px;padding:14px 18px;margin:20px 0 32px;color:#3b0764;font-size:13px;line-height:1.55}
.inperson-notice svg{flex-shrink:0;color:#7c3aed;margin-top:2px}
.inperson-notice p{margin:0}
.inperson-notice a{color:#6d28d9;font-weight:600;text-decoration:underline}
.calendar-container{background:rgba(255,255,255,0.8);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-light-border);border-radius:28px;padding:42px;box-shadow:var(--glass-light-shadow);display:none}
.calendar-container.is-open{display:block}
@media (max-width:900px){.calendar-container{padding:22px 12px}}

/* ==========================================================================
   Privacy page
   ========================================================================== */
.page-privacy .privacy-wrapper{line-height:1.7;color:var(--warm-charcoal)}
.page-privacy .privacy-section{background:var(--glass-light-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-light-border);border-radius:18px;padding:26px 28px;margin-bottom:16px;box-shadow:0 4px 16px rgba(33,56,133,0.05)}
.page-privacy .privacy-section h2{font-size:19px;color:var(--navy-500);margin-bottom:12px}
.page-privacy .privacy-section h3{font-size:16px;color:var(--ink);margin:14px 0 8px}
.page-privacy .privacy-section p,.page-privacy .privacy-section li{font-size:14.5px;margin-bottom:8px}
.page-privacy .privacy-section ul{padding-left:22px;margin-bottom:8px}
.page-privacy .highlight-box{background:rgba(139,92,246,0.08);border-left:4px solid var(--purple-400);border-radius:10px;padding:14px 18px;margin-top:10px}
.page-privacy .privacy-intro{margin-bottom:22px}

/* in-text links must not rely on color alone */
p a:not(.btn):not(.cta-banner-btn),.faq-answer a,.footer-bottom a{text-decoration:underline}
