/* ═══════════════════════════════════════════
   SENVORA — Premium Operational Finance
   Production stylesheet
   ═══════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Type */
  --heading:'Plus Jakarta Sans',sans-serif;
  --font:'Inter',sans-serif;
  --mono:'JetBrains Mono',monospace;

  /* Brand — Navy + Gold */
  --navy:#0B1A3C;
  --navy-deep:#06122B;
  --navy-soft:#172A52;
  --navy-line:rgba(11,26,60,.10);
  --navy-tint:rgba(11,26,60,.04);
  --navy-glow:rgba(11,26,60,.18);

  --gold:#C9A24A;
  --gold-soft:#E0BE6B;
  --gold-deep:#A8862F;
  --gold-tint:rgba(201,162,74,.10);
  --gold-line:rgba(201,162,74,.22);

  /* Neutrals */
  --black:#0A0F1F;
  --ink:#1A2238;
  --mid:#3D4660;
  --gray:#5C6884;
  --light:#8995AD;
  --pale:#C7CFDD;
  --border:#E6E9F1;
  --border-soft:#EEF1F6;
  --section-bg:#F7F8FB;
  --cream:#FAF8F2;
  --white:#FFFFFF;

  /* Status */
  --green:#0F8F66;
  --warn:#D49E2A;

  /* Radii */
  --r:10px;
  --r-lg:16px;
  --r-xl:22px;
  --r-2xl:28px;

  /* Shadows */
  --shadow-xs:0 1px 2px rgba(11,26,60,.04);
  --shadow-sm:0 2px 6px rgba(11,26,60,.05);
  --shadow-md:0 8px 24px rgba(11,26,60,.07);
  --shadow-lg:0 16px 48px rgba(11,26,60,.10);
  --shadow-xl:0 28px 80px rgba(11,26,60,.14);
  --gold-glow:0 8px 28px rgba(201,162,74,.25);

  /* Motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.4,.64,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --dur:.7s;
}

html{scroll-behavior:smooth;scroll-padding-top:88px}
body{
  font-family:var(--font);font-size:16px;line-height:1.65;color:var(--mid);
  background:var(--white);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img,svg{max-width:100%;display:block;border:0}
button{font-family:inherit}

::selection{background:var(--gold-tint);color:var(--navy)}

.mono{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;font-weight:400;text-transform:uppercase;color:var(--light)}

body{animation:pageIn .8s var(--ease) both}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

.wrap{max-width:1180px;margin:0 auto;padding:0 40px}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 40px}
.sec{padding:120px 0;position:relative}
.sec--cream{background:var(--cream)}
.sec--alt{background:var(--section-bg)}
.sec--dark{background:var(--navy-deep);color:var(--white);position:relative;overflow:hidden}
.sec--dark::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 45% at 82% -5%,rgba(201,162,74,.14) 0%,transparent 55%),
    radial-gradient(ellipse 45% 38% at -5% 105%,rgba(201,162,74,.08) 0%,transparent 60%),
    radial-gradient(ellipse 70% 60% at 50% 50%,rgba(36,60,110,.32) 0%,transparent 75%),
    radial-gradient(ellipse 30% 30% at 18% 30%,rgba(86,60,180,.08) 0%,transparent 65%);
  pointer-events:none
}

/* ── Typography — premium hierarchy with fluid clamp() scaling ── */
h1,h2,h3,h4{font-family:var(--heading);color:var(--navy);font-weight:700}
h1{font-size:clamp(36px,5.6vw,64px);line-height:1.02;letter-spacing:-.045em;font-weight:800}
h2{font-size:clamp(28px,3.6vw,42px);line-height:1.08;letter-spacing:-.035em}
h3{font-size:clamp(16px,1.4vw,18px);line-height:1.35;letter-spacing:-.012em;font-weight:600}
h4{font-size:14px;line-height:1.4;letter-spacing:-.01em;font-weight:600}
p{font-size:16px;line-height:1.7;color:var(--gray)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  color:var(--navy);letter-spacing:.24em;text-transform:uppercase;
  margin-bottom:18px;
}
.eyebrow::before{content:'';width:20px;height:1.5px;background:var(--gold);display:inline-block}

.tag{
  display:inline-block;padding:6px 14px;
  background:var(--gold-tint);color:var(--gold-deep);
  font-size:10.5px;font-weight:600;border-radius:50px;
  border:1px solid var(--gold-line);
  text-transform:uppercase;letter-spacing:.16em;font-family:var(--mono);
}

/* ═══════════ ANIMATIONS ═══════════ */
.anim{opacity:0;transform:translateY(28px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.anim.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.stagger>*.in{opacity:1;transform:none}
.anim-left{opacity:0;transform:translateX(-36px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.anim-left.in{opacity:1;transform:none}
.anim-right{opacity:0;transform:translateX(36px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.anim-right.in{opacity:1;transform:none}

.divider{height:1px;background:var(--border-soft);position:relative;overflow:hidden;margin:0 auto;max-width:1100px}
.divider::after{content:'';position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,transparent,var(--gold),transparent);transition:width 1.4s var(--ease)}
.divider.in::after{width:100%}

/* ═══════════ NAV ═══════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(28px) saturate(190%);
  -webkit-backdrop-filter:blur(28px) saturate(190%);
  border-bottom:1px solid transparent;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
  transition:all .4s var(--ease);
  opacity:0;pointer-events:none;transform:translateY(-100%);
  animation:navIn .6s var(--ease) 1.6s forwards
}
@keyframes navIn{to{opacity:1;pointer-events:auto;transform:translateY(0)}}
.nav.scrolled{
  background:rgba(255,255,255,.92);
  border-bottom-color:var(--border-soft);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 1px 0 rgba(11,26,60,.03),0 8px 24px rgba(11,26,60,.03)
}
.nav.hidden{transform:translateY(-100%);transition:transform .35s var(--ease)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 40px;display:flex;align-items:center;height:80px;gap:48px}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:36px;width:auto}
.nav-links{display:flex;gap:36px;margin-left:8px}
.nav-links a{font-size:14px;font-weight:500;color:var(--mid);transition:color .2s;position:relative;letter-spacing:.005em}
.nav-links a::after{content:'';position:absolute;bottom:-7px;left:0;width:0;height:1.5px;background:var(--gold);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--navy);font-weight:600}
.nav-links a.active::after{width:100%}
.nav-end{margin-left:auto;display:flex;align-items:center;gap:16px}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;
  padding:11px 22px;background:var(--navy);color:var(--white);
  border-radius:50px;transition:all .35s var(--ease);
  letter-spacing:.01em;
}
.nav-cta::after{content:'→';font-size:14px;transition:transform .3s var(--ease)}
.nav-cta:hover{background:var(--navy-soft);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.nav-cta:hover::after{transform:translateX(3px)}
.nav-burger{display:none;background:transparent;border:0;width:42px;height:42px;align-items:center;justify-content:center;cursor:pointer;color:var(--navy);border-radius:10px;margin-left:auto}
.nav-burger:hover{background:var(--navy-tint)}
.nav-burger svg{width:22px;height:22px}

/* Mobile nav drawer */
.nav-drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(360px,86vw);z-index:120;
  background:var(--white);
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;
  border-left:1px solid var(--border-soft);
  box-shadow:var(--shadow-xl);
}
.nav-drawer.open{transform:translateX(0)}
.nav-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-soft)}
.nav-drawer-head img{height:32px}
.nav-drawer-close{background:transparent;border:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--navy);border-radius:10px}
.nav-drawer-close:hover{background:var(--navy-tint)}
.nav-drawer-links{display:flex;flex-direction:column;padding:24px 24px}
.nav-drawer-links a{font-family:var(--heading);font-size:22px;font-weight:600;color:var(--navy);padding:14px 0;border-bottom:1px solid var(--border-soft);letter-spacing:-.01em}
.nav-drawer-links a:last-child{border-bottom:0}
.nav-drawer-cta{padding:16px 24px;margin-top:auto;border-top:1px solid var(--border-soft)}
.nav-drawer-cta .btn-pill{width:100%;justify-content:center}
.nav-overlay{position:fixed;inset:0;background:rgba(11,26,60,.32);z-index:115;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.nav-overlay.open{opacity:1;pointer-events:auto}

/* Inner pages: nav visible immediately */
body.page-inner .nav{opacity:1;pointer-events:auto;transform:none;animation:none}

/* ═══════════ HERO ═══════════ */
.hero{padding:0;background:var(--white);position:relative}
.hero-outer{padding:0;animation:heroPad 1.5s var(--ease-soft) 1.4s forwards}
@keyframes heroPad{from{padding:0}to{padding:80px 24px 24px}}
.hero-wrap{
  position:relative;overflow:hidden;
  min-height:100vh;border-radius:0;
  background:var(--navy-deep);
  animation:heroRadius 1.5s var(--ease-soft) 1.4s forwards
}
@keyframes heroRadius{from{border-radius:0}to{border-radius:24px}}
.hero-video{position:absolute;inset:0}
.hero-video video{width:100%;height:100%;object-fit:cover;transform:scale(1.1);animation:heroVidZoom 1.5s var(--ease-soft) 1.4s forwards}
@keyframes heroVidZoom{from{transform:scale(1.1)}to{transform:scale(1.02)}}
.hero-dim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(6,18,43,.45) 0%,rgba(6,18,43,.65) 60%,rgba(6,18,43,.82) 100%),
    radial-gradient(ellipse 70% 50% at 50% 100%,rgba(11,26,60,.5) 0%,transparent 70%)
}
.hero-text{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:100vh;padding:80px 40px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--gold-soft);letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:28px;padding:8px 18px;
  border:1px solid rgba(201,162,74,.32);border-radius:50px;
  background:rgba(201,162,74,.06);
  backdrop-filter:blur(10px);
  opacity:0;transform:translateY(16px);
  animation:heroIn .7s var(--ease) .15s forwards
}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold)}
.hero-text h1{
  color:var(--white);max-width:920px;margin-bottom:26px;
  font-weight:800;font-size:clamp(40px,6.2vw,72px);letter-spacing:-.05em;line-height:1.0;
  opacity:0;transform:translateY(20px);
  animation:heroIn .9s var(--ease) .3s forwards
}
.hero-text h1 em{font-style:normal;color:var(--gold);font-weight:800;position:relative}
.hero-text p{
  color:rgba(255,255,255,.72);font-size:18px;max-width:560px;
  margin-bottom:48px;line-height:1.6;font-weight:400;
  opacity:0;transform:translateY(16px);
  animation:heroIn .8s var(--ease) .55s forwards
}
.hero-btns{display:flex;gap:14px;opacity:0;transform:translateY(12px);animation:heroIn .7s var(--ease) .8s forwards}
@keyframes heroIn{to{opacity:1;transform:none}}

