@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --p:#1e3a5f;--p2:#163050;--a:#C2410C;--a2:#a83609;
  --bg:#fff;--bg2:#f8fafc;--txt:#1d293d;--mut:#62748e;
  --bdr:rgba(30,58,95,.10);--bdr2:rgba(30,58,95,.20);
  --r:.5rem;--rl:.75rem;--f:'Inter',-apple-system,sans-serif;
  --sh:0 4px 24px rgba(30,58,95,.08);--shl:0 8px 48px rgba(30,58,95,.14);
  --tr:.3s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--f);color:var(--txt);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{color:var(--p);font-weight:500;line-height:1.25;font-family:var(--f)}
p{color:var(--mut);line-height:1.7}

.wrap{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.wrap-md{max-width:960px;margin:0 auto;padding:0 1.5rem}
.wrap-sm{max-width:760px;margin:0 auto;padding:0 1.5rem}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;border-radius:var(--r);font-family:var(--f);font-weight:500;font-size:1rem;cursor:pointer;border:2px solid transparent;transition:all var(--tr);text-decoration:none;line-height:1;white-space:nowrap}
.btn svg{width:20px;height:20px;flex-shrink:0;transition:transform var(--tr)}
.btn:hover svg{transform:translateX(3px)}
.btn-p{background:var(--p);color:#fff;border-color:var(--p);box-shadow:var(--sh)}
.btn-p:hover{background:var(--p2);border-color:var(--p2);box-shadow:var(--shl);transform:translateY(-1px);color:#fff}
.btn-a{background:var(--a);color:#fff;border-color:var(--a);box-shadow:var(--sh)}
.btn-a:hover{background:var(--a2);box-shadow:var(--shl);transform:translateY(-1px);color:#fff}
.btn-ol{background:transparent;color:var(--p);border-color:rgba(30,58,95,.3)}
.btn-ol:hover{background:var(--p);color:#fff;transform:translateY(-1px)}
.btn-olw{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-olw:hover{background:#fff;color:var(--p);transform:translateY(-1px)}
.btn-lg{padding:1.1rem 2.5rem;font-size:1.125rem}

/* CARDS */
.card{background:#fff;border:1px solid var(--bdr);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh);transition:all var(--tr)}
.card:hover{box-shadow:var(--shl);transform:translateY(-2px);border-color:var(--bdr2)}
.card-pl{border-left:4px solid var(--p);border-radius:0 var(--rl) var(--rl) 0}
.card-al{border-left:4px solid var(--a);border-radius:0 var(--rl) var(--rl) 0}

/* DIVIDER */
.divider{width:100%;height:2px;background:linear-gradient(to right,transparent,var(--bdr) 30%,var(--bdr) 70%,transparent);position:relative}
.divider::after{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--a);box-shadow:0 0 8px rgba(194,65,12,.5)}

/* SPARK */
.spark-row{display:inline-flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.spark-row .ln{width:3rem;height:1px;background:linear-gradient(to right,transparent,rgba(30,58,95,.4))}
.spark-row .ln.r{background:linear-gradient(to left,transparent,rgba(30,58,95,.4))}
.spark{width:8px;height:8px;border-radius:50%;background:var(--a);position:relative;flex-shrink:0}
.spark::before,.spark::after{content:'';position:absolute;border-radius:50%;animation:spk 2s ease-in-out infinite}
.spark::before{inset:-4px;border:1px solid rgba(194,65,12,.35)}
.spark::after{inset:-9px;border:1px solid rgba(194,65,12,.15);animation-delay:.5s}
@keyframes spk{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.5}}

.net-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;opacity:.045;z-index:0;background-image:radial-gradient(circle,#1e3a5f 1px,transparent 1px);background-size:40px 40px}
#neural{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}

/* ═══ HEADER — always visible, transparent until scrolled ═══ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:999;
  transition:all var(--tr);
  background:transparent; /* transparent by default */
}
#hdr.scrolled{
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--bdr);
  box-shadow:0 2px 20px rgba(30,58,95,.07);
}
.hdr-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1280px;margin:0 auto;padding:1rem 1.5rem;
  transition:padding var(--tr);
}
#hdr.scrolled .hdr-inner{padding:.75rem 1.5rem}

/* LOGO */
.logo{display:flex;align-items:center;gap:1rem;text-decoration:none;flex-shrink:0;cursor:pointer}
.logo svg{transition:transform var(--tr);flex-shrink:0}
.logo:hover svg{transform:scale(1.04)}
.logo-text{display:flex;flex-direction:column;line-height:1.15}
.logo-name{
  font-size:.9375rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--p); /* always dark — source uses text-[#1d293d] variant=light */
}
.logo-tag{font-size:.585rem;color:var(--mut);letter-spacing:.15em;text-transform:uppercase;margin-top:2px}

/* NAV — text-muted-foreground (dark) always, exact from source */
.nav{display:flex;align-items:center;gap:.125rem}
.nav a{
  padding:.5rem .75rem;font-size:.875rem;
  color:var(--mut); /* always dark grey — source: text-muted-foreground */
  border-radius:var(--r);transition:all var(--tr);white-space:nowrap
}
.nav a:hover,.nav a.cur{color:var(--p);background:rgba(30,58,95,.05);font-weight:500}

/* BURGER */
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.burger span{display:block;width:24px;height:2px;background:var(--p);border-radius:2px;transition:all var(--tr)}
.burger.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE MENU */
.mob{display:none;position:fixed;top:0;right:0;bottom:0;width:min(320px,88vw);background:#fff;box-shadow:-8px 0 48px rgba(30,58,95,.18);z-index:1000;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.mob.on{transform:translateX(0)}
.mob-top{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--p)}
.mob-top .logo-name{color:#fff}.mob-top .logo-tag{color:rgba(255,255,255,.65)}
.mob-nav{padding:1.5rem 1rem;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}
.mob-nav a{display:block;padding:.875rem 1rem;color:var(--mut);border-radius:var(--r);font-size:.9375rem;transition:all var(--tr)}
.mob-nav a:hover,.mob-nav a.cur{color:var(--p);background:rgba(30,58,95,.06);font-weight:500}
.ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.2);backdrop-filter:blur(2px);z-index:999}
.ov.on{display:block}

/* ═══ HERO — pt-24 like source so header doesn't overlap content ═══ */
#hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding-top:6rem; /* matches source pt-24 */
}
.hero-bgs{position:absolute;inset:0;pointer-events:none}
.hero-bg{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-bg.on{opacity:.15}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  -webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);
  mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);
}
.hero-ct{
  position:relative;z-index:2;text-align:center;
  max-width:896px;margin:0 auto;padding:5rem 1.5rem 5rem;width:100%
}
/* NO slide-tag — source doesn't have it */
.slide{display:none}
.slide.on{display:block;animation:sli .5s cubic-bezier(.22,1,.36,1) forwards}
@keyframes sli{from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}
.slide h1{font-size:clamp(2rem,5vw,3.75rem);color:var(--p);font-weight:500;line-height:1.18;margin-bottom:1.5rem;letter-spacing:-.025em}
.slide p{font-size:clamp(1rem,2vw,1.2rem);color:var(--mut);max-width:640px;margin:0 auto 2.5rem;line-height:1.75}
.hero-arrows{position:absolute;top:50%;left:1rem;right:1rem;display:flex;justify-content:space-between;transform:translateY(-50%);pointer-events:none;z-index:20}
.arr-btn{pointer-events:all;width:48px;height:48px;border-radius:var(--r);background:rgba(255,255,255,.8);backdrop-filter:blur(8px);border:1px solid rgba(30,58,95,.3);color:var(--p);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--tr);box-shadow:0 2px 12px rgba(30,58,95,.1)}
.arr-btn:hover{background:var(--p);color:#fff;border-color:var(--p)}
.arr-btn svg{width:24px;height:24px}
.dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.75rem;z-index:20;align-items:center}
.dot{height:8px;border-radius:4px;background:rgba(30,58,95,.2);cursor:pointer;transition:all .35s ease;width:8px;border:none;padding:0}
.dot.on{width:3rem;background:var(--p)}

