:root{
  --navy-950:#070E1C;
  --navy-900:#0A1628;
  --navy-800:#0F2747;
  --navy-700:#163760;
  --steel:#2E4F7A;
  --ice:#9FC5F8;
  --ice-2:#C9DEF7;
  --bone:#F4F1EC;
  --bone-2:#EAE5DC;
  --white:#FFFFFF;
  --line: rgba(159,197,248,.18);
  --line-strong: rgba(159,197,248,.35);
  --gold:#C9A961;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter', sans-serif;
  background:var(--navy-900);
  color:var(--bone);
  line-height:1.55;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--ice);color:var(--navy-900)}
h1,h2,h3,h4{font-family:'Inter Tight', sans-serif;font-weight:500;letter-spacing:-0.02em;line-height:1.05}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1340px;margin:0 auto;padding:0 40px}
@media(max-width:720px){.container{padding:0 22px}}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:103;
  padding:22px 0;
  background:rgba(7,14,28,.72);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  width:38px;height:38px;border:1px solid var(--ice);
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter Tight';font-weight:500;color:var(--ice);
  font-size:14px;letter-spacing:.04em;
}
.brand-text{font-family:'Inter Tight';font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--bone)}
.brand-text small{display:block;font-size:10px;letter-spacing:.3em;color:var(--ice);opacity:.75;margin-top:3px;font-weight:400}
.nav-links{display:flex;gap:42px;list-style:none}
.nav-links a{font-size:13px;letter-spacing:.06em;color:var(--bone-2);transition:color .3s}
.nav-links a:hover, .nav-links a.is-active{color:var(--ice)}
.nav-cta{
  padding:11px 22px;border:1px solid var(--ice);color:var(--ice);
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  transition:all .3s;
}
.nav-cta:hover{background:var(--ice);color:var(--navy-900)}
.burger{display:none;width:28px;height:18px;position:relative;cursor:pointer;background:transparent;border:none;padding:0;-webkit-appearance:none;appearance:none;z-index:102}
.burger span{position:absolute;left:0;right:0;height:1px;background:var(--bone);transition:transform .35s ease, opacity .25s ease, top .35s ease, bottom .35s ease}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:50%}
.burger span:nth-child(3){bottom:0}
.burger.is-open span:nth-child(1){top:50%;transform:rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){bottom:50%;transform:rotate(-45deg)}
@media(max-width:920px){
  .nav-links,.nav-cta{display:none}
  .burger{display:block}
}

/* ============ MOBILE DRAWER (fullscreen) ============ */
.nav-drawer{
  position:fixed;inset:0;z-index:101;
  background:rgba(7,14,28,.98);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;flex-direction:column;
  padding:104px 28px 40px;
  transform:translateY(-100%);
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
  pointer-events:none;
  visibility:hidden;
}
.nav-drawer.is-open{transform:translateY(0);pointer-events:auto;visibility:visible}
.nav-drawer-list{list-style:none;display:flex;flex-direction:column;gap:2px;margin-bottom:auto}
.nav-drawer-list a{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 4px;font-family:'Inter Tight';font-size:24px;font-weight:400;
  color:var(--bone);letter-spacing:-0.015em;
  border-bottom:1px solid var(--line);
  transition:color .3s, padding-left .3s;
  min-height:60px;
}
.nav-drawer-list a:hover, .nav-drawer-list a:active{color:var(--ice);padding-left:8px}
.nav-drawer-list a::after{content:'→';font-size:18px;color:var(--ice);opacity:.5}
.nav-drawer-sub{
  font-family:'Inter Tight';font-size:11px;letter-spacing:.28em;color:var(--ice);
  text-transform:uppercase;font-weight:500;margin:32px 0 12px;opacity:.7;
}
.nav-drawer-cta{
  margin-top:24px;
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;background:#25D366;color:#fff;
  border-radius:0;
}
.nav-drawer-cta svg{width:24px;height:24px;fill:#fff;flex-shrink:0}
.nav-drawer-cta .lbl{display:block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:.9;font-weight:500;margin-bottom:2px}
.nav-drawer-cta .num{display:block;font-family:'Inter Tight';font-size:17px;font-weight:500}
body.menu-open{overflow:hidden}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 32px;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:500;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
  cursor:pointer;border:none;font-family:inherit;
}
.btn-primary{background:var(--ice);color:var(--navy-900)}
.btn-primary:hover{background:var(--bone);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--bone);border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--ice);color:var(--ice)}
.btn .arrow{transition:transform .35s}
.btn:hover .arrow{transform:translateX(4px)}