.btn-hero{
  padding:16px 34px;border-radius:50px;
  font-size:13.5px;font-weight:600;font-family:var(--font);
  border:1.5px solid rgba(255,255,255,.18);
  background:transparent;color:var(--white);
  cursor:pointer;transition:all .35s var(--ease);
  letter-spacing:.02em;display:inline-flex;align-items:center;gap:8px;
}
.btn-hero svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.btn-hero:hover svg{transform:translateX(4px)}
.btn-hero--primary{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-hero--primary:hover{background:var(--gold-soft);border-color:var(--gold-soft);transform:translateY(-2px);box-shadow:var(--gold-glow)}
.btn-hero--ghost:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.4);transform:translateY(-2px)}

.hero-trust{
  display:flex;align-items:center;gap:14px;margin-top:64px;
  opacity:0;transform:translateY(10px);
  animation:heroIn .7s var(--ease) 1s forwards
}
.hero-trust-line{width:30px;height:1px;background:rgba(255,255,255,.25)}
.hero-trust span{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.55);letter-spacing:.2em;text-transform:uppercase}

.hero-scroll{
  position:absolute;left:50%;bottom:36px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  color:rgba(255,255,255,.55);text-transform:uppercase;z-index:2;
  opacity:0;animation:heroIn .8s var(--ease) 1.4s forwards
}
.hero-scroll::after{
  content:'';width:1px;height:36px;
  background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,transparent 100%);
  animation:scrollHint 1.8s ease-in-out infinite
}
@keyframes scrollHint{0%,100%{opacity:.4}50%{opacity:1}}

/* ═══════════ MARQUEE ═══════════ */
.marquee{overflow:hidden;padding:24px 0;border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);background:var(--white)}
.marquee-track{display:flex;gap:56px;animation:marqueeScroll 38s linear infinite;width:max-content}
.marquee-track span{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--light);white-space:nowrap;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.marquee-track span svg{width:6px;height:6px;color:var(--gold)}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ═══════════ SECTION HEAD ═══════════ */
.sec-head{text-align:center;max-width:640px;margin:0 auto 72px}
.sec-head .eyebrow{justify-content:center}
.sec-head h2{margin-bottom:16px}
.sec-head p{font-size:17px;max-width:540px;margin:0 auto;color:var(--gray)}
.sec-head.left{text-align:left;margin-left:0}
.sec-head.left .eyebrow{justify-content:flex-start}

/* ═══════════ STATS ═══════════ */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-soft);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border-soft)}
.stat-card{padding:44px 36px;background:var(--white);display:flex;flex-direction:column;justify-content:space-between;min-height:220px;transition:background .3s var(--ease)}
.stat-card:hover{background:var(--cream)}
.stat-card p{font-size:13.5px;color:var(--light);line-height:1.55;font-weight:400}
.stat-num{font-family:var(--heading);font-size:68px;font-weight:800;color:var(--navy);letter-spacing:-.05em;line-height:1;margin-top:auto}
.stat-num em{font-style:normal;color:var(--gold);font-size:.55em;vertical-align:super;margin-left:2px;font-weight:700}

/* ═══════════ FEATURE / SERVICE CARDS ═══════════ */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card-feat{display:flex;flex-direction:column;transition:transform .4s var(--ease)}
.card-feat:hover{transform:translateY(-6px)}
.card-feat h3{margin-top:22px;margin-bottom:6px;font-size:19px}
.card-feat>p{font-size:14.5px;line-height:1.6;color:var(--gray)}

.mock{
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;flex:1;transition:all .4s var(--ease);
  box-shadow:var(--shadow-xs)
}
.mock:hover{box-shadow:var(--shadow-lg);border-color:var(--navy-line);transform:translateY(-2px)}
.mock-bar{display:flex;align-items:center;gap:6px;padding:12px 16px;border-bottom:1px solid var(--border-soft);background:var(--section-bg)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.r{background:#ff5f57}.dot.y{background:#febc2e}.dot.g{background:#28c840}
.mock-title{margin-left:auto;font-size:10.5px;color:var(--light);font-weight:500;font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em}
.mock-body{padding:14px}
.mock-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r);transition:background .2s;margin-bottom:2px;cursor:default}
.mock-row:hover{background:var(--section-bg)}
.mock-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mock-icon.navy{background:var(--navy-tint)}
.mock-icon.gold{background:var(--gold-tint)}
.mock-icon.green{background:rgba(15,143,102,.08)}
.mock-icon.warm{background:rgba(212,158,42,.10)}
.mock-name{flex:1;font-size:13px;font-weight:500;color:var(--ink)}
.badge{font-size:9px;font-weight:700;padding:3px 10px;border-radius:50px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--mono)}
.badge.green{background:rgba(15,143,102,.12);color:var(--green)}
.badge.gold{background:var(--gold-tint);color:var(--gold-deep)}
.badge.gray{background:var(--section-bg);color:var(--gray)}

.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.bar-row:last-child{margin-bottom:0}
.bar-label{font-size:12px;font-weight:500;color:var(--gray);width:120px;min-width:120px}
.bar-track{flex:1;height:6px;background:var(--section-bg);border-radius:50px;overflow:hidden}
.bar-fill{height:100%;border-radius:50px;background:var(--navy);width:0;transition:width 1.2s var(--ease)}
.bar-fill.gold{background:var(--gold)}
.bar-fill.green{background:var(--green)}
.bar-pct{font-size:11.5px;font-weight:600;color:var(--ink);width:40px;text-align:right;opacity:0;transition:opacity .4s var(--ease) .5s;font-family:var(--mono)}
.bars-animated .bar-pct{opacity:1}

.report-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r);transition:background .2s;margin-bottom:2px;cursor:default}
.report-row:hover{background:var(--section-bg)}
.report-row span:nth-child(2){flex:1;font-size:13px;font-weight:500;color:var(--ink)}
.report-icon{width:18px;height:18px;border-radius:5px;background:var(--gold-tint);display:flex;align-items:center;justify-content:center;color:var(--gold-deep)}
.report-tag{font-size:9px;font-weight:700;color:var(--gray);padding:3px 8px;background:var(--section-bg);border-radius:5px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--mono)}

/* ═══════════ SERVICE SPEC CARDS (homepage overview) ═══════════ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.svc-card{
  display:flex;flex-direction:column;
  padding:36px 32px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:all .4s var(--ease);
  text-decoration:none;color:inherit;
  min-height:460px;
  position:relative;overflow:hidden;
}
.svc-card::after{
  content:'';position:absolute;left:0;top:0;height:100%;width:3px;
  background:var(--gold);
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease);
}
.svc-card:hover::after{transform:scaleY(1)}
.svc-card:hover{
  border-color:var(--navy-line);
  box-shadow:var(--shadow-md);
  transform:translateY(-4px);
}

.svc-eyebrow{
  font-family:var(--mono);font-size:10.5px;font-weight:600;
  color:var(--gold-deep);letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:20px;
}
.svc-eyebrow::before{content:'';width:18px;height:1.5px;background:var(--gold)}

.svc-card h3{
  font-size:23px;color:var(--navy);
  margin-bottom:14px;letter-spacing:-.022em;line-height:1.2;
  font-weight:700;
}

.svc-pos{
  font-size:14.5px;color:var(--gray);
  line-height:1.6;margin-bottom:26px;
}

.svc-label{
  font-family:var(--mono);font-size:10px;font-weight:600;
  color:var(--light);letter-spacing:.16em;text-transform:uppercase;
  display:block;margin-bottom:12px;
}

.svc-deliv{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:9px;
}
.svc-deliv li{
  font-size:13.5px;color:var(--ink);line-height:1.5;
  padding-left:20px;position:relative;
}
.svc-deliv li::before{
  content:'';position:absolute;left:0;top:9px;
  width:12px;height:1.5px;background:var(--gold);
}

.svc-meta{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;padding-top:22px;margin-top:auto;
  border-top:1px solid var(--border-soft);
}
.svc-meta-text{display:flex;flex-direction:column;gap:4px}
.svc-meta-text .svc-label{margin:0}
.svc-meta-text strong{
  font-family:var(--heading);font-size:14.5px;font-weight:600;
  color:var(--navy);letter-spacing:-.005em;line-height:1.2;
}
.svc-arrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;font-weight:600;
  color:var(--navy);letter-spacing:.12em;text-transform:uppercase;
  transition:color .3s var(--ease);white-space:nowrap;
}
.svc-arrow svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.svc-card:hover .svc-arrow{color:var(--gold-deep)}
.svc-card:hover .svc-arrow svg{transform:translateX(5px)}

/* Featured CTA card (6th slot) */
.svc-card--cta{
  background:linear-gradient(140deg,var(--navy) 0%,var(--navy-soft) 100%);
  border-color:var(--navy);color:var(--white);
}
.svc-card--cta::before{
  content:'';position:absolute;top:-30%;right:-30%;
  width:80%;height:80%;
  background:radial-gradient(circle,rgba(201,162,74,.18) 0%,transparent 60%);
  pointer-events:none;
}
.svc-card--cta::after{display:none}
.svc-card--cta>*{position:relative;z-index:1}
.svc-card--cta .svc-eyebrow{color:var(--gold-soft)}
.svc-card--cta h3{color:var(--white);font-size:26px;line-height:1.18;margin-bottom:14px;letter-spacing:-.025em}
.svc-card--cta .svc-pos{color:rgba(255,255,255,.62);font-size:15px;margin-bottom:28px}
.svc-cta-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:9px}
.svc-cta-list li{
  font-size:13.5px;color:rgba(255,255,255,.78);line-height:1.5;
  padding-left:20px;position:relative;
}
.svc-cta-list li::before{
  content:'';position:absolute;left:0;top:9px;
  width:12px;height:1.5px;background:var(--gold);
}
.svc-cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;background:var(--gold);color:var(--navy);
  border-radius:50px;font-size:12.5px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  align-self:flex-start;margin-top:auto;
  transition:all .3s var(--ease);
}
.svc-cta-btn svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.svc-card--cta:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.svc-card--cta:hover .svc-cta-btn{background:var(--gold-soft)}
.svc-card--cta:hover .svc-cta-btn svg{transform:translateX(4px)}

