:root{
  --teal:#2563C9;
  --teal-deep:#1B4894;
  --ink:#111722;
  --ink-soft:#2a3140;
  --paper:#f7f8fb;
  --paper-warm:#eceff5;
  --line:#dce0ea;
  --grey:#7e828e;
  --grey-light:#aeb3c0;
  --serif:'Spectral', Georgia, serif;
  --sans:'Jost', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family:var(--serif);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
.narrow{max-width:820px;margin:0 auto;padding:0 32px}

/* ---------- LOGO ---------- */
.logo{display:inline-flex;align-items:flex-start;font-family:var(--serif);font-weight:400;line-height:1;letter-spacing:.18em;text-decoration:none}
.logo .ltrs{position:relative;display:inline-block}
.logo .dot{width:.20em;height:.20em;border-radius:50%;background:var(--teal);display:inline-block;margin-left:.12em;align-self:flex-start;margin-top:.05em}
.logo.stacked{flex-direction:column;align-items:flex-start}
.logo .sub{font-family:var(--sans);font-weight:300;letter-spacing:.42em;font-size:.26em;margin-top:.55em;padding-top:.5em;border-top:1px solid currentColor;width:100%;color:inherit;opacity:.75}

header .nav{max-width:none;margin:0;padding:0 clamp(32px,6vw,110px)}
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(21,23,26,0);transition:background .4s ease, box-shadow .4s ease, padding .4s ease;padding:26px 0}
header.scrolled{background:rgba(21,23,26,.97);box-shadow:0 1px 30px rgba(0,0,0,.18);padding:16px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.nav .logo{color:#fff;font-size:30px}
.nav .logo .dot{background:var(--teal)}
.nav ul{list-style:none;display:flex;gap:38px;align-items:center}
.nav a.link{font-family:var(--sans);font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.82);text-decoration:none;font-weight:400;transition:color .25s;position:relative}
.nav a.link::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--teal);transition:width .3s}
.nav a.link:hover{color:#fff}
.nav a.link:hover::after{width:100%}
.nav .cta{font-family:var(--sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;background:var(--teal);color:#fff;padding:12px 24px;border-radius:2px;text-decoration:none;transition:background .25s,transform .25s}
.nav .cta:hover{background:var(--teal-deep);transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;
  background:#0d1626}
/* full-bleed photo, its green background matches the hero so it blends seamlessly */
.hero-photo{position:absolute;top:0;right:0;bottom:0;width:100%;z-index:1;pointer-events:none}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero-photo::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,#0d1626 0%,#0d1626 22%,rgba(13,22,38,.7) 40%,rgba(13,22,38,.15) 58%,transparent 72%)}
.hero::before{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;background:
  radial-gradient(circle at 12% 40%, rgba(37,99,201,.10), transparent 50%);}
.hero::after{content:"";position:absolute;inset:0;z-index:2;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
/* full-width inner, text hard-left with page margin */
.hero-inner{position:relative;z-index:5;width:100%;padding:0 clamp(32px,6vw,110px);max-width:none}
.hero-content{max-width:560px}
.hero .eyebrow{font-family:var(--sans);font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--teal);margin-bottom:26px;opacity:0;animation:rise .9s .2s forwards}
.hero h1{font-size:clamp(40px,5.6vw,72px);font-weight:300;line-height:1.06;letter-spacing:-.01em;margin-bottom:26px;opacity:0;animation:rise .9s .35s forwards}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero .role{font-family:var(--sans);font-size:14px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey-light);margin-bottom:44px;opacity:0;animation:rise .9s .5s forwards}
.hero .actions{display:flex;gap:18px;flex-wrap:wrap;opacity:0;animation:rise .9s .65s forwards}
.btn{font-family:var(--sans);font-size:14px;letter-spacing:.12em;text-transform:uppercase;padding:16px 34px;border-radius:2px;text-decoration:none;transition:all .3s;display:inline-block;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(37,99,201,.3)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
/* arrow scroll indicator */
.scroll-cue{position:absolute;bottom:34px;left:clamp(32px,6vw,110px);z-index:4;width:46px;height:46px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;animation:rise .9s 1s forwards,bob 2.2s 1.2s ease-in-out infinite;transition:border-color .3s,background .3s}
.scroll-cue:hover{border-color:var(--teal);background:rgba(37,99,201,.12)}
.scroll-cue svg{width:18px;height:18px;stroke:#fff;stroke-width:1.6;fill:none}

@keyframes rise{to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
[class*=anim]{opacity:0;transform:translateY(30px)}
.hero .eyebrow,.hero h1,.hero .role,.hero .actions{transform:translateY(30px)}

/* ---------- SECTION SHELL ---------- */
section{padding:110px 0;position:relative}
.tag{font-family:var(--sans);font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--teal);display:flex;align-items:center;gap:14px;margin-bottom:26px}
.tag::before{content:"";width:34px;height:1px;background:var(--teal)}
h2{font-size:clamp(30px,4.4vw,52px);font-weight:300;line-height:1.14;letter-spacing:-.01em;margin-bottom:30px}
h2 em{font-style:italic;color:var(--teal)}
h3{font-size:26px;font-weight:500;margin-bottom:12px;line-height:1.25}
p{margin-bottom:20px;color:var(--ink-soft)}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- ABOUT ---------- */
.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:70px;align-items:start}
.portrait{position:relative}
.portrait .frame{aspect-ratio:3/4;border-radius:3px;background:var(--paper-warm);overflow:hidden;position:relative;box-shadow:0 30px 60px -25px rgba(0,0,0,.25)}
.portrait .frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.portrait .frame::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(37,99,201,.06));pointer-events:none;z-index:2}
.portrait .badge{position:absolute;bottom:-26px;right:-20px;background:var(--ink);color:#fff;padding:24px 30px;border-radius:3px;box-shadow:0 20px 40px -15px rgba(0,0,0,.4)}
.portrait .badge .num{font-size:42px;font-weight:300;color:var(--teal);line-height:1}
.portrait .badge .lbl{font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-light);margin-top:6px}
.about-body p{font-size:19px}
.about-body .intro{font-size:23px;font-weight:300;line-height:1.55;color:var(--ink);margin-bottom:28px}
.about-body strong{font-weight:600;color:var(--ink)}
.about-body em{font-style:italic;color:var(--teal-deep)}
.about-body a.inline{color:var(--teal-deep);text-decoration:none;border-bottom:1px solid var(--teal);transition:.2s}
.about-body a.inline:hover{color:var(--teal)}
.about-wide .intro{font-size:23px;font-weight:300;line-height:1.55;color:var(--ink);margin:14px 0 0;max-width:760px}
.about-cols{column-count:2;column-gap:56px;margin-top:46px}
.about-cols p{font-size:18px;margin:0 0 20px;break-inside:avoid}
.about-cols p:last-child{margin-bottom:0}
.about-wide strong{font-weight:600;color:var(--ink)}
.about-wide em{font-style:italic;color:var(--teal-deep)}
.about-wide a.inline{color:var(--teal-deep);text-decoration:none;border-bottom:1px solid var(--teal);transition:.2s}
.about-wide a.inline:hover{color:var(--teal)}

/* ---------- STATS STRIP ---------- */
.stats{background:var(--ink);color:#fff;padding:80px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat .num{font-size:clamp(42px,5vw,60px);font-weight:300;color:#fff;line-height:1}
.stat .num .plus{color:var(--teal)}
.stat .lbl{font-family:var(--sans);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-light);margin-top:14px;line-height:1.5}

/* ---------- MARQUEE ---------- */
.collab{background:var(--paper-warm);padding:90px 0;overflow:hidden}
.collab .head{text-align:center;margin-bottom:50px}
.marquee{display:flex;gap:0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:64px;padding-right:64px;animation:scroll 38s linear infinite;white-space:nowrap}
.collab:hover .marquee-track{animation-play-state:paused}
.uni{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--ink-soft);display:flex;align-items:center;gap:64px;opacity:.7}
.uni::after{content:"·";color:var(--teal);font-style:normal;font-size:24px}
@keyframes scroll{to{transform:translateX(-50%)}}
.profiles{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:54px}
.profiles a{font-family:var(--sans);font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);text-decoration:none;border:1px solid var(--line);background:var(--paper);padding:14px 26px;border-radius:2px;transition:.3s}
.profiles a:hover{border-color:var(--teal);color:var(--teal-deep);transform:translateY(-3px)}