/* ============ HERO HOME ============ */
.hero{
  min-height:100vh;
  padding:110px 0 60px;
  position:relative;
  background:
    radial-gradient(ellipse 80% 60% at 80% 20%, rgba(46,79,122,.4), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 80%, rgba(22,55,96,.5), transparent 60%),
    var(--navy-900);
  display:flex;align-items:center;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(159,197,248,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(159,197,248,.04) 1px, transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;position:relative;z-index:2;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ice);margin-bottom:28px;font-weight:500;
}
.hero-eyebrow::before{content:'';width:34px;height:1px;background:var(--ice)}
.hero h1{
  font-size:clamp(40px,5.6vw,82px);
  font-weight:400;
  color:var(--bone);
  margin-bottom:24px;
  letter-spacing:-0.03em;
}
.hero h1 em{
  font-style:normal;font-weight:300;
  color:var(--ice);
  display:block;
}
.hero-sub{
  font-size:17px;color:var(--ice-2);
  max-width:540px;line-height:1.55;
  margin-bottom:32px;
  font-weight:300;
}
.hero-ctas{display:flex;gap:18px;flex-wrap:wrap;align-items:center}

.hero-card{
  position:relative;
  padding:36px 32px;
  background:linear-gradient(180deg, rgba(159,197,248,.06), rgba(159,197,248,.02));
  border:1px solid var(--line);
}
.hero-card::before{
  content:'';position:absolute;top:-1px;left:-1px;width:60px;height:60px;
  border-top:1px solid var(--ice);border-left:1px solid var(--ice);
}
.hero-card::after{
  content:'';position:absolute;bottom:-1px;right:-1px;width:60px;height:60px;
  border-bottom:1px solid var(--ice);border-right:1px solid var(--ice);
}
.hero-card h3{font-size:13px;letter-spacing:.24em;color:var(--ice);text-transform:uppercase;margin-bottom:22px;font-weight:500}
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:22px 20px}
.stat .num{font-family:'Inter Tight';font-size:36px;font-weight:300;color:var(--bone);line-height:1;letter-spacing:-0.03em}
.stat .num span{color:var(--ice);font-size:24px;vertical-align:top;margin-left:2px}
.stat .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ice-2);margin-top:10px;opacity:.75}

@media(max-width:960px){
  .hero{padding:140px 0 80px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-sub{font-size:16px}
}

/* ============ PAGE HERO (interior) ============ */
.page-hero{
  padding:200px 0 120px;
  background:
    radial-gradient(ellipse 70% 60% at 80% 20%, rgba(46,79,122,.35), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(22,55,96,.45), transparent 60%),
    var(--navy-900);
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(159,197,248,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(159,197,248,.04) 1px, transparent 1px);
  background-size:80px 80px;pointer-events:none;
}
.breadcrumb{
  display:flex;gap:10px;align-items:center;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ice-2);margin-bottom:36px;position:relative;z-index:2;
  opacity:.8;
}
.breadcrumb a{color:var(--ice);transition:opacity .3s}
.breadcrumb a:hover{opacity:.7}
.breadcrumb .sep{color:var(--line-strong)}
.page-hero h1{
  font-size:clamp(40px,6.4vw,84px);
  font-weight:400;color:var(--bone);
  letter-spacing:-0.03em;line-height:1.04;
  margin-bottom:32px;max-width:1000px;
  position:relative;z-index:2;
}
.page-hero h1 em{font-style:normal;color:var(--ice);font-weight:300}
.page-hero .lead{
  font-size:19px;color:var(--ice-2);
  max-width:720px;line-height:1.65;
  margin-bottom:48px;font-weight:300;
  position:relative;z-index:2;
}
.page-hero .hero-ctas{position:relative;z-index:2}
@media(max-width:720px){.page-hero{padding:140px 0 80px}.page-hero .lead{font-size:16px}}