/* ═══════════ TILES (Why) ═══════════ */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tile{
  text-align:left;padding:32px 28px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--r-lg);
  transition:all .35s var(--ease);position:relative;overflow:hidden
}
.tile::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold),transparent);
  transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)
}
.tile:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--navy-line)}
.tile:hover::before{transform:scaleX(1)}
.tile-icon{
  width:44px;height:44px;border-radius:11px;
  background:var(--navy-tint);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;transition:all .35s var(--ease);color:var(--navy)
}
.tile-icon svg{width:20px;height:20px;stroke-width:1.6;color:currentColor}
.tile:hover .tile-icon{background:var(--navy);color:var(--white)}
.tile h3{margin-bottom:6px;font-size:16px;color:var(--navy)}
.tile p{font-size:13.5px;line-height:1.55;color:var(--gray)}

/* ═══════════ PAIN POINTS ═══════════ */
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pain-card{
  padding:34px 28px;border-radius:var(--r-lg);
  background:var(--white);border:1px solid var(--border);
  transition:all .35s var(--ease);position:relative
}
.pain-card:hover{border-color:var(--navy-line);box-shadow:var(--shadow-sm)}
.pain-card-num{
  font-family:var(--mono);font-size:11px;color:var(--gold-deep);
  letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;
  display:flex;align-items:center;gap:8px
}
.pain-card-num::before{content:'';width:14px;height:1.5px;background:var(--gold)}
.pain-card h3{font-size:18px;color:var(--navy);margin-bottom:8px;letter-spacing:-.012em}
.pain-card p{font-size:14.5px;line-height:1.6;color:var(--gray)}

/* Pain hook — transitional editorial pull-quote between pain & why */
.pain-hook{
  max-width:820px;margin:64px auto 0;padding:0 24px;
  text-align:center;position:relative;
}
.pain-hook::before{
  content:'';display:block;width:48px;height:1.5px;background:var(--gold);
  margin:0 auto 22px;
}
.pain-hook p{
  font-family:var(--heading);font-size:clamp(20px,2.4vw,28px);
  line-height:1.32;letter-spacing:-.018em;color:var(--navy);
  font-weight:600;
}
.pain-hook p em{font-style:normal;color:var(--gold-deep)}

/* ═══════════ WHY (split layout) ═══════════ */
.why-row{display:grid;grid-template-columns:1.05fr 1.2fr;gap:80px;align-items:center}
.why-text .eyebrow{margin-bottom:18px}
.why-text h2{margin-bottom:18px}
.why-text>p{font-size:16.5px;color:var(--gray);margin-bottom:28px;max-width:480px}
.why-list{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.why-item{display:flex;gap:16px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border-soft)}
.why-item:last-child{border-bottom:0}
.why-mark{
  flex-shrink:0;width:32px;height:32px;border-radius:9px;
  background:var(--gold-tint);color:var(--gold-deep);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11.5px;font-weight:700
}
.why-item-text strong{display:block;font-family:var(--heading);font-size:15.5px;font-weight:600;color:var(--navy);margin-bottom:2px;letter-spacing:-.01em}
.why-item-text span{font-size:14px;color:var(--gray);line-height:1.55}

.why-visual{
  background:linear-gradient(140deg,var(--navy) 0%,var(--navy-soft) 100%);
  border-radius:var(--r-2xl);padding:48px 40px;color:var(--white);
  position:relative;overflow:hidden;min-height:480px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:var(--shadow-lg)
}
.why-visual::before{
  content:'';position:absolute;top:-30%;right:-20%;width:70%;height:70%;
  background:radial-gradient(circle,rgba(201,162,74,.16) 0%,transparent 60%);
  pointer-events:none
}
.why-visual::after{
  content:'';position:absolute;bottom:-20%;left:-10%;width:50%;height:50%;
  background:radial-gradient(circle,rgba(201,162,74,.06) 0%,transparent 60%);
  pointer-events:none
}
.why-visual-head{position:relative;z-index:1}
.why-visual-head .mono{color:var(--gold-soft);margin-bottom:10px;display:block}
.why-visual-head h3{font-family:var(--heading);font-size:30px;font-weight:700;color:var(--white);letter-spacing:-.025em;line-height:1.1;margin-bottom:0;max-width:380px}
.why-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;position:relative;z-index:1;margin-top:32px}
.why-metric{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);padding:20px 22px;backdrop-filter:blur(8px)
}
.why-metric-num{font-family:var(--heading);font-size:34px;font-weight:800;color:var(--white);letter-spacing:-.04em;line-height:1;margin-bottom:6px}
.why-metric-num em{font-style:normal;color:var(--gold);font-size:.7em;font-weight:700}
.why-metric-label{font-size:12px;color:rgba(255,255,255,.55);line-height:1.5}

/* Animated chart inside the why-visual panel */
.why-chart{
  position:relative;z-index:1;margin-top:28px;padding:24px 4px 8px;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.why-chart-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;gap:14px;
}
.why-chart-title{
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  color:rgba(255,255,255,.55);letter-spacing:.22em;text-transform:uppercase;
}
.why-chart-legend{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.why-chart-legend span{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10.5px;color:rgba(255,255,255,.6);letter-spacing:.06em;
  text-transform:uppercase;font-family:var(--mono);
}
.why-chart-legend span::before{
  content:'';width:14px;height:2px;border-radius:2px;
}
.why-chart-legend .lg-gold::before{background:var(--gold)}
.why-chart-legend .lg-gray::before{background:rgba(255,255,255,.28);border-top:1px dashed rgba(255,255,255,.45);height:0;border-radius:0}
.why-chart-svg{display:block;width:100%;height:auto;overflow:visible}
.why-chart-svg .axis{stroke:rgba(255,255,255,.08);stroke-width:1}
.why-chart-svg .grid{stroke:rgba(255,255,255,.05);stroke-width:1;stroke-dasharray:2 4}
.why-chart-svg .ind-line{
  fill:none;stroke:rgba(255,255,255,.32);stroke-width:1.5;stroke-dasharray:4 5;
  stroke-dashoffset:1200;stroke-dasharray:1200;
  transition:stroke-dashoffset 1.6s var(--ease) .2s;
}
.why-chart-svg .ind-line.draw{stroke-dasharray:4 5;stroke-dashoffset:0}
.why-chart-svg .sen-area{fill:url(#senvora-fill);opacity:0;transition:opacity .8s var(--ease) .8s}
.why-chart-svg .sen-area.draw{opacity:1}
.why-chart-svg .sen-line{
  fill:none;stroke:var(--gold);stroke-width:2.4;
  stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1200;stroke-dashoffset:1200;
  filter:drop-shadow(0 1px 6px rgba(201,162,74,.35));
  transition:stroke-dashoffset 1.6s var(--ease) .1s;
}
.why-chart-svg .sen-line.draw{stroke-dashoffset:0}
.why-chart-svg .sen-dot{
  fill:var(--gold);stroke:#0B1A3C;stroke-width:2;r:0;
  transition:r .25s var(--ease-spring);
}
.why-chart-svg .sen-dot.draw{r:4}
.why-chart-svg .x-tick{
  font-family:'JetBrains Mono',monospace;font-size:9px;
  fill:rgba(255,255,255,.4);letter-spacing:.08em;
}
.why-chart-svg .y-tick{
  font-family:'JetBrains Mono',monospace;font-size:9px;
  fill:rgba(255,255,255,.32);letter-spacing:.08em;
}
.why-chart-foot{
  display:flex;align-items:baseline;gap:14px;
  margin-top:14px;font-family:var(--mono);font-size:10.5px;
  color:rgba(255,255,255,.5);letter-spacing:.16em;text-transform:uppercase;
}
.why-chart-foot strong{
  font-family:var(--heading);font-size:22px;font-weight:800;
  color:var(--gold);letter-spacing:-.025em;text-transform:none;
  line-height:1;
}
.why-chart-foot strong em{font-style:normal;font-size:.65em;vertical-align:super;color:var(--gold-soft)}

/* ═══════════ PROCESS ═══════════ */
.process-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:48px;position:relative}
.process-row::before{content:'';position:absolute;top:36px;left:12%;right:12%;height:1px;background:repeating-linear-gradient(90deg,var(--border) 0 6px,transparent 6px 12px)}
.process-step{text-align:center;padding:0 22px;position:relative}
.step-num{
  width:72px;height:72px;border-radius:50%;
  background:var(--white);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:14px;font-weight:600;
  color:var(--navy);margin:0 auto 24px;position:relative;z-index:1;
  transition:all .35s var(--ease);letter-spacing:.04em
}
.process-step:hover .step-num{
  background:var(--navy);color:var(--white);border-color:var(--navy);
  transform:scale(1.05);box-shadow:var(--shadow-md)
}
.process-step:hover .step-num::after{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  border:1px solid var(--gold);opacity:.5
}
.process-step h3{font-size:17px;margin-bottom:8px;color:var(--navy)}
.process-step p{font-size:13.5px;line-height:1.55;color:var(--gray)}

/* ═══════════ TESTIMONIALS ═══════════ */
.testi{position:relative;min-height:340px;padding:44px 0}
.testi-quote-mark{
  font-family:Georgia,serif;font-size:120px;line-height:.5;
  color:var(--gold);opacity:.18;position:absolute;top:0;left:-12px;
  pointer-events:none;font-weight:700
}
.testi-slide{position:absolute;top:44px;left:0;right:0;opacity:0;transform:translateY(14px);transition:all .55s var(--ease);pointer-events:none}
.testi-slide.active{position:relative;top:0;opacity:1;transform:none;pointer-events:auto}
.testi-slide.exit{opacity:0;transform:translateY(-14px)}
.testi-who{margin-bottom:30px;display:flex;align-items:center;gap:16px}
.testi-av{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-soft) 100%);
  border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--heading);font-size:15px;font-weight:700;color:var(--white);
  flex-shrink:0
}
.testi-slide.active .testi-av{animation:avatarIn .5s var(--ease-spring) .1s both}
@keyframes avatarIn{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.testi-who-text{display:flex;flex-direction:column;gap:2px}
.testi-who-text .mono{color:var(--navy);letter-spacing:.1em;font-weight:600;font-size:11px}
.testi-who-text .mono.light{color:var(--light);font-weight:400}
.testi blockquote{
  font-family:var(--heading);font-size:30px;font-weight:600;
  line-height:1.25;letter-spacing:-.02em;color:var(--navy);
  margin:0 0 36px;max-width:820px;border:0;padding:0
}
.testi-stats{display:flex;gap:48px;padding-top:28px;border-top:1px solid var(--border-soft)}
.testi-stats div{display:flex;flex-direction:column;gap:4px}
.testi-stats strong{font-family:var(--heading);display:block;font-size:28px;font-weight:800;color:var(--navy);letter-spacing:-.03em}
.testi-stats strong em{font-style:normal;color:var(--gold);font-size:.7em;vertical-align:super}
.testi-stats span{font-size:12px;color:var(--light);letter-spacing:.02em}
.testi-arrows{position:absolute;top:44px;right:0;display:flex;gap:8px;z-index:5}
.testi-arrows button{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--border);background:var(--white);cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--navy);
  transition:all .25s var(--ease)
}
.testi-arrows button:hover{border-color:var(--navy);background:var(--navy);color:var(--white);transform:translateY(-1px)}
.testi-dots{display:flex;gap:8px;margin-top:32px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);border:0;cursor:pointer;transition:all .35s var(--ease);padding:0}
.testi-dot.active{background:var(--gold);width:28px;border-radius:4px}