/* ---------- BIG STATEMENT ---------- */
.problem{background:var(--paper)}
.problem h2{margin-bottom:0;max-width:none}
.problem .intro{margin-top:14px}
.problem-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 56px;margin-top:46px}
.problem-cols .col-center{display:flex;flex-direction:column;justify-content:center}
.problem .stat-line{font-family:var(--serif);font-style:italic;font-size:clamp(18px,1.9vw,22px);color:var(--grey);margin:0 0 22px;break-inside:avoid}
.problem .stat-line:last-child{margin-bottom:0}
.problem .stat-line b{color:var(--teal-deep);font-style:normal;font-weight:600}
.problem .punch{margin-top:44px;padding-top:40px;border-top:1px solid var(--line);font-size:clamp(22px,2.6vw,30px);font-weight:300;line-height:1.5;color:var(--ink);max-width:none}
.problem .punch strong{font-weight:600;color:var(--teal-deep)}

/* ---------- SERVICES ---------- */
.services{background:var(--ink);color:#fff}
.services h2{color:#fff}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:50px;border-top:1px solid rgba(255,255,255,.12);border-left:1px solid rgba(255,255,255,.12)}
.svc{padding:46px 44px;border-right:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);transition:background .4s}
.svc:hover{background:rgba(37,99,201,.08)}
.svc .idx{font-family:var(--sans);font-size:13px;letter-spacing:.2em;color:var(--teal);margin-bottom:20px}
.svc h3{color:#fff;font-weight:500;font-size:24px}
.svc p{color:var(--grey-light);font-size:17px;margin-bottom:0}

/* ---------- PROCESS ---------- */
.process{background:var(--paper-warm)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:54px}
.step{background:var(--paper);border-radius:4px;padding:42px 36px;position:relative;border:1px solid var(--line);transition:transform .4s,box-shadow .4s}
.step:hover{transform:translateY(-6px);box-shadow:0 24px 50px -25px rgba(0,0,0,.22)}
.step .n{font-family:var(--serif);font-size:60px;font-weight:300;color:var(--paper-warm);line-height:1;position:absolute;top:24px;right:30px;-webkit-text-stroke:1px var(--line)}
.step h3{font-size:22px;position:relative;z-index:2}
.step p{font-size:17px;margin-bottom:0}
.step .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);margin-bottom:24px}