/* ============ SECTION BASE ============ */
section{position:relative}
.section-head{margin-bottom:80px;max-width:780px}
.section-num{font-size:11px;letter-spacing:.32em;color:var(--ice);text-transform:uppercase;font-weight:500;margin-bottom:24px;display:block}
.section-num::before{content:'— '}
.section-title{font-size:clamp(36px,5vw,68px);font-weight:400;color:var(--bone);margin-bottom:24px;letter-spacing:-0.025em}
.section-title em{font-style:normal;color:var(--ice);font-weight:300}
.section-lead{font-size:17px;color:var(--ice-2);max-width:640px;line-height:1.65;font-weight:300}

/* ============ ABOUT (home) ============ */
.about{padding:140px 0;background:var(--navy-950);border-top:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:96px;align-items:start}
.about-portrait{
  aspect-ratio:3/4;
  background:var(--navy-800);
  position:sticky;top:110px;
  overflow:hidden;border:1px solid var(--line);
}
.about-portrait img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center top;
  filter:saturate(.92) contrast(1.02);
}
.about-portrait::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(7,14,28,0) 35%, rgba(7,14,28,.55) 75%, rgba(7,14,28,.92) 100%);
  pointer-events:none;
}
.portrait-tag{
  position:absolute;left:28px;right:28px;bottom:28px;z-index:2;
  font-family:'Inter Tight';font-size:14px;letter-spacing:.04em;color:var(--bone);
  font-weight:500;
  padding-top:18px;border-top:1px solid rgba(244,241,236,.35);
}
.portrait-tag span{display:block;color:var(--ice);font-size:10px;margin-top:6px;letter-spacing:.24em;text-transform:uppercase;font-weight:400;opacity:.95}
.about-body p{font-size:17px;color:var(--ice-2);margin-bottom:22px;line-height:1.7;font-weight:300}
.about-body p:first-of-type::first-letter{
  font-family:'Inter Tight';font-size:64px;font-weight:300;color:var(--ice);
  float:left;line-height:.9;margin:6px 14px 0 0;letter-spacing:-0.02em;
}
.about-pillars{margin-top:48px;display:grid;grid-template-columns:1fr 1fr;gap:28px}
.pillar{border-top:1px solid var(--line-strong);padding-top:20px}
.pillar-k{font-family:'Inter Tight';font-size:28px;font-weight:400;color:var(--bone);letter-spacing:-0.02em}
.pillar-l{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ice);margin-top:8px;opacity:.85}

.formacion{margin-top:64px;padding-top:48px;border-top:1px solid var(--line-strong)}
.formacion-label{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ice);font-weight:500;display:block;margin-bottom:28px}
.formacion-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.formacion-card{
  display:flex;gap:22px;align-items:center;
  padding:24px 22px;
  background:linear-gradient(180deg, rgba(159,197,248,.05), rgba(159,197,248,.01));
  border:1px solid var(--line);
  transition:border-color .35s, transform .35s;
}
.formacion-card:hover{border-color:var(--ice);transform:translateY(-2px)}
.formacion-logo{
  width:62px;height:62px;flex-shrink:0;
  background:var(--bone);border-radius:2px;
  display:flex;align-items:center;justify-content:center;padding:8px;
}
.formacion-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.formacion-title{font-family:'Inter Tight';font-size:15px;color:var(--bone);font-weight:500;line-height:1.3;letter-spacing:-0.01em}
.formacion-school{font-size:12px;color:var(--ice-2);margin-top:6px;letter-spacing:.04em;opacity:.85;font-weight:300}
@media(max-width:760px){.formacion-grid{grid-template-columns:1fr}}
@media(max-width:920px){.about{padding:90px 0}.about-grid{grid-template-columns:1fr;gap:56px}}

