/* =========================================================
   Compliance to Confidence Accounting — site stylesheet
   Single source of truth. Edit here, applies everywhere.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --navy:#1B2A4A;
  --navy-deep:#0D1B3E;
  --teal:#1A7A6E;
  --teal-light:#22A394;
  --teal-pale:#E8F5F2;
  --gray-light:#F6F8FA;
  --gray-mid:#E2E7EE;
  --body:#2D3748;
  --muted:#5B6B82;
  --white:#FFFFFF;

  --radius:14px;
  --radius-lg:18px;
  --radius-sm:8px;

  --shadow-card:0 1px 2px rgba(13,27,62,.04), 0 4px 24px rgba(13,27,62,.05);
  --shadow-card-hover:0 2px 4px rgba(13,27,62,.06), 0 18px 40px rgba(13,27,62,.10);

  --serif:'DM Serif Display', Georgia, 'Times New Roman', serif;
  --sans:'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;

  --container:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,
*::before,
*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  color:var(--body);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg{display:block;max-width:100%}
a{color:var(--teal);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--teal-light)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ---------- Type ---------- */
h1,h2,h3,h4,h5{
  font-family:var(--serif);
  color:var(--navy);
  font-weight:400;
  line-height:1.15;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(36px, 5.4vw, 60px)}
h2{font-size:clamp(28px, 3.6vw, 42px); margin-bottom:18px}
h3{font-size:clamp(20px, 2vw, 24px); margin-bottom:10px}
h4{font-size:17px; font-weight:500; font-family:var(--sans); color:var(--navy)}
p{margin-bottom:14px}
p:last-child{margin-bottom:0}

.eyebrow{
  font-family:var(--sans);
  display:inline-block;
  color:var(--teal);
  font-size:12px;
  font-weight:600;
  letter-spacing:1.6px;
  text-transform:uppercase;
  margin-bottom:14px;
}

.section-label{
  display:block;
  text-align:center;
  color:var(--teal);
  font-size:12px;
  font-weight:600;
  letter-spacing:1.6px;
  text-transform:uppercase;
  margin-bottom:14px;
}
.section-title{text-align:center;margin-bottom:14px}
.section-intro{
  text-align:center;
  color:var(--muted);
  max-width:700px;
  margin:0 auto 48px;
  font-size:17px;
}

/* ---------- Layout ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}
section{padding:96px 0}
.bg-light{background:var(--gray-light)}
.bg-pale{background:var(--teal-pale)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 26px;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:15px;
  font-family:var(--sans);
  text-align:center;
  cursor:pointer;
  border:1.5px solid transparent;
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-teal:hover{background:var(--teal-light);border-color:var(--teal-light);color:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(26,122,110,.25)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.85);color:#fff;transform:translateY(-1px)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-deep);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--gray-mid)}
.btn-ghost:hover{background:var(--gray-light);color:var(--navy);transform:translateY(-1px)}

/* ---------- Nav ---------- */
.nav{
  position:fixed;
  inset:0 0 auto 0;
  height:74px;
  z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(226,231,238,.6);
  box-shadow:0 1px 0 rgba(13,27,62,.02);
}
.nav-inner{
  max-width:var(--container);
  height:100%;
  margin:0 auto;
  padding:0 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand:hover{color:var(--navy)}
.brand svg{flex-shrink:0}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text .b1{
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  color:var(--navy);
  letter-spacing:-0.01em;
}
.brand-text .b2{
  font-weight:500;
  font-size:11px;
  color:var(--teal);
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-top:2px;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
}
.nav-links a{
  color:var(--navy);
  font-weight:500;
  font-size:15px;
  position:relative;
  padding:6px 0;
}
.nav-links a:hover{color:var(--teal)}
.nav-links a.active{color:var(--teal)}
.nav-links a.active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:2px;
  background:var(--teal);
  border-radius:2px;
}
.nav-links .btn{padding:11px 22px;font-size:14px}