/* ═══════════ FAQ ═══════════ */
.faq-grid{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border-soft)}
.faq-item{border-bottom:1px solid var(--border-soft);transition:background .2s}
.faq-item summary,.faq-q{
  list-style:none;cursor:pointer;
  padding:26px 4px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-family:var(--heading);font-size:18px;font-weight:600;
  color:var(--navy);letter-spacing:-.012em;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-icon{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);transition:all .3s var(--ease)
}
.faq-item[open] .faq-icon{background:var(--navy);color:var(--white);border-color:var(--navy);transform:rotate(45deg)}
.faq-icon svg{width:14px;height:14px}
.faq-a{padding:0 4px 28px;font-size:15.5px;line-height:1.7;color:var(--gray);max-width:680px}
.faq-item:hover summary{color:var(--navy-deep)}

/* ═══════════ BUTTONS ═══════════ */
.btn-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;border-radius:50px;
  font-size:13px;font-weight:600;background:var(--navy);color:var(--white);
  border:0;cursor:pointer;transition:all .35s var(--ease);
  letter-spacing:.02em;font-family:var(--font)
}
.btn-pill:hover{background:var(--navy-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-pill svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.btn-pill:hover svg{transform:translateX(4px)}

.btn-gold{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:50px;
  font-size:13px;font-weight:600;background:var(--gold);color:var(--navy);
  border:0;cursor:pointer;transition:all .35s var(--ease);
  letter-spacing:.02em;font-family:var(--font)
}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px);box-shadow:var(--gold-glow)}
.btn-gold svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.btn-gold:hover svg{transform:translateX(4px)}

.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:50px;
  font-size:13px;font-weight:600;background:transparent;color:var(--navy);
  border:1.5px solid var(--border);cursor:pointer;transition:all .35s var(--ease);
  letter-spacing:.02em
}
.btn-outline:hover{border-color:var(--navy);background:var(--navy);color:var(--white);transform:translateY(-2px)}
.btn-outline svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.btn-outline:hover svg{transform:translateX(4px)}

.btn-ghost-light{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:50px;
  font-size:13px;font-weight:600;background:transparent;color:var(--white);
  border:1.5px solid rgba(255,255,255,.20);cursor:pointer;transition:all .35s var(--ease);
  letter-spacing:.02em
}
.btn-ghost-light:hover{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.06);transform:translateY(-2px)}

/* CTA banners across page */
.cta-banner{
  display:flex;align-items:center;justify-content:space-between;gap:40px;
  padding:40px 48px;border-radius:var(--r-xl);
  background:var(--cream);border:1px solid var(--gold-line);
  margin-top:0
}
.cta-banner-text h3{font-size:22px;color:var(--navy);margin-bottom:4px;letter-spacing:-.02em}
.cta-banner-text p{font-size:14.5px;color:var(--gray);margin:0}
.cta-banner-actions{display:flex;gap:10px;flex-shrink:0}

/* ═══════════ FINAL CTA ═══════════ */
.final-cta{text-align:center;max-width:640px;margin:0 auto;position:relative;z-index:1}
.final-cta .eyebrow{justify-content:center;color:var(--gold-soft)}
.final-cta .eyebrow::before{background:var(--gold)}
.final-cta h2{color:var(--white);margin-bottom:18px;font-size:clamp(30px,4.4vw,48px);line-height:1.06}
.final-cta h2 em{font-style:normal;color:var(--gold)}
.final-cta p{color:rgba(255,255,255,.6);font-size:17px;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}
.final-cta-btns{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* ═══════════ PAGE HERO ═══════════ */
.page-hero{padding:170px 0 90px;background:var(--white);text-align:center;position:relative;overflow:hidden}
.page-hero::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:1100px;height:560px;
  background:radial-gradient(ellipse at center top,var(--gold-tint) 0%,transparent 60%);
  pointer-events:none;opacity:.7
}
.page-hero-inner{max-width:720px;margin:0 auto;position:relative;z-index:1}
.page-hero-inner .eyebrow{justify-content:center}
.page-hero-inner h1{margin-bottom:20px;font-size:clamp(34px,5vw,58px);line-height:1.04;letter-spacing:-.045em}
.page-hero-inner h1 em{font-style:normal;color:var(--gold)}
.page-hero-inner p{font-size:18px;color:var(--gray);max-width:560px;margin:0 auto;line-height:1.6}

/* ═══════════ ABOUT ═══════════ */
.founder-row{display:grid;grid-template-columns:.85fr 1.3fr;gap:72px;align-items:center}
.founder-photo{position:relative}
.founder-placeholder{
  width:100%;aspect-ratio:1;border-radius:var(--r-2xl);
  background:linear-gradient(140deg,var(--navy) 0%,var(--navy-soft) 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--heading);font-size:96px;font-weight:800;color:var(--gold);
  letter-spacing:-.04em;position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg)
}
.founder-placeholder::after{
  content:'';position:absolute;top:-30%;right:-30%;width:80%;height:80%;
  background:radial-gradient(circle,rgba(201,162,74,.18) 0%,transparent 60%)
}
.founder-img{width:100%;aspect-ratio:1;border-radius:var(--r-2xl);object-fit:cover;box-shadow:var(--shadow-lg)}
.founder-text .eyebrow{margin-bottom:14px}
.founder-text h2{margin-bottom:6px;font-size:38px;letter-spacing:-.035em}
.founder-role{font-size:14px;color:var(--gold-deep);font-weight:600;margin-bottom:24px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em}
.founder-text p{margin-bottom:14px;font-size:16px;line-height:1.7}
.founder-text p:last-of-type{margin-bottom:0}

/* Philosophy section */
.philo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.philo-card{
  padding:36px 30px;border-radius:var(--r-lg);
  background:var(--white);border:1px solid var(--border);
  transition:all .35s var(--ease)
}
.philo-card:hover{border-color:var(--navy-line);box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.philo-num{
  font-family:var(--mono);font-size:11px;color:var(--gold-deep);
  letter-spacing:.18em;margin-bottom:18px;display:block
}
.philo-card h3{font-size:20px;color:var(--navy);margin-bottom:10px;letter-spacing:-.02em}
.philo-card p{font-size:14.5px;line-height:1.65;color:var(--gray)}

/* ═══════════ SERVICES PAGE ═══════════ */
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.service-block--reverse{direction:rtl}
.service-block--reverse>*{direction:ltr}
.service-content .eyebrow{margin-bottom:14px}
.service-content h2{margin-bottom:14px;font-size:36px}
.service-content>p{margin-bottom:24px;font-size:16px;color:var(--gray);max-width:480px}
.service-impact{
  margin:0 0 24px;padding:18px 22px;
  background:var(--gold-tint);border-left:3px solid var(--gold);
  border-radius:0 8px 8px 0
}
.service-impact strong{font-family:var(--heading);font-size:13px;color:var(--gold-deep);text-transform:uppercase;letter-spacing:.12em;display:block;margin-bottom:6px}
.service-impact p{font-size:14.5px;color:var(--ink);margin:0;line-height:1.55}
.service-list{list-style:none;padding:0;margin:0 0 28px}
.service-list li{font-size:14.5px;color:var(--ink);padding:11px 0 11px 28px;position:relative;border-bottom:1px solid var(--border-soft)}
.service-list li:last-child{border-bottom:0}
.service-list li::before{
  content:'';position:absolute;left:0;top:18px;width:14px;height:1.5px;background:var(--gold)
}
.service-process{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  margin:0 0 28px;padding-top:24px;border-top:1px solid var(--border-soft)
}
.service-process-step{display:flex;flex-direction:column;gap:6px}
.service-process-step .mono{color:var(--gold-deep);font-size:10px;font-weight:600}
.service-process-step strong{font-family:var(--heading);font-size:13.5px;color:var(--navy);font-weight:600;letter-spacing:-.005em}

.service-meta{font-size:13px;color:var(--gray);margin-bottom:24px;display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--section-bg);border-radius:8px}
.service-meta strong{color:var(--navy);font-weight:600}