/* ============ PRACTICE LIST (home) ============ */
.practice{padding:140px 0;background:var(--navy-900)}
.practice-list{border-top:1px solid var(--line-strong)}
.practice-item{
  border-bottom:1px solid var(--line-strong);
  padding:48px 0;
  display:grid;grid-template-columns:80px 1fr 2fr 60px;
  gap:48px;align-items:start;
  transition:padding .4s;
}
.practice-item:hover{padding-left:18px}
.pi-num{font-family:'Inter Tight';font-size:14px;color:var(--ice);letter-spacing:.04em;padding-top:6px;opacity:.7}
.pi-title{font-family:'Inter Tight';font-size:28px;font-weight:400;color:var(--bone);letter-spacing:-0.02em;line-height:1.15;padding-top:2px}
.pi-body{display:flex;flex-direction:column;gap:18px}
.pi-desc{font-size:15px;color:var(--ice-2);line-height:1.65;font-weight:300}
.pi-bullets{list-style:none;display:grid;gap:9px;padding:0;margin:0}
.pi-bullets li{
  position:relative;padding-left:22px;
  font-size:14px;color:var(--bone-2);line-height:1.55;font-weight:300;
}
.pi-bullets li::before{
  content:'';position:absolute;left:0;top:9px;
  width:10px;height:1px;background:var(--ice);
}
.pi-tag{
  display:block;margin-top:6px;
  font-size:12.5px;color:var(--ice);letter-spacing:.01em;
  font-style:italic;font-weight:400;line-height:1.55;
  padding-left:14px;border-left:1px solid var(--ice);
}
.pi-cta{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ice);margin-top:6px;display:inline-flex;align-items:center;gap:10px}
.pi-cta:hover{color:var(--bone)}
.pi-arrow{
  width:48px;height:48px;border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  color:var(--ice);transition:all .35s;
  margin-top:2px;
}
.practice-item:hover .pi-arrow{background:var(--ice);color:var(--navy-900);border-color:var(--ice)}
@media(max-width:920px){
  .practice{padding:90px 0}
  .practice-item{grid-template-columns:48px 1fr;gap:20px}
  .pi-body,.pi-arrow{grid-column:1/-1}
  .pi-arrow{justify-self:start;margin-top:8px}
  .pi-title{font-size:22px}
}

/* ============ METHOD ============ */
.method{padding:140px 0;background:var(--navy-950);border-top:1px solid var(--line)}
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-strong);border:1px solid var(--line-strong)}
.method-step{background:var(--navy-950);padding:48px 36px;min-height:320px;display:flex;flex-direction:column;justify-content:space-between;transition:background .4s}
.method-step:hover{background:var(--navy-800)}
.ms-num{font-family:'Inter Tight';font-size:14px;color:var(--ice);letter-spacing:.2em;font-weight:500}
.ms-num::before{content:'';display:inline-block;width:24px;height:1px;background:var(--ice);margin-right:14px;vertical-align:middle}
.ms-title{font-family:'Inter Tight';font-size:24px;font-weight:400;color:var(--bone);margin-top:auto;margin-bottom:18px;letter-spacing:-0.02em;line-height:1.2}
.ms-desc{font-size:14px;color:var(--ice-2);line-height:1.6;font-weight:300}
@media(max-width:1024px){.method-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.method-grid{grid-template-columns:1fr}.method{padding:90px 0}}

/* ============ QUOTE ============ */
.quote{padding:160px 0;background:var(--navy-900);text-align:center;position:relative;overflow:hidden}
.quote::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%, rgba(46,79,122,.35), transparent 70%);pointer-events:none}
.quote-text{font-family:'Inter Tight';font-weight:300;font-size:clamp(28px,4vw,52px);color:var(--bone);max-width:1000px;margin:0 auto;letter-spacing:-0.025em;line-height:1.25;position:relative}
.quote-text em{font-style:normal;color:var(--ice);font-weight:400}
.quote-author{margin-top:42px;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--ice);position:relative}
.quote-author::before{content:'';display:block;width:42px;height:1px;background:var(--ice);margin:0 auto 22px}