.hamburger{
  display:none;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  border-radius:8px;
}
.hamburger span{
  display:block;
  width:22px;
  height:2px;
  background:var(--navy);
  border-radius:2px;
  transition:all .25s var(--ease);
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:160px 0 110px;
  color:#fff;
  background:
    radial-gradient(ellipse at 75% 20%, rgba(26,122,110,.55), transparent 55%),
    linear-gradient(135deg, var(--navy) 0%, #16345A 50%, var(--teal) 100%);
  overflow:hidden;
  isolation:isolate;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.07'><path d='M0 30 L60 30'/><path d='M30 0 L30 60'/><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  pointer-events:none;
  z-index:-1;
}
.hero::after{
  content:"";
  position:absolute;
  bottom:-1px;left:0;right:0;
  height:80px;
  background:linear-gradient(to bottom, transparent, rgba(255,255,255,.04));
  pointer-events:none;
  z-index:-1;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:64px;
  align-items:center;
}
.hero h1{
  color:#fff;
  margin-bottom:24px;
  font-weight:400;
}
.hero h1 .accent{color:var(--teal-light)}
.hero .sub{
  color:rgba(255,255,255,.82);
  font-size:19px;
  line-height:1.6;
  margin-bottom:36px;
  max-width:560px;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero .eyebrow{color:var(--teal-light)}

.hero-card{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:var(--radius-lg);
  padding:36px;
  box-shadow:0 30px 60px rgba(0,0,0,.20);
}
.hero-card .eyebrow{margin-bottom:18px;color:var(--teal-light)}
.hero-card h3{color:#fff;font-family:var(--serif);font-size:22px;margin-bottom:18px}
.hero-card ul li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:rgba(255,255,255,.92);
  padding:11px 0;
  font-size:15px;
  border-top:1px solid rgba(255,255,255,.10);
}
.hero-card ul li:first-child{border-top:none;padding-top:4px}
.hero-card .tick{
  flex-shrink:0;
  width:20px;height:20px;
  color:var(--teal-light);
  margin-top:2px;
}

/* fade-up on load */
.fade-up{
  opacity:0;
  transform:translateY(20px);
  animation:fadeUp .9s var(--ease) forwards;
}
.fade-up.d1{animation-delay:.05s}
.fade-up.d2{animation-delay:.18s}
.fade-up.d3{animation-delay:.30s}
.fade-up.d4{animation-delay:.42s}
@keyframes fadeUp{
  to{opacity:1;transform:translateY(0)}
}

/* ---------- Page header ---------- */
.page-header{
  position:relative;
  background:
    radial-gradient(ellipse at 80% 30%, rgba(26,122,110,.45), transparent 55%),
    linear-gradient(135deg, var(--navy) 0%, #16345A 60%, var(--teal) 100%);
  color:#fff;
  padding:160px 0 80px;
  text-align:center;
  overflow:hidden;
  isolation:isolate;
}
.page-header::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.07'><path d='M0 30 L60 30'/><path d='M30 0 L30 60'/><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  pointer-events:none;
  z-index:-1;
}
.page-header .eyebrow{color:var(--teal-light)}
.page-header h1{color:#fff;margin-bottom:14px}
.page-header .sub{
  color:rgba(255,255,255,.82);
  font-size:19px;
  max-width:680px;
  margin:0 auto;
}

/* ---------- Cards (generic gradient-top hover) ---------- */
.card{
  position:relative;
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:34px 30px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:#d8dfe9;
}
.card:hover::before{transform:scaleX(1)}
.card h3{margin-bottom:10px}
.card p{color:var(--muted);font-size:15px;line-height:1.6}

/* ---------- "Why" stats grid ---------- */
.reality-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:64px;
  align-items:center;
}
.stat-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.stat{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:28px 26px;
  position:relative;
  overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.stat::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease);
}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover);border-color:#d8dfe9}
.stat:hover::before{transform:scaleX(1)}
.stat .num{
  font-family:var(--serif);
  font-size:46px;
  line-height:1;
  color:var(--navy);
  margin-bottom:10px;
  letter-spacing:-0.02em;
}
.stat p{color:var(--muted);font-size:14px;line-height:1.5;margin-bottom:0}
.stat .source{
  display:block;
  margin-top:10px;
  font-size:12px;
  color:var(--muted);
  opacity:.8;
  font-style:italic;
}
.reality-copy h2{margin-bottom:20px}
.reality-copy p{color:var(--body);font-size:17px;line-height:1.7}
.reality-copy p + p{margin-top:14px}