/* ═══════════ CONTACT ═══════════ */
.contact-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px}
.contact-form{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:40px 40px;
  box-shadow:var(--shadow-sm)
}
.contact-form h2{font-size:30px;margin-bottom:8px;letter-spacing:-.025em}
.contact-form>p{margin-bottom:28px;font-size:15px;color:var(--gray)}
.contact-form form{display:flex;flex-direction:column;gap:14px}
.contact-field label{
  display:block;font-family:var(--mono);font-size:10.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gray);
  margin-bottom:8px
}
.contact-form input,.contact-form textarea,.contact-form select{
  display:block;width:100%;padding:14px 16px;
  border:1.5px solid var(--border);border-radius:var(--r);
  font-family:var(--font);font-size:14.5px;color:var(--ink);
  background:var(--white);transition:all .25s var(--ease);
  -webkit-appearance:none;appearance:none
}
.contact-form select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235C6884' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--light)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  outline:0;border-color:var(--navy);background:var(--white);
  box-shadow:0 0 0 4px rgba(11,26,60,.08)
}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form button[type=submit]{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:16px;background:var(--navy);color:var(--white);
  border:0;border-radius:var(--r);
  font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;
  transition:all .35s var(--ease);letter-spacing:.02em;margin-top:6px
}
.contact-form button[type=submit]:hover{background:var(--navy-soft);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.contact-form button[type=submit] svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.contact-form button[type=submit]:hover svg{transform:translateX(4px)}

.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-card{
  padding:28px 26px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--r-lg);
  transition:all .25s var(--ease)
}
.contact-card:hover{box-shadow:var(--shadow-sm);border-color:var(--navy-line);transform:translateY(-2px)}
.contact-card h3{font-size:16px;margin-bottom:6px;color:var(--navy)}
.contact-card p{font-size:13.5px;margin-bottom:14px;color:var(--gray);line-height:1.55}
.contact-card a:not(.btn-pill):not(.btn-gold){font-size:14.5px;color:var(--navy);font-weight:500;transition:color .2s;border-bottom:1px solid var(--gold-line);padding-bottom:1px}
.contact-card a:not(.btn-pill):not(.btn-gold):hover{color:var(--gold-deep);border-color:var(--gold)}
.contact-icon{
  width:42px;height:42px;border-radius:11px;
  background:var(--gold-tint);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
  color:var(--gold-deep)
}
.contact-icon svg{width:18px;height:18px}
.contact-card--highlight{
  background:linear-gradient(140deg,var(--navy) 0%,var(--navy-soft) 100%);
  border-color:var(--navy);color:var(--white);position:relative;overflow:hidden
}
.contact-card--highlight::before{
  content:'';position:absolute;top:-30%;right:-30%;width:80%;height:80%;
  background:radial-gradient(circle,rgba(201,162,74,.16) 0%,transparent 60%);pointer-events:none
}
.contact-card--highlight>*{position:relative;z-index:1}
.contact-card--highlight h3{color:var(--white)}
.contact-card--highlight p{color:rgba(255,255,255,.6)}
.response-time{
  font-family:var(--heading);font-size:30px;font-weight:800;
  color:var(--gold);letter-spacing:-.03em;line-height:1
}

.form-msg{margin-top:14px;font-size:13.5px;text-align:center;font-weight:500}
.form-msg.ok{color:var(--green)}
.form-msg.err{color:#dc2626}

/* ═══════════ FOOTER ═══════════ */
.foot{
  background:var(--navy-deep);color:rgba(255,255,255,.6);
  padding:84px 0 0;position:relative;overflow:hidden;
  background-image:
    radial-gradient(ellipse 60% 50% at 90% 100%,rgba(201,162,74,.10) 0%,transparent 65%),
    radial-gradient(ellipse 40% 50% at 0% 0%,rgba(36,60,110,.4) 0%,transparent 70%),
    linear-gradient(180deg,#06122B 0%,#040a1f 100%);
}
.foot::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:1100px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,162,74,.4),transparent)
}
/* Layout: brand block (with contact info) | Company | Services (split into 2) */
.foot-top{
  display:grid;
  grid-template-columns:1.3fr 0.7fr 1.6fr;
  gap:64px;
  padding-bottom:64px;
  position:relative;z-index:1;
}
.foot-brand{display:flex;flex-direction:column;max-width:360px}
.foot-logo{margin-bottom:22px;width:auto}
.foot-tagline{
  font-size:14.5px;line-height:1.65;
  color:rgba(255,255,255,.55);
  margin:0 0 28px;max-width:320px;
}

/* Contact block (Contact us on · Write to us) */
.foot-contact{display:flex;flex-direction:column;gap:18px;margin-top:auto}
.foot-contact-item{display:flex;flex-direction:column;gap:4px}
.foot-contact-label{
  font-family:var(--mono);font-size:10.5px;font-weight:500;
  color:rgba(255,255,255,.42);letter-spacing:.18em;text-transform:uppercase;
}
.foot-contact-value{
  font-family:var(--heading);font-size:17px;font-weight:600;
  color:rgba(255,255,255,.92);letter-spacing:-.005em;
  transition:color .25s var(--ease);
}
.foot-contact-value:hover{color:var(--gold)}

/* Columns shared rules */
.foot-col{display:flex;flex-direction:column;gap:14px}
.foot-col h4{
  font-family:var(--heading);
  font-size:19px;font-weight:600;letter-spacing:-.005em;
  color:rgba(255,255,255,.95);
  margin:0 0 14px;text-transform:none;
}
.foot-col a{
  font-size:14.5px;line-height:1.5;
  color:rgba(255,255,255,.62);
  transition:color .2s var(--ease), padding-left .2s var(--ease);
}
.foot-col a:hover{color:var(--gold)}