/* ============ DIFFERENTIALS ============ */
.diff{padding:140px 0;background:var(--navy-950);border-top:1px solid var(--line)}
.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.diff-card{
  padding:48px 36px;
  background:linear-gradient(180deg, rgba(159,197,248,.04), transparent);
  border:1px solid var(--line);
  position:relative;transition:all .4s;
}
.diff-card:hover{border-color:var(--ice);transform:translateY(-4px)}
.diff-icon{
  width:52px;height:52px;border:1px solid var(--ice);
  display:flex;align-items:center;justify-content:center;
  color:var(--ice);margin-bottom:32px;
}
.diff-title{font-family:'Inter Tight';font-size:22px;font-weight:500;color:var(--bone);margin-bottom:14px;letter-spacing:-0.015em}
.diff-desc{font-size:14.5px;color:var(--ice-2);line-height:1.65;font-weight:300}
@media(max-width:920px){.diff{padding:90px 0}.diff-grid{grid-template-columns:1fr;gap:24px}}

/* ============ CONTACT ============ */
.contact{padding:160px 0 140px;background:var(--navy-900);border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start}
.contact h2{font-size:clamp(40px,5.5vw,76px);font-weight:400;letter-spacing:-0.03em;color:var(--bone);margin-bottom:32px;line-height:1}
.contact h2 em{font-style:normal;color:var(--ice);font-weight:300;display:block}
.contact-intro{font-size:17px;color:var(--ice-2);line-height:1.7;margin-bottom:48px;font-weight:300;max-width:480px}
.contact-info{display:grid;gap:28px}
.ci-item{border-top:1px solid var(--line-strong);padding-top:18px}
.ci-label{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ice);margin-bottom:10px;opacity:.85}
.ci-value{font-family:'Inter Tight';font-size:20px;color:var(--bone);font-weight:400;letter-spacing:-0.01em}
.ci-value a:hover{color:var(--ice)}
.form{display:grid;gap:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.field{display:flex;flex-direction:column;gap:10px}
.field label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ice);font-weight:500}
.field input, .field select, .field textarea{
  background:transparent;border:none;border-bottom:1px solid var(--line-strong);
  padding:14px 0;font-family:inherit;font-size:15px;color:var(--bone);
  transition:border-color .3s;font-weight:300;
}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-bottom-color:var(--ice)}
.field textarea{resize:vertical;min-height:110px}
.field select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--ice) 50%),linear-gradient(135deg, var(--ice) 50%, transparent 50%);background-position:calc(100% - 14px) center, calc(100% - 8px) center;background-size:6px 6px;background-repeat:no-repeat;padding-right:30px}
.field select option{background:var(--navy-900);color:var(--bone)}
.form .btn{margin-top:10px;justify-self:start}
.form-disclaimer{font-size:12px;color:var(--ice-2);opacity:.6;margin-top:18px;line-height:1.5}
@media(max-width:920px){.contact{padding:90px 0}.contact-grid{grid-template-columns:1fr;gap:56px}.form-row{grid-template-columns:1fr}}

/* ============ SERVICE PAGE BLOCKS ============ */
.svc-section{padding:120px 0;border-top:1px solid var(--line)}
.svc-section.alt{background:var(--navy-950)}
.svc-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:96px;align-items:start}
.svc-grid .lbl{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--ice);font-weight:500;position:sticky;top:120px}
.svc-grid h2{font-family:'Inter Tight';font-size:clamp(32px,4vw,48px);font-weight:400;color:var(--bone);letter-spacing:-0.025em;margin-bottom:28px;line-height:1.1}
.svc-grid h2 em{font-style:normal;color:var(--ice);font-weight:300}
.svc-grid p{font-size:16.5px;color:var(--ice-2);line-height:1.75;margin-bottom:20px;font-weight:300}
.svc-grid p strong{color:var(--bone);font-weight:500}
@media(max-width:920px){.svc-section{padding:80px 0}.svc-grid{grid-template-columns:1fr;gap:36px}.svc-grid .lbl{position:static}}