/* ---------- Journey card (Comply → Understand → Optimise → Grow) ---------- */
.journey-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.journey-copy h2{margin-bottom:20px}
.journey-copy p{color:var(--body);font-size:17px;line-height:1.7;margin-bottom:14px}
.journey-card{
  position:relative;
  background:linear-gradient(160deg, var(--navy) 0%, #16345A 60%, var(--teal) 130%);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:42px 38px;
  overflow:hidden;
  isolation:isolate;
  box-shadow:0 30px 60px rgba(13,27,62,.18);
}
.journey-card::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.08'><path d='M0 30 L60 30'/><path d='M30 0 L30 60'/><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  z-index:-1;
}
.journey-card .eyebrow{color:var(--teal-light)}
.journey-card h3{color:#fff;font-family:var(--serif);font-size:24px;margin-bottom:24px}
.journey-steps{display:flex;flex-direction:column;gap:0}
.step{
  display:flex;
  align-items:flex-start;
  gap:18px;
  position:relative;
  padding:16px 0;
}
.step:not(:last-child)::after{
  content:"";
  position:absolute;
  left:15px; top:48px; bottom:-4px;
  width:2px;
  background:linear-gradient(to bottom, var(--teal-light), rgba(255,255,255,.15));
}
.step-dot{
  flex-shrink:0;
  width:32px;
  height:32px;
  border-radius:50%;
  background:rgba(255,255,255,.10);
  border:1.5px solid var(--teal-light);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--teal-light);
  font-weight:600;
  font-size:14px;
  font-family:var(--sans);
  z-index:1;
}
.step-text h4{
  color:#fff;
  font-family:var(--serif);
  font-size:18px;
  font-weight:400;
  margin-bottom:4px;
}
.step-text p{
  color:rgba(255,255,255,.75);
  font-size:14px;
  margin-bottom:0;
  line-height:1.5;
}

/* ---------- Packages overview cards ---------- */
.pkg-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
  margin-top:48px;
}
.pkg-card{
  position:relative;
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:38px 32px;
  display:flex;
  flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  overflow:hidden;
}
.pkg-card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease);
}
.pkg-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-card-hover);
  border-color:#d8dfe9;
}
.pkg-card:hover::before{transform:scaleX(1)}
.pkg-card .badge{
  position:absolute;
  top:18px; right:22px;
  background:var(--teal);
  color:#fff;
  font-size:10px;
  font-weight:600;
  padding:6px 12px;
  border-radius:20px;
  letter-spacing:1px;
  text-transform:uppercase;
  font-family:var(--sans);
}
.pkg-card .pkg-eyebrow{
  font-size:12px;
  font-weight:600;
  color:var(--teal);
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-bottom:14px;
  display:block;
}
.pkg-card h3{margin-bottom:12px;font-size:26px}
.pkg-card .lead{color:var(--muted);font-size:15px;margin-bottom:22px;min-height:48px}
.pkg-card .price{
  font-family:var(--serif);
  font-size:34px;
  color:var(--navy);
  margin:14px 0 4px;
  letter-spacing:-0.02em;
}
.pkg-card .price small{
  font-family:var(--sans);
  font-size:14px;
  font-weight:400;
  color:var(--muted);
}
.pkg-card .fit{font-size:13px;color:var(--muted);margin-bottom:22px}
.pkg-card .learn{
  font-weight:600;
  color:var(--teal);
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:15px;
}
.pkg-card .learn:hover{color:var(--teal-light);gap:10px}