/* Services column split into 2 sub-columns */
.foot-col--services{}
.foot-services-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 32px;
}
.foot-services-col{display:flex;flex-direction:column;gap:12px}
.foot-services-col a{font-size:14.5px;color:rgba(255,255,255,.62);transition:color .2s var(--ease)}
.foot-services-col a:hover{color:var(--gold)}
.foot-clocks{
  padding:36px 0 28px;border-top:1px solid rgba(255,255,255,.06);
  position:relative;z-index:1;
}
.foot-clocks-label{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;font-weight:500;
  color:rgba(255,255,255,.5);letter-spacing:.24em;text-transform:uppercase;
  margin-bottom:24px;
}
.foot-clocks-label::before{content:'';width:20px;height:1.5px;background:var(--gold)}
.foot-clocks-list{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:24px;
}
.foot-clock{
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.clock-face{
  width:120px;height:120px;flex-shrink:0;
  border-radius:50%;
  background:radial-gradient(
    circle at 50% 35%,
    rgba(255,255,255,.075) 0%,
    rgba(255,255,255,.025) 55%,
    rgba(0,0,0,.05)        100%
  );
  filter:drop-shadow(0 8px 22px rgba(0,0,0,.5));
}
.clock-ring{
  fill:none;
  stroke:rgba(255,255,255,.22);
  stroke-width:.6;
}
.clock-ticks .tick-hour{
  stroke:#fff;stroke-width:1.6;stroke-linecap:round;opacity:.98;
}
.clock-ticks .tick-min{
  stroke:rgba(255,255,255,.32);stroke-width:.55;stroke-linecap:round;
}
.clock-hand{
  stroke:#fff;stroke-linecap:round;
  /* Rotation pivot is set explicitly via the SVG transform="rotate(deg 50 50)"
     attribute — do NOT set CSS transform-origin here, it overrides the SVG pivot. */
  transition:transform .35s var(--ease-spring);
}
.clock-hand-hour{stroke-width:3.4}
.clock-hand-min{stroke-width:2.4}
.clock-hand-sec{
  stroke:#DC4D4D;stroke-width:.9;
  transition:transform .12s linear;
}
.clock-center{fill:#DC4D4D}
.clock-pin{fill:rgba(255,255,255,.92)}
.clock-city{
  font-family:var(--heading);font-weight:600;
  font-size:16px;color:rgba(255,255,255,.92);
  letter-spacing:.01em;
}
@media(prefers-reduced-motion:reduce){
  .clock-hand{transition:none}
}

.foot-bot{
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 0;border-top:1px solid rgba(255,255,255,.08);
  position:relative;z-index:1;
  gap:24px;flex-wrap:wrap;
}
.foot-utility{display:flex;gap:28px;flex-wrap:wrap}
.foot-utility a{
  font-size:13px;color:rgba(255,255,255,.5);
  transition:color .2s var(--ease);
}
.foot-utility a:hover{color:var(--gold)}
.foot-copy{
  font-size:13px;color:rgba(255,255,255,.4);margin:0;
}

/* Starfield overlay — subtle constellation feel */
.foot-stars{
  position:absolute;inset:0;
  pointer-events:none;
  opacity:.55;
  background-image:
    radial-gradient(1px 1px at 10% 12%, rgba(255,255,255,.7) 50%, transparent 100%),
    radial-gradient(1px 1px at 18% 78%, rgba(255,255,255,.55) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 27% 34%, rgba(255,255,255,.6) 50%, transparent 100%),
    radial-gradient(1px 1px at 35% 64%, rgba(160,200,255,.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 42% 18%, rgba(255,255,255,.5) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 50%, rgba(201,162,74,.45) 50%, transparent 100%),
    radial-gradient(1px 1px at 58% 28%, rgba(255,255,255,.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 64% 72%, rgba(160,200,255,.45) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 73% 40%, rgba(255,255,255,.6) 50%, transparent 100%),
    radial-gradient(1px 1px at 80% 86%, rgba(255,255,255,.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 88% 18%, rgba(201,162,74,.4) 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 94% 62%, rgba(255,255,255,.55) 50%, transparent 100%),
    radial-gradient(1px 1px at 4% 52%, rgba(255,255,255,.4) 50%, transparent 100%),
    radial-gradient(1px 1px at 22% 6%, rgba(255,255,255,.45) 50%, transparent 100%),
    radial-gradient(1px 1px at 67% 8%, rgba(255,255,255,.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 31% 92%, rgba(160,200,255,.4) 50%, transparent 100%);
  background-size:100% 100%;
  background-repeat:no-repeat;
}
/* Soft connecting glow — adds depth without a second image */
.foot-stars::after{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 700px 220px at 30% 40%, rgba(120,160,220,.06) 0%, transparent 70%),
    radial-gradient(ellipse 800px 240px at 75% 70%, rgba(201,162,74,.05) 0%, transparent 70%);
}

/* ═══════════ WHATSAPP ═══════════ */
.wa{
  position:fixed;bottom:28px;right:28px;width:56px;height:56px;
  background:#25d366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,.35);z-index:99;
  transition:all .35s var(--ease)
}
.wa:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 10px 28px rgba(37,211,102,.45)}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:1024px){
  .sec{padding:88px 0}
  .wrap,.wrap-narrow{padding:0 32px}
  .nav-inner{padding:0 32px;gap:24px}
  .cards-3{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}
  .svc-grid{grid-template-columns:1fr 1fr;gap:14px}
  .svc-card{min-height:auto;padding:32px 28px}
  .svc-card h3{font-size:21px}
  .svc-card--cta h3{font-size:24px}
  .pain-grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .stat-row{grid-template-columns:1fr}.stat-card{min-height:auto}.stat-num{font-size:54px}
  .testi blockquote{font-size:24px}
  .process-row{grid-template-columns:1fr 1fr;gap:36px}
  .process-row::before{display:none}
  .why-row{grid-template-columns:1fr;gap:48px}
  .why-visual{min-height:auto;padding:36px 32px}
  .service-block,.service-block--reverse{grid-template-columns:1fr;gap:36px}
  .service-block--reverse{direction:ltr}
  .service-process{grid-template-columns:repeat(2,1fr)}
  .founder-row{grid-template-columns:1fr;gap:40px;max-width:520px;margin:0 auto}
  .contact-grid{grid-template-columns:1fr}
  .philo-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:48px}
  .foot-cols{grid-template-columns:repeat(3,1fr);gap:24px}
  .cta-banner{flex-direction:column;align-items:flex-start;padding:32px}
  .testi{padding:32px 0}
}
@media(max-width:768px){
  .sec{padding:64px 0}
  .hero-text p{font-size:16px;margin-bottom:36px}
  .hero-text{padding:48px 24px}
  .hero-eyebrow{font-size:10px;padding:6px 14px;margin-bottom:22px}
  .hero-trust{margin-top:48px;gap:10px;flex-wrap:wrap;justify-content:center}
  @keyframes heroPad{from{padding:0}to{padding:80px 12px 12px}}
  @keyframes heroRadius{from{border-radius:0}to{border-radius:16px}}
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .nav-inner{height:72px;padding:0 24px;gap:0}
  .nav-logo img{height:32px}
  .hero-btns{flex-direction:column;align-items:stretch;width:100%;max-width:280px}
  .btn-hero{width:100%;justify-content:center;text-align:center}
  .pain-grid,.grid-4,.svc-grid{grid-template-columns:1fr}
  .svc-grid{max-width:460px;margin-left:auto;margin-right:auto}
  .testi blockquote{font-size:22px}
  .testi-arrows{position:static;margin-top:20px}
  .testi-stats{flex-direction:column;gap:18px}
  .testi-who{flex-wrap:wrap}
  .foot-top{grid-template-columns:1fr;gap:36px}
  .foot-cols{grid-template-columns:repeat(2,1fr);gap:32px 24px}
  .foot-bot{flex-direction:column;gap:10px;text-align:center;padding:20px 0}
  .foot-clocks{padding:28px 0 20px}
  .foot-clocks-list{grid-template-columns:repeat(2, 1fr);gap:28px 16px}
  .clock-face{width:108px;height:108px}
  .clock-city{font-size:15px}
  .testi{min-height:auto}
  .page-hero{padding:128px 0 56px}
  .page-hero-inner p{font-size:16px}
  .process-row{grid-template-columns:1fr;max-width:380px;margin-left:auto;margin-right:auto;gap:32px}
  .founder-placeholder{max-width:280px;margin:0 auto;font-size:72px}
  .why-visual{padding:32px 28px}
  .why-visual-head h3{font-size:24px}
  .why-metrics{grid-template-columns:1fr 1fr;gap:12px}
  .why-metric{padding:16px 18px}
  .why-metric-num{font-size:28px}
  .service-content h2{font-size:28px}
  .service-process{grid-template-columns:1fr 1fr}
  .contact-form{padding:32px 28px}
  .contact-form h2{font-size:24px}
  .cta-banner-actions{width:100%}
  .cta-banner-actions .btn-pill,.cta-banner-actions .btn-outline,.cta-banner-actions .btn-gold{flex:1;justify-content:center}
  .faq-item summary,.faq-q{font-size:16px;padding:22px 4px;gap:18px}
  .faq-a{font-size:14.5px;padding:0 4px 24px}
}
@media(max-width:480px){
  .hero-text h1{letter-spacing:-.04em}
  .wrap,.wrap-narrow{padding:0 22px}
  .nav-inner{padding:0 22px}
  .sec{padding:56px 0}.sec-head{margin-bottom:40px}
  .nav-logo img{height:30px}
  .testi blockquote{font-size:20px}
  .stat-num{font-size:46px}
  .testi-stats strong{font-size:24px}
  .wa{bottom:20px;right:20px;width:50px;height:50px}
  .why-metrics{grid-template-columns:1fr}
  .founder-placeholder{font-size:64px}
  .testi-quote-mark{font-size:80px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .anim,.anim-left,.anim-right,.stagger>*{opacity:1!important;transform:none!important}
}

/* ─────────────────────────────────────────
   BLOG · PROSE · GUTENBERG EDITOR CONTENT
   ───────────────────────────────────────── */

/* Reading column for posts and admin-built pages */
.prose{font-size:17.5px;line-height:1.75;color:var(--ink)}
.prose h2{font-family:var(--heading);font-size:30px;color:var(--navy);margin:48px 0 16px;letter-spacing:-.02em}
.prose h3{font-family:var(--heading);font-size:23px;color:var(--navy);margin:36px 0 12px}
.prose h4{font-family:var(--heading);font-size:18px;color:var(--navy);margin:28px 0 10px;letter-spacing:.01em}
.prose p{margin:0 0 20px}
.prose a{color:var(--gold-deep);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;text-decoration-color:var(--gold-line);transition:color .2s var(--ease)}
.prose a:hover{color:var(--navy);text-decoration-color:var(--navy)}
.prose strong{color:var(--navy);font-weight:600}
.prose em{font-style:italic;color:var(--ink)}
.prose ul,.prose ol{margin:0 0 22px;padding-left:22px}
.prose li{margin:0 0 8px}
.prose blockquote{border-left:3px solid var(--gold);background:var(--gold-tint);padding:18px 24px;margin:28px 0;font-style:italic;color:var(--navy);border-radius:0 var(--r) var(--r) 0}
.prose blockquote p{margin:0}
.prose pre{background:var(--navy-deep);color:#E8ECF5;padding:18px 22px;border-radius:var(--r-lg);overflow-x:auto;font-family:var(--mono);font-size:13.5px;line-height:1.6;margin:28px 0}
.prose code{font-family:var(--mono);font-size:.9em;background:var(--cream);padding:2px 6px;border-radius:4px;color:var(--navy)}
.prose pre code{background:none;padding:0;color:inherit}
.prose img,.prose figure img{max-width:100%;height:auto;border-radius:var(--r-lg);margin:24px 0}
.prose figure{margin:28px 0}
.prose figure figcaption{font-size:13.5px;color:var(--light);font-family:var(--mono);text-align:center;margin-top:10px;letter-spacing:.02em}
.prose hr{border:none;border-top:1px solid var(--border);margin:40px 0}
.prose table{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.prose th,.prose td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left}
.prose th{background:var(--cream);font-weight:600;color:var(--navy)}

/* Gutenberg wide / full alignment */
.prose .alignwide{margin-left:-60px;margin-right:-60px;max-width:none}
.prose .alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:none;width:100vw}
@media(max-width:960px){.prose .alignwide{margin-left:0;margin-right:0}}

/* Generic admin-built page content (page.php) */
.page-content{padding:0}
.page-content > * + *{margin-top:0}

/* Post hero adjustments */
.post-hero{padding-top:120px;padding-bottom:40px}
.post-hero h1{font-size:clamp(34px, 5.5vw, 56px);max-width:780px;margin-inline:auto}
.post-meta{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--light);margin-top:24px}
.post-meta-sep{margin:0 10px;color:var(--pale)}

.post-featured{margin:0 0 40px}
.post-featured img{width:100%;height:auto;border-radius:var(--r-xl);box-shadow:var(--shadow-md)}

.post-body{padding-top:24px}
.post-foot{padding-top:0;padding-bottom:80px}

.post-tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0 24px;padding-top:24px;border-top:1px solid var(--border)}
.post-tag{display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);padding:6px 12px;border:1px solid var(--border);border-radius:999px;transition:all .2s var(--ease)}
.post-tag:hover{border-color:var(--gold);color:var(--gold-deep);background:var(--gold-tint)}