/* ---------- TESTIMONIALS ---------- */
.quotes{background:var(--paper)}
.q-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:54px}
.q{background:var(--paper-warm);padding:40px 36px;border-radius:4px;position:relative;border:1px solid var(--line)}
.q .mark{font-family:var(--serif);font-size:80px;color:var(--teal);opacity:.2;line-height:.6;height:30px;display:block}
.q p{font-size:17px;line-height:1.65;color:var(--ink-soft);font-style:italic}
.q p b{color:var(--ink);font-style:normal;font-weight:600}
.q .who{font-family:var(--sans);font-size:14px;letter-spacing:.06em;color:var(--teal-deep);font-weight:500;margin-top:20px;border-top:1px solid var(--line);padding-top:18px}

/* ---------- READING ---------- */
.reading{background:var(--paper-warm)}
.read-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:20px}
.read-list{list-style:none}
.read-list li{padding:20px 0;border-bottom:1px solid var(--line);font-size:17px;color:var(--ink-soft)}
.read-list li:last-child{border-bottom:none}
.read-list li em{color:var(--ink);font-weight:500;font-style:italic}
.read-list a{color:var(--teal-deep);text-decoration:none;border-bottom:1px solid var(--teal)}
.read-intro p{font-size:19px}
.read-intro strong{color:var(--ink);font-weight:600}