/* ---------- Tick lists ---------- */
.tick-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}
.tick-list li{
  position:relative;
  padding-left:34px;
  font-size:15px;
  line-height:1.75;
  color:var(--text);
}
.tick-list li svg{
  position:absolute;
  left:0;
  top:4px;
  width:20px;
  height:20px;
  color:var(--teal);
}
.tick-list li strong{display:inline;color:var(--navy)}

/* ---------- Sectors / Who we work with ---------- */
.who-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:22px;
  margin-top:14px;
}
.who-card{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:30px 26px;
  text-align:left;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;
  overflow:hidden;
}
.who-card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease);
}
.who-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-card-hover);
  border-color:#d8dfe9;
}
.who-card:hover::before{transform:scaleX(1)}
.who-card svg{
  width:34px;
  height:34px;
  color:var(--teal);
  margin-bottom:14px;
}
.who-card h4{font-size:16px;margin-bottom:6px}
.who-card p{font-size:14px;color:var(--muted);margin:0;line-height:1.5}

/* ---------- CTA strip ---------- */
.cta-strip{
  position:relative;
  background:
    radial-gradient(ellipse at 75% 30%, rgba(26,122,110,.55), transparent 55%),
    linear-gradient(135deg, var(--navy) 0%, #16345A 60%, var(--teal) 130%);
  color:#fff;
  text-align:center;
  padding:96px 0;
  overflow:hidden;
  isolation:isolate;
}
.cta-strip::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.07'><path d='M0 30 L60 30'/><path d='M30 0 L30 60'/><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  z-index:-1;
}
.cta-strip h2{color:#fff;margin-bottom:16px;max-width:780px;margin-left:auto;margin-right:auto}
.cta-strip p{color:rgba(255,255,255,.82);font-size:18px;max-width:640px;margin:0 auto 30px}
.cta-strip .cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-strip .info{
  display:flex;
  gap:34px;
  justify-content:center;
  flex-wrap:wrap;
  margin:24px 0 8px;
}
.cta-strip .info a{
  color:#fff;
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:16px;
}
.cta-strip .info a:hover{color:var(--teal-light)}
.cta-strip .info svg{width:20px;height:20px;color:var(--teal-light)}

/* ---------- Footer ---------- */
.footer{
  background:var(--navy-deep);
  color:rgba(255,255,255,.72);
  padding:72px 0 28px;
  font-size:14px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1.3fr;
  gap:48px;
  margin-bottom:48px;
}
.footer h4{
  color:#fff;
  font-family:var(--sans);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-weight:600;
  margin-bottom:18px;
}
.footer ul li{margin-bottom:10px}
.footer a{color:rgba(255,255,255,.72)}
.footer a:hover{color:var(--teal-light)}
.footer .brand-block .tag{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.footer .brand-block .tag-text{
  font-family:var(--serif);
  color:#fff;
  font-size:18px;
  letter-spacing:-0.01em;
}
.footer .brand-block p{
  color:rgba(255,255,255,.55);
  font-size:14px;
  line-height:1.6;
  max-width:300px;
}
.footer .legal{
  border-top:1px solid rgba(255,255,255,.10);
  padding-top:24px;
  font-size:12px;
  color:rgba(255,255,255,.45);
  text-align:center;
  line-height:1.7;
}

/* ---------- About specific ---------- */
.intro-block{max-width:820px;margin:0 auto;text-align:center}
.intro-block p{font-size:18px;color:var(--body);line-height:1.75}

.philo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  margin-top:14px;
}
.philo-card{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:34px 30px;
  position:relative;
  overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.philo-card::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--teal) 0%, var(--teal-light) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .45s var(--ease);
}
.philo-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:#d8dfe9}
.philo-card:hover::before{transform:scaleX(1)}
.philo-card .icon{
  width:46px;height:46px;
  border-radius:12px;
  background:var(--teal-pale);
  display:flex;align-items:center;justify-content:center;
  color:var(--teal);
  margin-bottom:18px;
}
.philo-card .icon svg{width:26px;height:26px}
.philo-card h3{font-size:21px;margin-bottom:10px}
.philo-card p{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:0}