.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;padding-top:32px;border-top:1px solid var(--border)}
.post-nav a{display:block;padding:18px 22px;border:1px solid var(--border);border-radius:var(--r-lg);transition:all .25s var(--ease);background:var(--white)}
.post-nav a:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.post-nav-label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--light);margin-bottom:6px}
.post-nav-next{text-align:right}
.post-nav strong{display:block;color:var(--navy);font-family:var(--heading);font-size:16px;line-height:1.35}
@media(max-width:640px){.post-nav{grid-template-columns:1fr}.post-nav-next{text-align:left}}

/* Post card grid (archive, home, search) */
.post-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:28px;margin-bottom:48px}
@media(max-width:960px){.post-grid{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:640px){.post-grid{grid-template-columns:1fr}}

.post-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:all .3s var(--ease)}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold-line)}
.post-card-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.post-card:hover .post-card-thumb img{transform:scale(1.03)}
.post-card-body{padding:26px 24px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-card-cat{color:var(--gold-deep)}
.post-card h3{font-family:var(--heading);font-size:20px;line-height:1.3;color:var(--navy);margin:0}
.post-card h3 a{color:inherit;transition:color .2s var(--ease)}
.post-card h3 a:hover{color:var(--gold-deep)}
.post-card p{color:var(--gray);font-size:15px;line-height:1.55;margin:0;flex:1}
.post-card-meta{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--light);margin-top:6px}

/* Pagination */
.post-pagination{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:24px}
.post-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;border:1px solid var(--border);border-radius:10px;font-family:var(--mono);font-size:13px;color:var(--gray);transition:all .2s var(--ease);background:var(--white)}
.post-pagination .page-numbers:hover{border-color:var(--gold);color:var(--gold-deep)}
.post-pagination .page-numbers.current{background:var(--navy);color:var(--white);border-color:var(--navy)}
.post-pagination .page-numbers.dots{border:none;background:none}

/* Search form on /?s= */
.search-form{display:flex;gap:10px;max-width:480px;margin:24px auto 0}
.search-form input[type="search"]{flex:1;padding:13px 18px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--font);font-size:15px;background:var(--white);transition:border-color .2s var(--ease)}
.search-form input[type="search"]:focus{outline:none;border-color:var(--gold)}
.search-form button{padding:13px 22px;background:var(--navy);color:var(--white);border:none;border-radius:var(--r);font-family:var(--font);font-weight:500;font-size:14px;cursor:pointer;transition:background .2s var(--ease)}
.search-form button:hover{background:var(--navy-soft)}

.blog-empty{padding:60px 0;text-align:center;color:var(--gray)}

/* Gutenberg buttons */
.wp-block-button__link{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;background:var(--navy);color:var(--white);border-radius:999px;font-family:var(--heading);font-weight:600;font-size:14.5px;letter-spacing:.01em;text-decoration:none;border:none;transition:all .25s var(--ease)}
.wp-block-button__link:hover{background:var(--gold);color:var(--navy);transform:translateY(-1px);box-shadow:var(--gold-glow)}
.is-style-outline .wp-block-button__link{background:transparent;color:var(--navy);border:1.5px solid var(--navy);box-shadow:none}
.is-style-outline .wp-block-button__link:hover{background:var(--navy);color:var(--white)}

/* Editor-only: hint label on the four locked pages */
.editor-styles-wrapper .wp-block.is-root-container > p:first-child:empty::before{content:"This page is template-locked. Editor content is ignored on the front end.";display:block;padding:16px 20px;background:#FFF8E6;border-left:3px solid var(--gold);color:var(--navy);font-family:var(--heading);font-weight:500;border-radius:var(--r)}

/* ─────────────────────────────────────────
   CASE STUDIES
   ───────────────────────────────────────── */

/* Card grid (archive + related) */
.cs-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:28px;margin-bottom:48px}
@media(max-width:960px){.cs-grid{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:640px){.cs-grid{grid-template-columns:1fr}}

.cs-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:all .3s var(--ease);color:inherit}
.cs-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold-line)}
.cs-card-thumb{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--cream);position:relative}
.cs-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.cs-card:hover .cs-card-thumb img{transform:scale(1.03)}
.cs-card-thumb--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 100%);color:var(--gold)}
.cs-card-thumb--placeholder .mono{font-size:11px;letter-spacing:.2em;color:var(--gold-soft)}

.cs-card-body{padding:26px 24px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.cs-card-tag{color:var(--gold-deep);font-size:10.5px}
.cs-card h3{font-family:var(--heading);font-size:20px;line-height:1.3;color:var(--navy);margin:0;letter-spacing:-.01em}
.cs-card-client{margin:0;color:var(--gray);font-size:13.5px;font-family:var(--mono);text-transform:none;letter-spacing:.01em}
.cs-card-excerpt{color:var(--gray);font-size:14.5px;line-height:1.55;margin:4px 0 0;flex:1}
.cs-card-outcome{display:flex;align-items:baseline;gap:10px;margin-top:14px;padding:14px 16px;background:var(--cream);border-radius:var(--r)}
.cs-card-outcome strong{font-family:var(--heading);font-size:22px;color:var(--navy);font-weight:700;letter-spacing:-.01em}
.cs-card-outcome span{font-size:12.5px;color:var(--gray);line-height:1.3}
.cs-card-arrow{display:inline-flex;align-items:center;gap:6px;color:var(--gold-deep);font-family:var(--heading);font-weight:600;font-size:13.5px;margin-top:8px;transition:gap .2s var(--ease)}
.cs-card-arrow svg{width:14px;height:14px}
.cs-card:hover .cs-card-arrow{gap:10px}

/* Single case study */
.cs-hero{padding-bottom:36px}
.cs-hero h1{font-size:clamp(34px, 5.5vw, 56px);max-width:820px;margin-inline:auto;letter-spacing:-.025em}
.cs-featured img{width:100%;height:auto;border-radius:var(--r-xl);box-shadow:var(--shadow-md);max-height:540px;object-fit:cover}

.cs-summary{background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:32px 36px;box-shadow:var(--shadow-sm)}
.cs-summary-row{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;padding-bottom:24px;border-bottom:1px solid var(--border-soft)}
@media(max-width:720px){.cs-summary-row{grid-template-columns:1fr;gap:18px}}
.cs-summary-cell{display:flex;flex-direction:column;gap:4px}
.cs-summary-cell .mono{color:var(--light);font-size:10.5px}
.cs-summary-cell strong{font-family:var(--heading);font-size:15.5px;color:var(--navy);font-weight:600;line-height:1.4}

.cs-outcome-row{display:grid;grid-template-columns:repeat(3, 1fr);gap:24px;margin-top:24px}
@media(max-width:720px){.cs-outcome-row{grid-template-columns:1fr;gap:14px}}
.cs-outcome{display:flex;flex-direction:column;gap:6px;padding:18px 20px;background:var(--cream);border-radius:var(--r-lg);text-align:center}
.cs-outcome strong{font-family:var(--heading);font-size:34px;color:var(--navy);font-weight:700;letter-spacing:-.02em;line-height:1}
.cs-outcome span{font-size:13px;color:var(--gray);line-height:1.4}

.cs-summary-section{padding-bottom:24px}

/* Calendly inline widget polish */
.calendly-section{background:var(--white)}
.calendly-inline-widget{border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm)}
@media(max-width:640px){.calendly-inline-widget{height:780px!important;border-radius:var(--r-lg)}}

/* Turnstile widget inside the contact form */
.contact-turnstile{margin:8px 0 4px}
.contact-turnstile .cf-turnstile{display:flex;justify-content:flex-start}

/* ═════════════════════════════════════════════════════════════════
   NEW LOGO + FOUNDER IMAGE
   Logos are navy ink + gold accent on transparent backgrounds, so on
   the light nav they display as-is. The footer is dark, so the foot
   logo gets a brightness/invert filter to render it as clean white.
   ═════════════════════════════════════════════════════════════════ */

/* Nav (light bg) → original navy logo. Footer (dark bg) → white logo. */
.foot-logo{
  filter:brightness(0) invert(1);
  opacity:.92;
  transition:opacity .25s var(--ease);
}
a:hover > .foot-logo{opacity:1}

/* Logo sizing
   Nav uses the wordmark-only crop (primary_logo_wordmark.png, 690×64).
   Display height matches the visual weight of the 14px nav-link text —
   the SENVORA letters then read inline with the menu, not above it.
   Footer keeps the full secondary_logo (S-mark + wordmark + tagline)
   for richer brand presence in the larger footer surface. */
.nav-logo img{height:20px}
.nav-drawer-head img{height:22px}
.foot-logo{height:60px}
@media(max-width:960px){
  .nav-logo img{height:18px}
  .foot-logo{height:52px}
}
@media(max-width:480px){
  .nav-logo img{height:16px}
  .foot-logo{height:44px}
}

/* Founder image — sidebar-style portrait beside the bio text.
   Sized DELIBERATELY SMALLER than the text column so the row reads
   "person + their story" rather than "giant photo above tiny caption".
   Strategy:
     - Slim image column (1fr) vs roomier text column (1.6fr)
     - Compact square cap (max 340px) — square keeps it neutral and
       avoids the "tall narrow strip" feel of a portrait crop
     - Aligned to top so it pairs visually with the eyebrow + heading
     - No flex container — img is its own block, margin-aligned */
.founder-row{
  grid-template-columns:1fr 1.6fr;
  gap:56px;
  align-items:start;
}
.founder-photo{position:relative;max-width:340px}
.founder-img{
  display:block;
  width:100%;
  height:auto;
  /* Preserve the photo's natural 3:4 portrait aspect — no cropping.
     The image is sized by width; height follows the source ratio. */
  aspect-ratio:3 / 4;
  object-fit:contain;
  border-radius:var(--r-2xl);
  border:1px solid var(--border-soft);
  box-shadow:var(--shadow-md);
  /* Editorial portrait treatment — slight desaturation + contrast lift +
     barely-perceptible darken. Pulls the busy background back and gives
     the photo a magazine-cover feel rather than a phone snapshot. */
  filter:saturate(.82) contrast(1.06) brightness(.97);
  transition:filter .4s var(--ease);
}
.founder-img:hover{
  filter:saturate(1) contrast(1.04) brightness(1);
}
.founder-photo::after{
  content:'';
  position:absolute;inset:auto auto -12px -12px;
  width:56px;height:56px;
  border-left:2px solid var(--gold);
  border-bottom:2px solid var(--gold);
  border-bottom-left-radius:var(--r-xl);
  pointer-events:none;opacity:.7;
}
@media(max-width:1024px){
  .founder-row{grid-template-columns:1fr;gap:36px;max-width:520px;margin:0 auto;align-items:center}
  .founder-photo{max-width:320px;margin:0 auto}
}
@media(max-width:720px){
  .founder-photo{max-width:280px}
  .founder-photo::after{display:none}
}
@media(max-width:480px){
  .founder-photo{max-width:240px}
  .founder-img{border-radius:var(--r-xl)}
}