/* Service detail cards */
.svc-cards{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-strong);border:1px solid var(--line-strong);margin-top:24px}
.svc-card{background:var(--navy-900);padding:36px 32px;transition:background .35s}
.svc-section.alt .svc-card{background:var(--navy-950)}
.svc-card:hover{background:var(--navy-800)}
.svc-card .k{font-family:'Inter Tight';font-size:12px;color:var(--ice);letter-spacing:.22em;text-transform:uppercase;font-weight:500;margin-bottom:18px;display:block}
.svc-card h3{font-family:'Inter Tight';font-size:20px;font-weight:500;color:var(--bone);letter-spacing:-0.015em;margin-bottom:14px;line-height:1.25}
.svc-card p{font-size:14.5px;color:var(--ice-2);line-height:1.6;font-weight:300}
@media(max-width:720px){.svc-cards{grid-template-columns:1fr}}

/* Legal framework citations */
.framework{display:grid;gap:24px;margin-top:12px}
.fw-item{
  display:grid;grid-template-columns:140px 1fr;gap:36px;
  padding:24px 0;border-bottom:1px solid var(--line);
}
.fw-item:last-child{border-bottom:none}
.fw-k{font-family:'Inter Tight';font-size:15px;color:var(--ice);font-weight:500;letter-spacing:-0.005em}
.fw-v{font-size:14.5px;color:var(--bone-2);line-height:1.65;font-weight:300}
.fw-v strong{color:var(--bone);font-weight:500}
@media(max-width:720px){.fw-item{grid-template-columns:1fr;gap:6px;padding:18px 0}}

/* FAQ */
.faq-list{display:grid;gap:0;border-top:1px solid var(--line-strong);margin-top:12px}
.faq-item{border-bottom:1px solid var(--line-strong);padding:0}
.faq-item details{padding:28px 0}
.faq-item summary{
  cursor:pointer;list-style:none;
  font-family:'Inter Tight';font-size:19px;font-weight:500;
  color:var(--bone);letter-spacing:-0.01em;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  transition:color .3s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--ice)}
.faq-item summary::after{content:'+';font-family:'Inter Tight';font-size:28px;color:var(--ice);font-weight:300;transition:transform .35s}
.faq-item details[open] summary::after{transform:rotate(45deg)}
.faq-item details[open] summary{color:var(--ice)}
.faq-item .faq-a{margin-top:18px;font-size:15.5px;color:var(--ice-2);line-height:1.7;font-weight:300;max-width:820px}
.faq-item .faq-a p{margin-bottom:12px}
.faq-item .faq-a p:last-child{margin-bottom:0}

/* CTA strip */
.cta-strip{padding:120px 0;background:var(--navy-950);border-top:1px solid var(--line);text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 50% 50%, rgba(46,79,122,.4), transparent 70%);pointer-events:none}
.cta-strip h2{font-family:'Inter Tight';font-size:clamp(34px,5vw,58px);font-weight:400;color:var(--bone);letter-spacing:-0.025em;margin-bottom:24px;line-height:1.1;position:relative}
.cta-strip h2 em{font-style:normal;color:var(--ice);font-weight:300}
.cta-strip p{font-size:17px;color:var(--ice-2);max-width:620px;margin:0 auto 40px;line-height:1.65;font-weight:300;position:relative}
.cta-strip .btn{position:relative}

/* Related practice areas */
.related{padding:120px 0;background:var(--navy-900);border-top:1px solid var(--line)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.related-card{
  display:block;padding:32px 28px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(159,197,248,.03), transparent);
  transition:all .4s;
}
.related-card:hover{border-color:var(--ice);transform:translateY(-3px)}
.related-card .rk{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ice);font-weight:500;margin-bottom:18px;display:block}
.related-card h3{font-family:'Inter Tight';font-size:20px;font-weight:500;color:var(--bone);margin-bottom:10px;letter-spacing:-0.015em}
.related-card p{font-size:14px;color:var(--ice-2);line-height:1.55;font-weight:300;margin-bottom:18px}
.related-card .arrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ice)}
@media(max-width:920px){.related-grid{grid-template-columns:1fr}}