.how-we-work{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-lg);
  padding:48px;
  max-width:900px;
  margin:0 auto;
  box-shadow:var(--shadow-card);
}
.how-we-work h3{margin-bottom:14px;font-size:24px}
.how-we-work .lead{font-size:17px;color:var(--body);margin-bottom:24px;line-height:1.7}
.reg-block{
  background:var(--teal-pale);
  border-left:4px solid var(--teal);
  padding:28px 32px;
  border-radius:0 var(--radius) var(--radius) 0;
  max-width:820px;
  margin:0 auto;
}
.reg-block h3{margin-bottom:10px;font-size:20px}
.reg-block p{color:var(--body);font-size:15px;line-height:1.7;margin-bottom:0}

/* ---------- Packages page ---------- */
.pkg-detail{padding:96px 0}
.pkg-detail .lead{
  color:var(--muted);
  font-size:18px;
  max-width:740px;
  margin:0 0 36px 0;
  line-height:1.65;
}
.pkg-detail-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:56px;
  align-items:start;
}
.included-block h3{margin-bottom:14px;font-size:20px}
.fit-block{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius);
  padding:32px 30px;
  position:sticky;
  top:96px;
}
.fit-block .price{
  font-family:var(--serif);
  font-size:42px;
  color:var(--navy);
  letter-spacing:-0.02em;
  line-height:1;
  margin-bottom:6px;
}
.fit-block .price small{
  font-family:var(--sans);
  font-size:14px;
  color:var(--muted);
  font-weight:400;
}
.fit-block .pricing-note{font-size:13px;color:var(--muted);margin-bottom:22px}
.fit-block h4{font-size:14px;text-transform:uppercase;letter-spacing:1.2px;color:var(--teal);font-weight:600;margin-bottom:8px}
.fit-block p{font-size:15px;color:var(--body);margin-bottom:18px}
.fit-block .btn{width:100%;margin-top:8px}

.callout{
  background:var(--teal-pale);
  border-left:4px solid var(--teal);
  padding:20px 24px;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  margin:18px 0;
  color:var(--body);
  font-size:15px;
  line-height:1.6;
}

/* ---------- Pricing calculator ---------- */
.calc-intro{max-width:740px;margin:0 auto 44px;text-align:center}
.calc-intro p{color:var(--body);font-size:17px;line-height:1.7;margin-bottom:14px}
.calc{
  max-width:920px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-lg);
  padding:44px;
  box-shadow:var(--shadow-card);
}
.calc-row{margin-bottom:24px}
.calc-row label{
  display:block;
  font-weight:600;
  color:var(--navy);
  margin-bottom:9px;
  font-size:14px;
}
.calc-row select,
.calc-row input[type="number"]{
  width:100%;
  padding:13px 16px;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-sm);
  font-size:15px;
  font-family:inherit;
  color:var(--body);
  background:#fff;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.calc-row select:focus,
.calc-row input:focus{
  outline:none;
  border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(26,122,110,.12);
}