/* ═════════════════════════════════════════════════════════════════
   NEW COMPONENTS — light theme
   Styles for the new homepage trust grid (Built Around Structure)
   and the compact 9-service grid. Uses existing light-theme tokens.
   ═════════════════════════════════════════════════════════════════ */

/* Trust grid · Built Around Structure, Not Chaos — premium card treatment
   ───────────────────────────────────────────────────────────────────────
   Refinements vs default card:
   - Soft gradient background (white → faint cream) reads as paper, not plastic
   - Larger 54px icon with two-stop gold gradient + crisp border
   - Hairline border instead of strong border-soft
   - Top gold accent line that animates in on hover
   - Spring-eased lift, warm gold-tinted shadow, micro-rotation on the icon
   - Numbered eyebrow label (01 · 02 · …) for premium hierarchy
*/
.trust-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:20px;
  counter-reset:trust;
}
.trust-card{
  position:relative;
  padding:34px 26px 30px;
  background:linear-gradient(180deg, #ffffff 0%, #fbf8ef 100%);
  border:1px solid rgba(11,26,60,.07);
  border-radius:var(--r-xl);
  display:flex;flex-direction:column;gap:18px;
  text-align:left;
  overflow:hidden;
  isolation:isolate;
  counter-increment:trust;
  transition:transform .45s var(--ease-spring), box-shadow .45s var(--ease), border-color .35s var(--ease);
}
/* Top gold accent rule — fades in on hover */
.trust-card::before{
  content:'';
  position:absolute;top:0;left:24px;right:24px;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:0;
  transform:translateY(-1px);
  transition:opacity .35s var(--ease), transform .5s var(--ease);
}
/* Numbered eyebrow at top-right */
.trust-card::after{
  content:'0' counter(trust);
  position:absolute;top:22px;right:24px;
  font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--light);letter-spacing:.18em;
  opacity:.65;
  transition:color .3s var(--ease), opacity .3s var(--ease);
}
.trust-card:hover{
  transform:translateY(-6px);
  border-color:rgba(201,162,74,.32);
  box-shadow:
    0 26px 50px -22px rgba(11,26,60,.22),
    0 0 60px -28px rgba(201,162,74,.45);
}
.trust-card:hover::before{opacity:1;transform:translateY(0)}
.trust-card:hover::after{color:var(--gold-deep);opacity:1}

.trust-icon{
  width:54px;height:54px;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.55) 0%, transparent 55%),
    linear-gradient(135deg, rgba(201,162,74,.20) 0%, rgba(201,162,74,.05) 100%);
  border:1px solid rgba(201,162,74,.28);
  border-radius:14px;
  color:var(--gold-deep);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 6px 16px -8px rgba(201,162,74,.45);
  transition:transform .55s var(--ease-spring), background .35s var(--ease), border-color .3s var(--ease);
}
.trust-icon svg{width:26px;height:26px;stroke-width:1.5}
.trust-card:hover .trust-icon{
  transform:scale(1.06) rotate(-3deg);
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.7) 0%, transparent 55%),
    linear-gradient(135deg, rgba(201,162,74,.32) 0%, rgba(201,162,74,.10) 100%);
  border-color:rgba(201,162,74,.42);
}

.trust-card h3{
  font-family:var(--heading);font-size:17.5px;font-weight:700;
  line-height:1.3;margin:0;color:var(--navy);letter-spacing:-.012em;
}
.trust-card p{
  font-size:14px;line-height:1.62;margin:0;color:var(--gray);
}

@media(max-width:1100px){.trust-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .trust-card{padding:28px 22px 26px;gap:14px}
  .trust-icon{width:48px;height:48px;border-radius:12px}
  .trust-icon svg{width:22px;height:22px}
}
@media(max-width:480px){
  .trust-grid{grid-template-columns:1fr;gap:14px}
  .trust-card{padding:24px 22px 22px}
}

/* Compact 9-service grid for the homepage */
.svc-grid--compact{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.svc-card--compact{
  padding:26px 24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  display:flex;flex-direction:column;gap:12px;
  text-decoration:none;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  min-height:auto;
}
.svc-card--compact:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-line);
}
.svc-card--compact .svc-eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-deep);
}
.svc-card--compact h3{
  font-family:var(--heading);font-size:18px;font-weight:600;
  line-height:1.3;margin:0;color:var(--navy);letter-spacing:-.005em;
}
.svc-card--compact .svc-pos{
  font-size:13.5px;line-height:1.55;color:var(--gray);margin:0;flex:1;
}
.svc-card--compact .svc-arrow{
  margin-top:6px;
  color:var(--gold-deep);
  font-family:var(--heading);font-size:13px;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
  transition:gap .2s var(--ease);
}
.svc-card--compact .svc-arrow svg{width:13px;height:13px}
.svc-card--compact:hover .svc-arrow{gap:10px}
@media(max-width:960px){.svc-grid--compact{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid--compact{grid-template-columns:1fr}}


/* ═════════════════════════════════════════════════════════════════
   RESPONSIVE FINISHING
   Audit pass after adding new components + 9 services + longer CTA.
   These rules layer on top of the existing breakpoint structure.
   ═════════════════════════════════════════════════════════════════ */

/* Never horizontal-scroll the page on any viewport */
html, body{overflow-x:hidden}

/* Nav: burger now kicks in at 1000px so the 5 menu items + the
   longer "Book a Consultation" CTA never overflow on tablet widths. */
@media(max-width:1000px){
  .nav-links, .nav-cta{display:none}
  .nav-burger{display:flex}
  .nav-inner{height:72px;padding:0 28px;gap:0}
}
@media(max-width:560px){
  .nav-inner{padding:0 18px}
}

/* Ensure tappable controls hit ≥44px on touch */
@media(max-width:1000px){
  .nav-burger{width:44px;height:44px}
}
@media(max-width:768px){
  .btn-pill, .btn-hero, .btn-gold, .btn-outline, .btn-ghost-light{
    min-height:46px;
  }
}

/* Trust grid responsive rules now live inline with the trust-card block above. */

/* Compact 9-service grid — tighter on small phones */
@media(max-width:480px){
  .svc-card--compact{padding:22px 20px;gap:10px}
  .svc-card--compact h3{font-size:17px}
  .svc-card--compact .svc-pos{font-size:13px}
}

/* Page-hero typography on small phones — keep it premium, not cramped */
@media(max-width:480px){
  .page-hero{padding:104px 0 44px}
  .page-hero-inner h1{font-size:clamp(28px,8vw,40px);letter-spacing:-.035em;margin-bottom:16px}
  .page-hero-inner p{font-size:15px;line-height:1.55}
}

/* Service blocks: keep mock dashboards from overflowing on phone */
@media(max-width:480px){
  .service-block{gap:32px}
  .mock{max-width:100%;width:100%;box-sizing:border-box}
  .mock-row{padding:8px 10px}
  .mock-name{font-size:12.5px}
  .service-content h2{font-size:26px;letter-spacing:-.03em}
  .service-list li{font-size:14.5px}
}

/* Contact form + Calendly inline on phones */
@media(max-width:480px){
  .calendly-inline-widget{height:720px!important}
  .contact-form{padding:24px 20px;border-radius:var(--r-lg)}
  .contact-form h2{font-size:22px}
  .contact-form button[type="submit"]{width:100%;justify-content:center}
}

/* Case study summary card on phones */
@media(max-width:480px){
  .cs-summary{padding:24px 20px}
  .cs-outcome{padding:14px 16px}
  .cs-outcome strong{font-size:26px}
  .cs-hero h1{font-size:clamp(26px,7.5vw,38px);letter-spacing:-.03em}
}

/* Founder portrait responsive sizing now lives with the .founder-row block above. */

/* Marquee: slightly slower scroll on mobile so it doesn't feel manic */
@media(max-width:768px){
  .marquee-track{animation-duration:36s}
}

/* Final CTA / cta-banner: stack vertically + buttons fill width on phone */
@media(max-width:480px){
  .final-cta-btns{width:100%;flex-direction:column;align-items:stretch}
  .final-cta-btns .btn-gold,
  .final-cta-btns .btn-ghost-light,
  .final-cta-btns .btn-outline{
    width:100%;justify-content:center;
  }
  .cta-banner{padding:24px 20px}
  .cta-banner-text h3{font-size:22px}
}

/* ═════════════════════════════════════════════════════════════════
   FOOTER RESPONSIVE (new layout: brand | company | services-split)
   ═════════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .foot-top{
    grid-template-columns:1fr 1fr;
    gap:48px;
  }
  .foot-col--services{grid-column:1 / -1}
  .foot-services-grid{gap:14px 40px}
}
@media(max-width:720px){
  .foot-top{grid-template-columns:1fr;gap:40px}
  .foot-brand{max-width:none}
  .foot-services-grid{grid-template-columns:1fr 1fr;gap:12px 24px}
}
@media(max-width:480px){
  .foot-top{gap:36px;padding-bottom:48px}
  .foot-services-grid{grid-template-columns:1fr;gap:10px}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:14px;padding:24px 0;text-align:left}
  .foot-utility{gap:20px;flex-wrap:wrap}
  .foot-contact-value{font-size:16px}
  .foot-col h4{font-size:17px}
  .foot-tagline{font-size:14px}
}