/* ============ FOOTER ============ */
.footer{padding:80px 0 36px;background:var(--navy-950);border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.footer-col h4{font-family:'Inter Tight';font-size:12px;letter-spacing:.28em;color:var(--ice);text-transform:uppercase;font-weight:500;margin-bottom:24px}
.footer-col ul{list-style:none;display:grid;gap:12px}
.footer-col li a{font-size:13.5px;color:var(--bone-2);font-weight:300;opacity:.85;transition:color .3s, opacity .3s}
.footer-col li a:hover{color:var(--ice);opacity:1}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.footer-tag{font-size:13.5px;color:var(--ice-2);line-height:1.65;font-weight:300;max-width:340px;opacity:.8}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.footer-bottom p{font-size:12px;color:var(--ice-2);opacity:.6;letter-spacing:.04em}
.footer-mini{display:flex;gap:24px;list-style:none}
.footer-mini a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ice-2);opacity:.65;transition:opacity .3s}
.footer-mini a:hover{opacity:1;color:var(--ice)}
@media(max-width:920px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr}}

/* ============ WHATSAPP ============ */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:95;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.4), 0 0 0 0 rgba(37,211,102,.5);
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
  animation:wa-pulse 2.4s ease-out infinite;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff}
@keyframes wa-pulse{
  0%{box-shadow:0 10px 30px rgba(37,211,102,.4), 0 0 0 0 rgba(37,211,102,.5)}
  70%{box-shadow:0 10px 30px rgba(37,211,102,.4), 0 0 0 18px rgba(37,211,102,0)}
  100%{box-shadow:0 10px 30px rgba(37,211,102,.4), 0 0 0 0 rgba(37,211,102,0)}
}

.wa-btn{
  display:inline-flex;align-items:center;gap:18px;
  padding:18px 26px;
  background:#25D366;color:#fff;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
  margin-bottom:24px;
}
.wa-btn:hover{background:#1FB855;transform:translateY(-2px)}
.wa-btn svg{width:28px;height:28px;fill:#fff;flex-shrink:0}
.wa-btn .wb-l{display:flex;flex-direction:column;gap:2px;text-align:left}
.wa-btn .wb-lbl{font-size:10px;letter-spacing:.22em;text-transform:uppercase;opacity:.9;font-weight:500}
.wa-btn .wb-num{font-family:'Inter Tight';font-size:18px;font-weight:500;letter-spacing:.02em}

/* ============ CONTACT COMPACT (service pages) ============ */
.contact-compact{padding:120px 0;background:var(--navy-900);border-top:1px solid var(--line)}
.cc-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
.cc-grid .lbl-num{font-size:11px;letter-spacing:.32em;color:var(--ice);text-transform:uppercase;font-weight:500;margin-bottom:24px;display:block}
.cc-grid h2{font-family:'Inter Tight';font-size:clamp(34px,4.4vw,54px);font-weight:400;color:var(--bone);letter-spacing:-0.025em;margin-bottom:24px;line-height:1.05}
.cc-grid h2 em{font-style:normal;color:var(--ice);font-weight:300}
.cc-grid .lead{font-size:16.5px;color:var(--ice-2);line-height:1.65;font-weight:300;margin-bottom:32px;max-width:480px}
.cc-info{display:grid;gap:22px;margin-top:8px}
.cc-info .ci-item{border-top:1px solid var(--line-strong);padding-top:16px}
.cc-info .ci-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--ice);margin-bottom:8px;opacity:.85}
.cc-info .ci-value{font-family:'Inter Tight';font-size:17px;color:var(--bone);font-weight:400;letter-spacing:-0.005em;line-height:1.4}
.cc-info .ci-value a:hover{color:var(--ice)}
@media(max-width:920px){.contact-compact{padding:80px 0}.cc-grid{grid-template-columns:1fr;gap:48px}}