.pkg-pick{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.pkg-pick button{
  padding:18px 16px;
  border:2px solid var(--gray-mid);
  background:#fff;
  border-radius:var(--radius-sm);
  text-align:left;
  transition:all .25s var(--ease);
}
.pkg-pick button:hover{border-color:var(--teal-light)}
.pkg-pick button.active{border-color:var(--teal);background:var(--teal-pale)}
.pkg-pick .pn{font-weight:600;color:var(--navy);font-size:15px;display:block}
.pkg-pick .pd{font-size:12px;color:var(--muted);display:block;margin-top:4px}

.toggle-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  border-top:1px solid var(--gray-mid);
}
.toggle-row:first-of-type{border-top:none}
.toggle-row label{margin:0;font-weight:600;color:var(--navy)}
.switch{position:relative;width:48px;height:28px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.slider{
  position:absolute;
  cursor:pointer;
  inset:0;
  background:#cbd5e0;
  border-radius:28px;
  transition:.25s var(--ease);
}
.slider::before{
  content:"";
  position:absolute;
  height:22px;width:22px;
  left:3px;top:3px;
  background:#fff;
  border-radius:50%;
  transition:.25s var(--ease);
  box-shadow:0 2px 6px rgba(0,0,0,.18);
}
.switch input:checked + .slider{background:var(--teal)}
.switch input:checked + .slider::before{transform:translateX(20px)}
.sub-input{margin-top:12px;display:none}
.sub-input.show{display:block}

.result{
  background:linear-gradient(160deg, var(--navy) 0%, #16345A 100%);
  color:#fff;
  border-radius:var(--radius);
  padding:32px;
  margin-top:32px;
  position:relative;
  overflow:hidden;
}
.result::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.05'><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  pointer-events:none;
}
.result > *{position:relative}
.result-line{
  display:flex;
  justify-content:space-between;
  padding:9px 0;
  color:rgba(255,255,255,.85);
  font-size:14px;
}
.result-line.tot{
  border-top:1px solid rgba(255,255,255,.20);
  margin-top:14px;
  padding-top:18px;
  font-size:30px;
  font-weight:400;
  font-family:var(--serif);
  color:#fff;
  letter-spacing:-0.01em;
}
.result-line.ann{
  color:var(--teal-light);
  font-size:14px;
  justify-content:flex-end;
}
.disclaimer{
  font-size:12px;
  color:var(--muted);
  margin-top:16px;
  text-align:center;
  line-height:1.6;
}
.trust-dots{
  display:flex;
  justify-content:center;
  gap:24px;
  margin-top:24px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:13px;
}
.trust-dots span:not(:last-child)::after{
  content:"·";
  margin-left:24px;
  color:var(--teal);
}

/* ---------- Contact ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:60px;
  align-items:start;
}
.contact-info h2{margin-bottom:14px}
.contact-info p{color:var(--body);font-size:16px;line-height:1.7}
.contact-info .channels{margin-top:24px}
.contact-info .channels a{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 0;
  color:var(--body);
  font-size:16px;
  border-bottom:1px solid var(--gray-mid);
}
.contact-info .channels a:last-child{border-bottom:none}
.contact-info .channels a:hover{color:var(--teal)}
.contact-info .channels svg{
  width:22px;height:22px;
  color:var(--teal);
  flex-shrink:0;
}
.calendly-cta{
  background:var(--teal-pale);
  border:1px solid rgba(26,122,110,.18);
  border-radius:var(--radius);
  padding:28px 30px;
  margin-top:24px;
}
.calendly-cta h4{color:var(--navy);font-size:17px;margin-bottom:8px}
.calendly-cta p{font-size:14px;color:var(--body);margin-bottom:14px}

.contact-form{
  background:#fff;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-lg);
  padding:42px;
  box-shadow:var(--shadow-card);
}
.contact-form h2{margin-bottom:8px;font-size:28px}
.contact-form .form-intro{
  color:var(--muted);
  font-size:14px;
  margin-bottom:24px;
}
.form-row{margin-bottom:18px}
.form-row label{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--navy);
  margin-bottom:7px;
}
.form-row input,
.form-row select,
.form-row textarea{
  width:100%;
  padding:12px 15px;
  border:1px solid var(--gray-mid);
  border-radius:var(--radius-sm);
  font-family:inherit;
  font-size:15px;
  color:var(--body);
  background:#fff;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{
  outline:none;
  border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(26,122,110,.12);
}
.form-row textarea{resize:vertical;min-height:120px}
.thanks{
  background:var(--teal-pale);
  border:1px solid rgba(26,122,110,.25);
  border-left:4px solid var(--teal);
  padding:24px 28px;
  border-radius:var(--radius);
  color:var(--navy);
  font-weight:500;
  font-size:16px;
}

.location-card{
  background:linear-gradient(160deg, var(--navy) 0%, #16345A 100%);
  color:#fff;
  border-radius:var(--radius);
  padding:48px 32px;
  text-align:center;
  margin-top:60px;
  position:relative;
  overflow:hidden;
}
.location-card::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><g fill='none' stroke='%23ffffff' stroke-width='0.6' stroke-opacity='0.06'><path d='M0 30 L60 30'/><path d='M30 0 L30 60'/><path d='M0 0 L60 60'/><path d='M60 0 L0 60'/></g></svg>");
  background-size:60px 60px;
  pointer-events:none;
}
.location-card svg{
  width:36px;height:36px;
  color:var(--teal-light);
  margin:0 auto 14px;
  position:relative;
}
.location-card p{
  color:#fff;
  font-size:18px;
  margin:0;
  position:relative;
}
.location-card .loc-sub{
  color:rgba(255,255,255,.7);
  font-size:14px;
  margin-top:6px;
}

/* ---------- Privacy / legal pages ---------- */
.legal-content{
  max-width:780px;
  margin:0 auto;
}
.legal-content .draft-banner{
  background:#FFF7E6;
  border-left:4px solid #D97706;
  padding:20px 24px;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  margin-bottom:36px;
  color:#7C4A03;
  font-size:14px;
  line-height:1.6;
}
.legal-content h2{
  font-size:24px;
  margin-top:36px;
  margin-bottom:12px;
}
.legal-content h2:first-child{margin-top:0}
.legal-content p{font-size:15px;color:var(--body);line-height:1.75}
.legal-content ul{margin:12px 0 14px 24px;list-style:disc}
.legal-content ul li{font-size:15px;color:var(--body);line-height:1.7;margin-bottom:6px}

/* ---------- MTD strip ---------- */
.mtd{
  background:var(--navy-deep);
  color:#fff;
  padding:24px 0;
  text-align:center;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mtd p{margin:0;font-size:15px;color:rgba(255,255,255,.85)}
.mtd a{color:var(--teal-light);font-weight:600;margin-left:6px}
.mtd a:hover{color:#fff}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  section{padding:72px 0}
  .hero{padding:130px 0 72px}
  .page-header{padding:130px 0 64px}
  .hero-grid,
  .reality-grid,
  .journey-grid,
  .pkg-grid,
  .pkg-detail-grid,
  .contact-grid,
  .footer-grid,
  .philo-grid,
  .who-grid{grid-template-columns:1fr;gap:36px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:16px}
  .who-grid{grid-template-columns:1fr 1fr}
  .fit-block{position:static}
  .nav-links{
    display:none;
    position:fixed;
    top:74px; left:0; right:0;
    background:#fff;
    flex-direction:column;
    align-items:flex-start;
    padding:24px 28px;
    gap:18px;
    border-bottom:1px solid var(--gray-mid);
    box-shadow:0 14px 30px rgba(13,27,62,.10);
  }
  .nav-links.open{display:flex}
  .nav-links a.active::after{display:none}
  .nav-links li{width:100%}
  .nav-links .btn{width:100%;justify-content:center}
  .hamburger{display:flex}
  .hero-card{padding:28px}
  .calc{padding:30px 24px}
  .contact-form{padding:30px 24px}
  .how-we-work{padding:32px 26px}
  .journey-card{padding:34px 28px}
}

@media (max-width:600px){
  .container{padding:0 22px}
  .nav-inner{padding:0 22px}
  h1{font-size:34px}
  h2{font-size:26px}
  .stat-grid,.who-grid{grid-template-columns:1fr}
  .pkg-pick{grid-template-columns:1fr}
  .hero{padding:120px 0 60px}
  .page-header{padding:120px 0 56px}
  section{padding:60px 0}
  .hero .sub{font-size:17px}
  .calc{padding:26px 20px}
  .contact-form{padding:26px 20px}
  .how-we-work{padding:28px 22px}
  .pkg-detail .lead{font-size:16px}
  .stat .num{font-size:38px}
  .cta-strip{padding:72px 0}
  .footer{padding:56px 0 24px}
  .footer-grid{gap:36px}
}