/* ---------- FREE CHAPTER ---------- */
.chapter{grid-column:1/-1;margin-top:54px}
.chapter-toggle{width:100%;background:var(--ink);color:#fff;border:none;cursor:pointer;text-align:left;padding:26px 30px;display:grid;grid-template-columns:1fr 30px;grid-template-areas:"label icon" "sub icon";column-gap:20px;row-gap:4px;align-items:center;border-radius:4px;transition:background .25s}
.chapter-toggle:hover{background:#1a2740}
.ct-label{grid-area:label;font-family:var(--sans);font-size:16px;font-weight:600;letter-spacing:.04em}
.ct-sub{grid-area:sub;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--grey-light)}
.ct-icon{grid-area:icon;position:relative;width:18px;height:18px;justify-self:end}
.ct-icon::before,.ct-icon::after{content:"";position:absolute;background:var(--teal);transition:transform .3s,opacity .3s}
.ct-icon::before{top:8px;left:0;width:18px;height:2px}
.ct-icon::after{top:0;left:8px;width:2px;height:18px}
.chapter-toggle[aria-expanded="true"]{border-radius:4px 4px 0 0}
.chapter-toggle[aria-expanded="true"] .ct-icon::after{transform:rotate(90deg);opacity:0}
.chapter-body{overflow:hidden;max-height:0;transition:max-height .5s cubic-bezier(.4,0,.2,1);background:var(--paper);border:1px solid var(--line);border-top:none;border-radius:0 0 4px 4px}
.chapter-inner{padding:40px clamp(24px,5vw,60px) 48px;max-width:780px}
.chapter-inner .ch-h2{font-family:var(--serif);font-size:clamp(26px,3.4vw,34px);font-weight:400;color:var(--ink);line-height:1.2;margin:0 0 24px}
.chapter-inner .ch-h3{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin:34px 0 12px}
.chapter-inner p{font-size:17px;line-height:1.7;color:var(--ink-soft);margin:0 0 18px}
.chapter-inner strong{color:var(--ink);font-weight:600}
.ch-list{list-style:none;margin:0 0 18px;padding:0}
.ch-list li{position:relative;padding:0 0 14px 22px;font-size:17px;line-height:1.65;color:var(--ink-soft)}
.ch-list li::before{content:"";position:absolute;left:0;top:11px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
.ch-note{background:rgba(37,99,201,.06);border-left:3px solid var(--teal);border-radius:0 4px 4px 0;padding:20px 24px;margin:0 0 22px;font-size:16px;line-height:1.65;color:var(--ink-soft)}
.ch-note strong{color:var(--teal-deep)}
.ch-note em{font-style:italic}
.ch-code{background:var(--ink);color:#cdd6e6;border-radius:4px;padding:22px 24px;margin:0 0 22px;overflow-x:auto;font-family:'Courier New',monospace;font-size:14px;line-height:1.6}
.ch-code code{font-family:inherit;white-space:pre}
.ch-cta{margin-top:30px;padding-top:24px;border-top:1px solid var(--line);font-size:16px;color:var(--grey)}
.ch-cta em{font-style:italic;color:var(--ink)}

/* ---------- PRICING ACCORDION ---------- */
.pricing{background:var(--paper)}
.pricing-intro{font-size:19px;font-weight:300;color:var(--ink-soft);max-width:680px;margin-top:14px}

/* outer toggle wrapping the whole price list */
.price-wrap{margin-top:46px}
.price-toggle{width:100%;background:var(--ink);color:#fff;border:none;cursor:pointer;text-align:left;padding:26px 30px;display:grid;grid-template-columns:1fr 30px;grid-template-areas:"label icon" "sub icon";column-gap:20px;row-gap:4px;align-items:center;border-radius:4px;transition:background .25s}
.price-toggle:hover{background:#1a2740}
.pt-label{grid-area:label;font-family:var(--sans);font-size:16px;font-weight:600;letter-spacing:.04em}
.pt-sub{grid-area:sub;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--grey-light)}
.pt-icon{grid-area:icon;position:relative;width:18px;height:18px;justify-self:end}
.pt-icon::before,.pt-icon::after{content:"";position:absolute;background:var(--teal);transition:transform .3s,opacity .3s}
.pt-icon::before{top:8px;left:0;width:18px;height:2px}
.pt-icon::after{top:0;left:8px;width:2px;height:18px}
.price-toggle[aria-expanded="true"]{border-radius:4px 4px 0 0}
.price-toggle[aria-expanded="true"] .pt-icon::after{transform:rotate(90deg);opacity:0}
.price-body{overflow:hidden;max-height:0;transition:max-height .5s cubic-bezier(.4,0,.2,1);background:var(--paper);border:1px solid var(--line);border-top:none;border-radius:0 0 4px 4px}
.price-inner{padding:8px clamp(16px,3vw,30px) 20px}

.accordion{border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-head{width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:28px 8px;display:grid;grid-template-columns:1fr auto 38px;grid-template-areas:"title price icon" "kind price icon";column-gap:24px;align-items:center;font-family:var(--serif);transition:background .25s}
.acc-head:hover{background:rgba(37,99,201,.04)}
.acc-kind{grid-area:kind;font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-top:4px}
.acc-title{grid-area:title;font-size:22px;font-weight:500;color:var(--ink);line-height:1.2}
.acc-price{grid-area:price;font-family:var(--sans);font-size:17px;font-weight:500;color:var(--ink);white-space:nowrap;text-align:right}
.acc-icon{grid-area:icon;position:relative;width:18px;height:18px;justify-self:end}
.acc-icon::before,.acc-icon::after{content:"";position:absolute;background:var(--teal);transition:transform .3s,opacity .3s}
.acc-icon::before{top:8px;left:0;width:18px;height:2px}
.acc-icon::after{top:0;left:8px;width:2px;height:18px}
.acc-head[aria-expanded="true"] .acc-icon::after{transform:rotate(90deg);opacity:0}
.acc-head[aria-expanded="true"]{background:rgba(37,99,201,.04)}
.acc-body{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.acc-inner{padding:0 56px 30px 8px}
.acc-inner p{font-size:17px;line-height:1.65;color:var(--ink-soft);margin:0}
.acc-inner strong{color:var(--ink);font-weight:600}
@media(max-width:600px){
  .acc-head{grid-template-columns:1fr 30px;grid-template-areas:"kind icon" "title icon" "price icon";row-gap:6px;padding:22px 4px}
  .acc-price{text-align:left;font-size:16px;margin-top:4px}
  .acc-inner{padding:0 30px 26px 4px}
}

/* ---------- CONTACT ---------- */
.contact{background:var(--ink);color:#fff}
.contact h2{color:#fff}
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:64px;margin-top:30px}
.contact-info p{color:var(--grey-light)}
.contact-info .lead{font-size:22px;font-weight:300;color:#fff;line-height:1.5;margin-bottom:34px}
.contact-info .row{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}
.contact-info .row .k{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal)}
.contact-info .row .v{font-size:19px;color:#fff}
.contact-info .row a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.25);transition:.2s;width:fit-content}
.contact-info .row a:hover{border-color:var(--teal)}
.form{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:40px}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey-light);margin-bottom:10px}
.field input,.field textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);border-radius:2px;padding:14px 16px;font-family:var(--serif);font-size:17px;color:#fff;transition:border .25s,background .25s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal);background:rgba(255,255,255,.08)}
.field textarea{resize:vertical;min-height:120px}
.form .btn-primary{width:100%;border:none;font-size:14px}
.form .note{font-family:var(--sans);font-size:12px;color:var(--grey);margin-top:16px;text-align:center;letter-spacing:.04em}

/* ---------- FOOTER ---------- */
footer{background:#0e0f11;color:var(--grey-light);padding:60px 0 36px}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:30px}
.foot .logo{color:#fff;font-size:28px}
.foot .links{display:flex;gap:28px;flex-wrap:wrap}
.foot .links a{font-family:var(--sans);font-size:13px;letter-spacing:.08em;color:var(--grey-light);text-decoration:none;transition:.2s}
.foot .links a:hover{color:var(--teal)}
.foot .copy{font-family:var(--sans);font-size:13px;color:var(--grey);width:100%;border-top:1px solid rgba(255,255,255,.08);padding-top:28px;margin-top:10px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .nav ul{position:fixed;inset:0;background:rgba(14,15,17,.98);flex-direction:column;justify-content:center;gap:34px;transform:translateX(100%);transition:transform .4s}
  .nav ul.open{transform:translateX(0)}
  .burger{display:flex;z-index:120}
  .burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .about-grid{grid-template-columns:1fr;gap:80px}
  .portrait{max-width:380px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:48px 30px}
  .svc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .q-grid{grid-template-columns:1fr}
  .read-grid{grid-template-columns:1fr;gap:40px}
  .contact-grid{grid-template-columns:1fr;gap:44px}
  .hero-photo::after{background:linear-gradient(90deg,#0d1626 0%,#0d1626 14%,rgba(13,22,38,.55) 42%,rgba(13,22,38,.1) 65%,transparent 80%)}
  .hero-content{max-width:90%}
  .about-cols{column-count:1}
  .problem-cols{grid-template-columns:1fr;gap:0}
}
@media(max-width:560px){
  .wrap,.narrow{padding:0 22px}
  body{font-size:17px}
  section{padding:78px 0}
  .hero-inner{padding:110px 26px 90px}
  .hero-photo{width:100%}
  .hero-photo img{object-position:72% center}
  .hero-photo::after{background:linear-gradient(180deg,rgba(13,22,38,.25) 0%,rgba(13,22,38,.55) 45%,rgba(13,22,38,.85) 100%)}
  .hero-content{max-width:100%}
  .scroll-cue{left:calc(50% - 23px)}
  .portrait .badge{right:0}
}

/* ---------- CONTACT FORM (honeypot + status) ---------- */
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form .note{transition:color .3s}
.form .note.success{color:#7bd6a8}
.form .note.error{color:#ff9a8a}
.form.sending button{opacity:.6;pointer-events:none}