/* ============ MOBILE REFINEMENT (≤720) ============ */
@media(max-width:720px){
  body{padding-bottom:90px}

  /* Hero */
  .hero{padding:96px 0 32px;min-height:auto}
  .hero-eyebrow{margin-bottom:18px;font-size:10px;letter-spacing:.28em}
  .hero h1{font-size:clamp(30px,8.4vw,40px);line-height:1.08;margin-bottom:20px}
  .hero-sub{font-size:15px;margin-bottom:24px}
  .hero-card{padding:26px 22px;margin-top:8px}
  .hero-card h3{font-size:11px;margin-bottom:18px}
  .hero-stats{gap:22px 18px}
  .stat .num{font-size:36px;font-weight:200}
  .stat .num span{font-size:18px}
  .stat .lbl{font-size:10px;margin-top:6px;letter-spacing:.18em}

  /* WhatsApp button + float */
  .wa-btn{padding:14px 18px;gap:12px;width:100%;justify-content:flex-start}
  .wa-btn svg{width:24px;height:24px}
  .wa-btn .wb-lbl{font-size:9px;letter-spacing:.2em}
  .wa-btn .wb-num{font-size:16px}
  .wa-float{bottom:18px;right:18px;width:52px;height:52px}
  .wa-float svg{width:26px;height:26px}

  /* About: kill sticky on mobile */
  .about-portrait{position:static;aspect-ratio:4/5}
  .about-pillars{grid-template-columns:1fr;gap:18px;margin-top:36px}
  .about-body p{font-size:15.5px;line-height:1.65}
  .about-body p:first-of-type::first-letter{font-size:46px;margin:4px 10px 0 0}

  /* Page hero */
  .page-hero{padding:120px 0 64px}
  .page-hero h1{font-size:clamp(30px,9vw,46px);line-height:1.08;margin-bottom:20px}
  .page-hero .lead{font-size:15px;margin-bottom:28px}
  .breadcrumb{font-size:10px;margin-bottom:24px;flex-wrap:wrap}

  /* Section titles */
  .section-title{font-size:clamp(30px,8.4vw,42px);line-height:1.1}
  .section-head{margin-bottom:48px}
  .section-lead{font-size:15px}

  /* Practice items */
  .practice-item{padding:32px 0;gap:14px}
  .pi-title{font-size:21px}
  .pi-bullets li{font-size:13.5px}
  .pi-tag{font-size:12px}
  .pi-cta{font-size:10px}

  /* Method steps */
  .method-step{min-height:auto;padding:36px 26px}
  .ms-title{font-size:20px}

  /* Service section */
  .svc-grid h2{font-size:clamp(28px,7.6vw,38px);line-height:1.1}
  .svc-grid p{font-size:15px;line-height:1.65}
  .svc-grid .lbl{font-size:10px}
  .svc-card{padding:28px 22px}
  .svc-card h3{font-size:18px}
  .svc-card p{font-size:13.5px}

  /* FAQ */
  .faq-item summary{font-size:16px;gap:18px}
  .faq-item .faq-a{font-size:14.5px}

  /* Contact */
  .contact h2{font-size:clamp(34px,8vw,46px)}
  .contact-info, .cc-info{margin-top:0}
  .cc-grid h2{font-size:clamp(28px,7.6vw,40px);line-height:1.08}
  .cc-grid .lead{font-size:15px;margin-bottom:24px}

  /* CTA strip */
  .cta-strip{padding:80px 0}
  .cta-strip h2{font-size:clamp(28px,7.6vw,40px)}
  .cta-strip p{font-size:15px}

  /* Form fields */
  .field input, .field select, .field textarea{font-size:16px}
  .field label{font-size:10px}

  /* Footer */
  .footer{padding:60px 0 28px}
  .footer-col h4{margin-bottom:18px}

  /* Quote */
  .quote{padding:90px 0}

  /* Related */
  .related{padding:80px 0}
  .related-card{padding:26px 22px}
}

/* ============ ANIMATIONS ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