/* ═══ ABOUT ═══ */
#about{position:relative;padding:8rem 1.5rem;background:rgba(255,255,255,.4)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1100px;margin:0 auto}
.img-outer{position:relative}
.img-outer::before{content:'';position:absolute;top:-1rem;left:-1rem;width:4rem;height:4rem;border-left:2px solid rgba(194,65,12,.3);border-top:2px solid rgba(194,65,12,.3);border-radius:8px 0 0 0;pointer-events:none}
.img-outer::after{content:'';position:absolute;bottom:-1rem;right:-1rem;width:4rem;height:4rem;border-right:2px solid rgba(194,65,12,.3);border-bottom:2px solid rgba(194,65,12,.3);border-radius:0 0 8px 0;pointer-events:none}
.img-wrap{position:relative;aspect-ratio:1;border-radius:var(--r);border:2px solid rgba(30,58,95,.2);background:linear-gradient(135deg,rgba(30,58,95,.05),rgba(30,58,95,.1));padding:1rem;overflow:hidden}
.prof{position:absolute;inset:1rem;width:calc(100% - 2rem);height:calc(100% - 2rem);object-fit:cover;border-radius:6px;opacity:0;transition:opacity 1s ease}
.prof.on{opacity:1}
.corner-dots{position:absolute;inset:0;pointer-events:none;animation:rot 20s linear infinite}
.corner-dots span{position:absolute;width:12px;height:12px;border-radius:50%}
.corner-dots span:nth-child(1){top:0;left:0;background:var(--p)}
.corner-dots span:nth-child(2){top:0;right:0;background:var(--p)}
.corner-dots span:nth-child(3){bottom:0;left:0;background:var(--p)}
.corner-dots span:nth-child(4){bottom:0;right:0;background:var(--a)}
@keyframes rot{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.text-card-p{padding:1.5rem;background:var(--bg2);border-left:4px solid var(--p);border-radius:0 var(--rl) var(--rl) 0}
.text-card-a{padding:1.5rem;background:#fff;border-left:4px solid rgba(194,65,12,.5);border-radius:0 var(--rl) var(--rl) 0;box-shadow:var(--sh)}
.text-card-p p,.text-card-a p{margin:0;font-size:1.0625rem;color:var(--mut);line-height:1.8}

/* ═══ WHAT I DO (6 cards) ═══ */
#what{padding:5rem 1.5rem;background:linear-gradient(to bottom,#fff,var(--bg2) 50%,#fff);position:relative}
.what-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:3rem auto 0}
.what-card{background:#fff;border:2px solid var(--bdr);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh);transition:all var(--tr);text-decoration:none;display:flex;flex-direction:column}
.what-card:hover{box-shadow:var(--shl);transform:translateY(-3px);border-color:rgba(30,58,95,.25)}
.what-card h3{font-size:1.125rem;font-weight:500;color:var(--p);margin-bottom:.625rem}
.what-card p{font-size:.9375rem;color:var(--mut);line-height:1.65;flex:1;margin-bottom:1rem}
.what-cta{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--p);transition:gap var(--tr)}
.what-card:hover .what-cta{gap:.625rem}
.what-cta svg{width:16px;height:16px}

/* ═══ PROJECTS ═══ */
#projects{padding:7rem 1.5rem;background:linear-gradient(to bottom,#fff,var(--bg2) 50%,#fff);position:relative}
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:1100px;margin:3.5rem auto 0}
.pcard{display:block;text-decoration:none;cursor:pointer}
.pcard-inner{height:100%;border-radius:var(--rl);border:2px solid var(--bdr);overflow:hidden;transition:all var(--tr);background:#fff}
.pcard-inner:hover{box-shadow:0 20px 60px rgba(30,58,95,.18);transform:translateY(-3px)}
.pcard-inner.is-a:hover{border-color:rgba(194,65,12,.35)}
.pcard-inner.is-p:hover{border-color:rgba(30,58,95,.35)}
.pbar{height:4px}.pbar.p{background:var(--p)}.pbar.a{background:var(--a)}
.pbody{padding:2rem}
.picon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.picon.p{background:var(--p)}.picon.a{background:var(--a)}
.picon svg{color:#fff;width:24px;height:24px}
.pcard h3{font-size:1.2rem;font-weight:500;margin-bottom:.75rem}
.pcard h3.p{color:var(--p)}.pcard h3.a{color:var(--a)}
.pdesc{color:var(--p);font-weight:500;font-style:italic;font-size:.9375rem;margin-bottom:.75rem}
.psub{color:var(--mut);font-size:.9375rem;line-height:1.65;margin-bottom:1.25rem}
.pcta{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500}
.pcta.p{color:var(--p)}.pcta.a{color:var(--a)}
.pcta svg{width:16px;height:16px;transition:transform var(--tr)}
.pcard:hover .pcta svg{transform:translateX(4px)}

/* ═══ LATEST WORK ═══ */
#latest{padding:5rem 1.5rem;background:linear-gradient(to bottom,rgba(248,250,252,.5),rgba(255,255,255,.5))}
.ltitle{font-size:clamp(2rem,4vw,3.5rem);font-weight:700;background:linear-gradient(135deg,#0b3c5d,#1e3a5f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;line-height:1.2}
.feat{background:linear-gradient(135deg,#eff6ff,#eef2ff);border:2px solid rgba(30,58,95,.2);border-radius:1.25rem;box-shadow:0 8px 48px rgba(30,58,95,.14);overflow:hidden;margin-bottom:1.5rem}
.feat-inner{display:grid;grid-template-columns:1fr 1fr}
.feat-text{padding:3rem;display:flex;flex-direction:column;justify-content:center}
.feat-ic{width:72px;height:72px;border-radius:50%;background:rgba(30,58,95,.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;flex-shrink:0}
.feat-img{background-size:cover;background-position:center;background-color:var(--bg2);min-height:280px}
.bento{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem}
.bento-wide{background:#fff;border:2px solid rgba(30,58,95,.15);border-radius:1.25rem;box-shadow:var(--sh);transition:all var(--tr);padding:2rem;display:flex;align-items:flex-start;gap:1.5rem}
.bento-wide:hover{border-color:var(--p);box-shadow:var(--shl);transform:translateY(-2px)}
.bento-narrow{background:#fff;border:1px solid #e5e7eb;border-radius:1.25rem;box-shadow:0 4px 12px rgba(0,0,0,.06);padding:1.5rem;display:flex;flex-direction:column;transition:all var(--tr)}
.bento-narrow:hover{border-color:rgba(30,58,95,.25);box-shadow:var(--shl);transform:translateY(-2px)}
.bic-lg{width:64px;height:64px;border-radius:1rem;background:rgba(30,58,95,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bic-lg svg{color:var(--p);width:32px;height:32px}
.bic-sm{width:56px;height:56px;border-radius:50%;background:rgba(30,58,95,.08);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;flex-shrink:0}
.bic-sm svg{color:var(--p);width:24px;height:24px}
.lgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}
.lcard{background:#fff;border:1px solid #e5e7eb;border-radius:1.25rem;box-shadow:0 4px 12px rgba(0,0,0,.06);padding:1.5rem;display:flex;flex-direction:column;transition:all var(--tr)}
.lcard:hover{border-color:rgba(30,58,95,.25);box-shadow:var(--shl);transform:translateY(-2px)}
.lic{width:52px;height:52px;border-radius:50%;background:rgba(30,58,95,.08);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.lic svg{color:var(--p);width:24px;height:24px}
.lcard h3{font-size:1.05rem;font-weight:700;color:var(--txt);margin-bottom:.375rem}
.lsub{color:var(--p);font-style:italic;font-size:.875rem;margin-bottom:.75rem}
.ldesc{color:#4b5563;font-size:.875rem;line-height:1.65;flex:1;margin-bottom:1.25rem}
.lbtn{display:block;width:100%;padding:.8rem;border:1px solid rgba(30,58,95,.2);border-radius:var(--r);color:var(--p);font-size:.9375rem;font-weight:500;text-align:center;cursor:pointer;background:#fff;transition:all var(--tr);text-decoration:none;font-family:var(--f)}
.lbtn:hover{background:rgba(30,58,95,.05);border-color:var(--p)}
/* Subscribe */
.sub-card{background:linear-gradient(135deg,#0b3c5d,#0d4d73);border-radius:1.25rem;box-shadow:var(--shl);overflow:hidden}
.sub-inner{padding:4rem 2rem;text-align:center;position:relative;z-index:2}
.sub-inner h3{font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:#fff;margin-bottom:.875rem}
.sub-inner>p{color:rgba(219,234,254,.9);font-size:1.1rem;line-height:1.7;margin-bottom:2rem}
.sub-form{display:flex;gap:.75rem;max-width:600px;margin:0 auto 1.25rem;flex-wrap:wrap}
.sub-form input{flex:1;min-width:200px;padding:1rem 1.25rem;border-radius:var(--r);background:#fff;border:none;font-family:var(--f);font-size:1rem;color:var(--txt);outline:none}
.sub-btn{background:#fff;color:var(--p);border:none;padding:1rem 1.5rem;border-radius:var(--r);font-family:var(--f);font-size:1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all var(--tr);white-space:nowrap}
.sub-btn:hover{background:#f1f5f9;transform:translateY(-1px)}
.sub-or{display:flex;align-items:center;gap:1rem;max-width:600px;margin:0 auto 1.25rem}
.sub-or::before,.sub-or::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.2)}
.sub-or span{color:rgba(219,234,254,.7);font-size:.875rem}
#nl-msg{font-size:.9375rem;min-height:1.4rem;margin-top:.5rem;color:#fff}

/* ═══ FEATURED MEDIA ═══ */
#media{padding:8rem 1.5rem;background:linear-gradient(to bottom,#fff,rgba(248,250,252,.3));position:relative;overflow:hidden}
#media::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 2px 2px,rgba(30,58,95,.04) 1px,transparent 0);background-size:40px 40px;pointer-events:none}
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1280px;margin:4rem auto 0}
.mcard{background:#fff;border-radius:1rem;border:2px solid rgba(30,58,95,.3);overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;text-decoration:none;box-shadow:0 4px 24px rgba(30,58,95,.08)}
.mcard:hover{transform:translateY(-8px);box-shadow:0 8px 48px rgba(30,58,95,.14);border-color:var(--a)}
.mthumb{aspect-ratio:16/9;background:linear-gradient(135deg,rgba(30,58,95,.2),rgba(194,65,12,.1));position:relative;overflow:hidden}
.mthumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.mcard:hover .mthumb img{transform:scale(1.1)}
.mplay-ov{position:absolute;inset:0;background:rgba(30,58,95,.4);display:flex;align-items:center;justify-content:center;transition:background .3s ease}
.mcard:hover .mplay-ov{background:rgba(30,58,95,.2)}
.mplay-btn{background:rgba(255,255,255,.9);border-radius:50%;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.2);transition:transform .3s ease}
.mcard:hover .mplay-btn{transform:scale(1.1)}
.mplay-btn svg{width:40px;height:40px;color:var(--a);fill:var(--a)}
.mcat-badge{position:absolute;top:1rem;left:1rem;background:rgba(194,65,12,.9);backdrop-filter:blur(4px);padding:.375rem 1rem;border-radius:999px}
.mcat-badge span{color:#fff;font-size:.875rem;font-weight:500}
.mbody{padding:1.5rem}
.mcard h3{font-size:1.0625rem;font-weight:500;color:var(--p);line-height:1.4;margin-bottom:.5rem;transition:color .3s ease}
.mcard:hover h3{color:var(--a)}
.mvenue{font-size:.875rem;color:var(--mut)}

/* Media CTA block */
.media-cta{background:linear-gradient(135deg,#1e3a5f,#163050);border-radius:1rem;border:2px solid #1e3a5f;box-shadow:var(--shl);padding:2rem 2.5rem;text-align:center;margin-top:3rem}
.media-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.stat-pill{padding:1.5rem;border-radius:.75rem;background:#fff;text-align:center}
.stat-pill.accent{border:2px solid rgba(194,65,12,.4)}
.stat-pill.primary{border:2px solid rgba(30,58,95,.4)}
.stat-pill p{font-size:1.0625rem;font-weight:500;color:var(--mut);margin:0}

/* ═══ CONTACT ═══ */
#contact{padding:5rem 1.5rem;background:linear-gradient(to bottom,rgba(255,255,255,.4),rgba(249,250,251,.4))}
.cgrid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;max-width:1100px;margin:3rem auto 0;align-items:start}
.cf-card{background:#fff;border:2px solid var(--bdr);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh);transition:all var(--tr)}
.cf-card:hover{border-color:rgba(30,58,95,.3)}
.cf-head{display:flex;align-items:center;gap:.75rem;margin-bottom:.375rem}
.cf-head h3{font-size:1.125rem;color:var(--txt);font-weight:500}
.cf-head svg{width:20px;height:20px;color:var(--p)}
.cf-sub{font-size:.875rem;color:var(--mut);margin-bottom:1.5rem}
.field{margin-bottom:1.125rem}
.field input,.field textarea,.field select{width:100%;padding:.875rem 1rem;border:1px solid var(--bdr);border-radius:var(--r);font-family:var(--f);font-size:.9375rem;color:var(--txt);background:#fff;transition:border-color var(--tr);outline:none;-webkit-appearance:none;appearance:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--p)}
.field input::placeholder,.field textarea::placeholder{color:rgba(98,116,142,.6)}
.field textarea{min-height:130px;resize:vertical}
.field 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='%2362748e' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.cf-submit{width:100%;background:var(--p);color:#fff;border:none;padding:1.25rem;border-radius:var(--r);font-family:var(--f);font-size:1.0625rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--tr)}
.cf-submit:hover{background:var(--p2);transform:translateY(-1px);box-shadow:var(--shl)}
#cf-msg{margin-top:.875rem;font-size:.9375rem;text-align:center;min-height:1.4rem}
.clink{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border-radius:var(--rl);border:2px solid var(--bdr);transition:all var(--tr);text-decoration:none;box-shadow:0 2px 8px rgba(30,58,95,.06);margin-bottom:1rem}
.clink:hover{border-color:var(--p);transform:translateX(4px)}
.clink-ic{width:44px;height:44px;border-radius:50%;background:rgba(30,58,95,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.clink-ic svg{color:var(--p);width:22px;height:22px}
.clink span{color:var(--mut);font-size:1rem;transition:color var(--tr)}
.clink:hover span{color:var(--p)}
.resp-box{padding:2rem;background:var(--bg2);border-radius:var(--rl);border:2px solid rgba(30,58,95,.12)}
.resp-box h4{font-size:1rem;font-weight:600;color:var(--p);margin-bottom:.5rem}
.resp-box p{font-size:.9375rem;color:var(--mut);line-height:1.6;margin:0}

/* FOOTER */
#ftr{background:#fff;border-top:1px solid rgba(30,58,95,.1);padding:3rem 1.5rem}
.ftr-in{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:2rem}
.soc-links{display:flex;gap:1rem}
.soc-a{width:44px;height:44px;border-radius:50%;background:var(--bg2);border:2px solid rgba(30,58,95,.2);display:flex;align-items:center;justify-content:center;color:var(--p);transition:all var(--tr);text-decoration:none}
.soc-a:hover{border-color:var(--p);box-shadow:var(--sh);transform:scale(1.1)}
.soc-a.off{opacity:.4;cursor:not-allowed;pointer-events:none}
.soc-a svg{width:20px;height:20px}
.copy{font-size:.875rem;color:var(--mut);text-align:center}

/* INNER PAGES */
.pg-hero{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:8rem 1.5rem 4rem;position:relative;overflow:hidden;text-align:center}
.pg-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.pg-hero-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.96) 0%,rgba(248,250,252,.93) 100%)}
.pg-hero-ct{position:relative;z-index:2;max-width:840px;margin:0 auto}
.pg-hero h1{font-size:clamp(2.5rem,6vw,4.5rem);color:var(--p);font-weight:500;line-height:1.15;margin-bottom:1.5rem;letter-spacing:-.03em}
.lead{font-size:clamp(1.1rem,2.5vw,1.4rem);color:var(--txt);line-height:1.7;max-width:700px;margin:0 auto}
.lead-accent{color:var(--p);font-weight:500}
.section{padding:5rem 1.5rem;position:relative}
.section-light{background:linear-gradient(to bottom,#fff,var(--bg2) 50%,#fff)}
.section-navy{background:var(--p);padding:5rem 1.5rem}
.section-navy h2{color:#fff;font-size:clamp(1.75rem,3.5vw,2.5rem);margin-bottom:1.5rem}
.section-navy p{color:rgba(255,255,255,.85)}
.accent-quote{font-style:italic;color:rgba(255,255,255,.95);border-left:4px solid rgba(194,65,12,.7);padding:1.5rem;background:rgba(255,255,255,.08);border-radius:0 var(--r) var(--r) 0;margin:2rem 0;font-size:1.05rem;line-height:1.8}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.1rem,2.5vw,1.375rem)}
.badge{display:inline-flex;padding:.25rem .875rem;background:rgba(30,58,95,.07);color:var(--p);border:1px solid var(--bdr);border-radius:999px;font-size:.8125rem;font-weight:600;margin-bottom:1rem}
.quote-pull{font-size:1.1rem;color:var(--a);font-style:italic;border-left:4px solid rgba(194,65,12,.4);padding:1.25rem 1.5rem;background:rgba(194,65,12,.04);border-radius:0 var(--r) var(--r) 0;margin:1.5rem 0;line-height:1.7}
.quote-card{background:linear-gradient(135deg,rgba(30,58,95,.04),rgba(194,65,12,.04));border-radius:1rem;padding:2rem 2.5rem;border:2px solid rgba(30,58,95,.12);text-align:center}
.quote-card p{font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--p);font-style:italic;line-height:1.7;margin:0}
.text-card-primary{padding:1.5rem;background:var(--bg2);border-left:4px solid var(--p);border-radius:0 var(--rl) var(--rl) 0}
.text-card-accent{padding:1.5rem;background:#fff;border-left:4px solid rgba(194,65,12,.5);border-radius:0 var(--rl) var(--rl) 0;box-shadow:var(--sh)}
.text-card-primary p,.text-card-accent p{margin:0;font-size:1.0625rem;color:var(--mut);line-height:1.8}
.check-item{display:flex;align-items:flex-start;gap:.875rem;margin-bottom:.875rem}
.check-item svg{width:20px;height:20px;flex-shrink:0;margin-top:2px}
.check-item p{margin:0;font-size:.9375rem;line-height:1.6}
.principle-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh);transition:all var(--tr)}
.principle-card:hover{box-shadow:var(--shl);transform:translateY(-2px)}
.principle-ic{width:48px;height:48px;border-radius:var(--r);background:rgba(30,58,95,.08);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.principle-ic svg{color:var(--p);width:24px;height:24px}
.testimonial{background:linear-gradient(135deg,rgba(30,58,95,.03),rgba(30,58,95,.07));border:1px solid var(--bdr);border-radius:var(--rl);padding:2rem;position:relative}
.testimonial::before{content:'"';position:absolute;top:.5rem;left:1.25rem;font-size:4rem;color:var(--p);opacity:.12;line-height:1;font-family:Georgia,serif}
.testimonial p{font-style:italic;color:var(--txt);font-size:1.0625rem;line-height:1.7;margin:0;padding-top:.5rem}
.media-section-title{font-size:1.25rem;font-weight:500;border-bottom:2px solid var(--bdr);padding-bottom:.75rem;margin-bottom:1.5rem;color:var(--p)}

/* AOS */
[data-aos]{opacity:0;transition:opacity .75s ease,transform .75s ease}
[data-aos="fade-up"]{transform:translateY(40px)}
[data-aos="fade-right"]{transform:translateX(-40px)}
[data-aos="fade-left"]{transform:translateX(40px)}
[data-aos].aos-on{opacity:1!important;transform:none!important}

/* RESPONSIVE */
@media(max-width:1024px){
  .nav{display:none}.burger{display:flex}.mob{display:flex}
  .about-grid,.cgrid{grid-template-columns:1fr;gap:2.5rem}
  .proj-grid,.what-grid{grid-template-columns:1fr}
  .mgrid{grid-template-columns:1fr 1fr}
  .feat-inner,.bento{grid-template-columns:1fr}
  .feat-img{display:none}
  .media-stats{grid-template-columns:1fr}
}
@media(max-width:768px){
  .timeline-spine{display:none;}
  .hero-ct{padding:3rem 1rem 5rem}
  .mgrid,.lgrid{grid-template-columns:1fr}
  .sub-form{flex-direction:column}
}
