/* =========================================================================
   AgelessTek Solutions — Core Stylesheet (V1 · Minimalist)
   Brand reference: company quotation document
   ========================================================================= */

:root {
  /* Brand palette */
  --red:        #b21f2a;
  --red-bright: #d4313b;
  --red-deep:   #4a0f14;
  --ink:        #211a1b;
  --ink-soft:   #463b3d;
  --muted:      #7a6c6e;
  --faint:      #a99c9e;
  --paper:      #ffffff;
  --shell:      #f3eeee;
  --wash:       #faf6f6;
  --wash-red:   #fcf1f1;
  --line:       #ece5e6;
  --line-strong:#d9d0d1;
  --night:      #160d0f;

  /* Typography */
  --sans:    "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --display: "Space Grotesk", system-ui, sans-serif;
  --mono:    "IBM Plex Mono", ui-monospace, "SF Mono", monospace;

  /* Rhythm */
  --container: 1180px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --ease: cubic-bezier(.22, .61, .36, 1);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

h1, h2, h3, h4 { font-family: var(--display); margin: 0; font-weight: 600; letter-spacing: -.02em; line-height: 1.08; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
::selection { background: var(--red); color: #fff; }

.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }

/* ---------- shared bits ---------- */
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--red);
  font-weight: 600;
  display: inline-flex; align-items: center; gap: 10px;
  margin: 0 0 18px;
}
.eyebrow::before { content: ""; width: 26px; height: 1.5px; background: var(--red); display: inline-block; }
.eyebrow.center { justify-content: center; }
.eyebrow.light { color: rgba(255,255,255,.78); }
.eyebrow.light::before { background: rgba(255,255,255,.6); }

.section { padding: clamp(70px, 11vw, 140px) 0; position: relative; }
.section-lead { font-size: clamp(15px, 1.7vw, 18px); color: var(--muted); line-height: 1.7; max-width: 56ch; }

h2.head { font-size: clamp(28px, 4.4vw, 50px); }
h2.head .dim { color: var(--faint); }

/* ---------- buttons ---------- */
.btn {
  --bg: var(--ink); --fg: #fff;
  display: inline-flex; align-items: center; gap: 11px;
  font-family: var(--mono); font-size: 12.5px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 15px 26px; border-radius: var(--radius);
  background: var(--bg); color: var(--fg);
  border: 1.5px solid var(--bg);
  cursor: pointer; position: relative; overflow: hidden;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s, border-color .3s;
  will-change: transform;
}
.btn .arr { transition: transform .4s var(--ease); }
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -16px rgba(40,15,18,.6); }
.btn:hover .arr { transform: translateX(4px); }
.btn-red    { --bg: var(--red); --fg: #fff; }
.btn-red:hover { background: var(--red-bright); border-color: var(--red-bright); }
.btn-ghost  { --bg: transparent; --fg: var(--ink); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--ink); background: transparent; }
.btn-light  { --bg: #fff; --fg: var(--ink); }
.btn-outline-light { --bg: transparent; --fg: #fff; border-color: rgba(255,255,255,.4); }
.btn-outline-light:hover { border-color: #fff; }
.btn-block { width: 100%; justify-content: center; }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px var(--gutter);
  transition: background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled {
  background: rgba(255,255,255,.86);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  padding: 12px var(--gutter);
  box-shadow: 0 1px 0 var(--line);
}
.brand { position: relative; display: inline-flex; align-items: center; color: #fff; transition: color .4s; }
/* white + red logo are STACKED (red absolutely over white) and cross-faded,
   so they can never sit side-by-side regardless of cache/CSS state. */
.brand .logo { height: 30px; width: auto; display: block; transition: opacity .4s var(--ease); }
.brand .logo-red { position: absolute; left: 0; top: 0; opacity: 0; }
.site-header.scrolled .logo-white { opacity: 0; }
.site-header.scrolled .logo-red { opacity: 1; }

.nav { display: flex; align-items: center; gap: 6px; }
.nav a.link {
  font-family: var(--mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase;
  color: rgba(255,255,255,.82); padding: 9px 13px; border-radius: 3px; position: relative;
  transition: color .3s;
}
.site-header.scrolled .nav a.link { color: var(--muted); }
.nav a.link::after { content:""; position:absolute; left:13px; right:13px; bottom:5px; height:1.5px; background: var(--red); transform: scaleX(0); transform-origin: left; transition: transform .35s var(--ease); }
.nav a.link:hover { color: #fff; }
.site-header.scrolled .nav a.link:hover { color: var(--ink); }
.nav a.link:hover::after { transform: scaleX(1); }
.nav .btn { margin-left: 10px; padding: 10px 16px; font-size: 11px; letter-spacing: .1em; white-space: nowrap; }

.nav-toggle { display: none; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero {
  position: relative; min-height: 100svh; display: flex; align-items: center;
  background: radial-gradient(135% 130% at 80% 12%, var(--red-bright) 0%, var(--red) 40%, var(--red-deep) 100%);
  color: #fff; overflow: hidden; isolation: isolate;
}
.hero::after { /* subtle top/bottom shading */
  content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,0) 26%, rgba(0,0,0,0) 60%, rgba(8,4,5,.55));
}
.hero-birds { position: absolute; inset: 0; z-index: 1; pointer-events: none; }

/* real Nairobi skyline — anchored as a bottom band, parallaxed horizontally */
.hero-skyline {
  position: absolute; left: 50%; bottom: -2px; z-index: 0;
  height: clamp(260px, 50vh, 560px); width: auto; max-width: none;
  transform: translateX(-50%);
  opacity: .5; pointer-events: none; will-change: transform;
}
.hero-skyline.back { height: clamp(300px, 56vh, 620px); opacity: .2; filter: blur(1.2px); bottom: 8px; }
@media (max-width: 700px) { .hero-skyline { height: 40vh; } .hero-skyline.back { height: 44vh; } }

.hero-inner { position: relative; z-index: 3; padding-top: 90px; padding-bottom: 140px; width: 100%; }
.hero-kicker {
  font-family: var(--mono); font-size: 12px; letter-spacing: .24em; text-transform: uppercase;
  color: rgba(255,255,255,.82); display: inline-flex; align-items: center; gap: 10px;
}
.hero-kicker::before { content:""; width: 30px; height: 1.5px; background: rgba(255,255,255,.6); }
.hero h1 {
  font-size: clamp(40px, 8.4vw, 96px); line-height: .98; letter-spacing: -.035em;
  margin: 22px 0 0; max-width: 16ch; color: #fff; font-weight: 600;
}
.hero h1 em { font-style: normal; color: rgba(255,255,255,.55); }
.hero h1 .accent { position: relative; white-space: nowrap; }
.hero h1 .accent::after { content:""; position:absolute; left:0; right:0; bottom:.07em; height:.07em; background: #fff; opacity:.85; transform: scaleX(0); transform-origin:left; transition: transform 1s var(--ease) .9s; }
.hero.in h1 .accent::after { transform: scaleX(1); }
.hero-sub { margin: 28px 0 0; font-size: clamp(15px, 2vw, 19px); line-height: 1.65; color: rgba(255,255,255,.86); max-width: 52ch; }
.hero-cta { margin-top: 38px; display: flex; flex-wrap: wrap; gap: 14px; }

.hero-meta {
  position: absolute; left: var(--gutter); right: var(--gutter); bottom: 30px; z-index: 3;
  display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.62); border-top: 1px solid rgba(255,255,255,.14); padding-top: 16px;
}
.hero-meta b { color: #fff; font-weight: 500; }
.scrollcue { display: inline-flex; align-items: center; gap: 9px; }
.scrollcue .dot { width: 6px; height: 6px; border-radius: 50%; background: #fff; animation: cuePulse 1.8s var(--ease) infinite; }
@keyframes cuePulse { 0%,100%{ opacity:.3; transform: translateY(0);} 50%{ opacity:1; transform: translateY(4px);} }

/* =========================================================================
   REVEAL ANIMATIONS
   ========================================================================= */
[data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal][data-d="1"] { transition-delay: .08s; }
[data-reveal][data-d="2"] { transition-delay: .16s; }
[data-reveal][data-d="3"] { transition-delay: .24s; }
[data-reveal][data-d="4"] { transition-delay: .32s; }
[data-reveal][data-d="5"] { transition-delay: .40s; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; }
}

/* =========================================================================
   MARQUEE STRIP
   ========================================================================= */
.strip { background: var(--ink); color: #fff; overflow: hidden; padding: 17px 0; border-bottom: 1px solid #2c2122; }
.marquee { display: flex; gap: 56px; width: max-content; animation: slide 32s linear infinite; }
.marquee:hover { animation-play-state: paused; }
.marquee span { font-family: var(--mono); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.62); display: inline-flex; align-items: center; gap: 56px; }
.marquee span::after { content:"✦"; color: var(--red-bright); }
@keyframes slide { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee { animation: none; } }

/* =========================================================================
   ABOUT / AGELESS
   ========================================================================= */
.about { background: var(--paper); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(34px, 6vw, 96px); align-items: center; }
.about .word {
  font-family: var(--display); font-weight: 700; letter-spacing: -.04em; line-height: .9;
  font-size: clamp(64px, 13vw, 168px); color: var(--ink);
}
.about .word b { color: var(--red); }
.about .word small { display:block; font-family: var(--mono); font-size: 12px; letter-spacing: .3em; color: var(--faint); font-weight: 500; text-transform: uppercase; margin-top: 18px; }
.about-copy p + p { margin-top: 18px; }
.about-copy p.big { font-family: var(--display); font-size: clamp(20px, 2.6vw, 28px); line-height: 1.35; color: var(--ink); letter-spacing: -.015em; font-weight: 500; }
.about-copy p { color: var(--ink-soft); }
.about-copy .pill { display:inline-flex; gap:9px; align-items:center; margin-top: 26px; font-family: var(--mono); font-size: 11.5px; letter-spacing:.1em; text-transform:uppercase; color: var(--muted); }
.about-copy .pill b { color: var(--red); }

.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; margin-top: clamp(48px,7vw,86px); }
.stats .stat { background: var(--paper); padding: 26px 22px; }
.stat .n { font-family: var(--display); font-size: clamp(30px,4vw,46px); font-weight: 700; color: var(--ink); line-height: 1; }
.stat .n b { color: var(--red); }
.stat .l { font-size: 12.5px; color: var(--muted); margin-top: 9px; line-height:1.4; }

/* =========================================================================
   SERVICES
   ========================================================================= */
.services { background: var(--wash); border-top: 1px solid var(--line); }
.svc-head { display:flex; align-items: flex-end; justify-content: space-between; gap: 30px; flex-wrap: wrap; margin-bottom: clamp(34px, 5vw, 60px); }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.svc {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px 28px 30px; position: relative; overflow: hidden;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
}
.svc::before { content:""; position:absolute; left:0; top:0; height:3px; width:0; background: var(--red); transition: width .5s var(--ease); }
.svc:hover { transform: translateY(-6px); box-shadow: 0 26px 50px -30px rgba(40,15,18,.4); border-color: var(--line-strong); }
.svc:hover::before { width:100%; }
.svc .ico { width: 46px; height: 46px; border-radius: 11px; background: var(--wash-red); color: var(--red); display:grid; place-items:center; margin-bottom: 22px; transition: background .4s, color .4s; }
.svc:hover .ico { background: var(--red); color:#fff; }
.svc .ico svg { width: 23px; height: 23px; }
.svc .no { position:absolute; top: 26px; right: 28px; font-family: var(--mono); font-size: 11px; color: var(--faint); letter-spacing:.1em; }
.svc h3 { font-size: 19px; margin-bottom: 10px; }
.svc p { font-size: 13.5px; color: var(--muted); line-height: 1.6; }
.svc ul { list-style:none; margin: 16px 0 0; padding: 14px 0 0; border-top: 1px solid var(--line); }
.svc ul li { font-size: 12.5px; color: var(--ink-soft); padding-left: 18px; position: relative; margin-bottom: 7px; }
.svc ul li::before { content:""; position:absolute; left:0; top:7px; width:5px; height:5px; border-radius:50%; background: var(--red); opacity:.55; }

/* =========================================================================
   DOCUMENTS / PROCESS
   ========================================================================= */
/* =========================================================================
   RECENT WORK / CLIENTS
   ========================================================================= */
.clients { background: var(--paper); border-top: 1px solid var(--line); }
.clients-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.client { display: block; color: var(--ink); }
.client .frame { border: 1px solid var(--line-strong); border-radius: 10px; overflow: hidden; background: var(--paper); box-shadow: 0 1px 2px rgba(40,15,18,.05); transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s; }
.client:hover .frame { transform: translateY(-6px); box-shadow: 0 28px 54px -30px rgba(40,15,18,.42); border-color: var(--red); }
.client .bar { display: flex; align-items: center; gap: 7px; padding: 11px 14px; background: var(--wash); border-bottom: 1px solid var(--line); }
.client .bar i { width: 9px; height: 9px; border-radius: 50%; background: var(--line-strong); flex: none; }
.client .bar i:first-child { background: #e6b8bb; }
.client .bar em { margin-left: 10px; font-family: var(--mono); font-size: 11.5px; color: var(--muted); font-style: normal; letter-spacing: .02em; }
.client .shot { aspect-ratio: 76 / 52; background: var(--wash) repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(0,0,0,.015) 10px, rgba(0,0,0,.015) 20px); overflow: hidden; position: relative; }
.client .shot::after { content: "Loading preview…"; position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--mono); font-size: 11px; color: var(--faint); letter-spacing: .08em; z-index: 0; }
.client .shot img { position: relative; z-index: 1; width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; transition: transform 1.2s var(--ease); }
.client:hover .shot img { transform: scale(1.04); }
.client .meta { display: flex; justify-content: space-between; align-items: center; margin-top: 13px; }
.client .meta .dom { font-family: var(--display); font-size: 15px; font-weight: 600; color: var(--ink); }
.client .meta .visit { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--red); opacity: 0; transform: translateX(-5px); transition: opacity .4s var(--ease), transform .4s var(--ease); }
.client:hover .meta .visit { opacity: 1; transform: none; }
.clients-more { margin-top: clamp(26px,4vw,40px); font-size: 14.5px; color: var(--muted); }
.clients-more a { color: var(--red); font-weight: 500; white-space: nowrap; }
.clients-more a:hover { text-decoration: underline; text-underline-offset: 3px; }

.process { background: var(--paper); }
.steps-row { display:grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: clamp(30px,4vw,48px); }
.pstep { padding: 26px 24px; border:1px solid var(--line); border-radius: var(--radius); background: var(--wash); position: relative; }
.pstep .pn { font-family: var(--mono); font-size: 12px; color: var(--red); font-weight: 600; letter-spacing:.1em; }
.pstep h4 { font-size: 16px; margin: 12px 0 8px; }
.pstep p { font-size: 13px; color: var(--muted); line-height: 1.55; }

.docs-band {
  margin-top: clamp(40px,6vw,72px);
  background: radial-gradient(130% 200% at 92% 0%, var(--red-bright), var(--red) 46%, var(--red-deep) 120%);
  color: #fff; border-radius: 6px; padding: clamp(30px,5vw,52px); position: relative; overflow: hidden;
  display:grid; grid-template-columns: 1.3fr 1fr; gap: clamp(28px,5vw,56px); align-items:center;
}
.docs-band::after { content:""; position:absolute; right:-60px; bottom:-90px; width:320px; height:320px; border-radius:50%; border:1px solid rgba(255,255,255,.14); pointer-events:none; }
.docs-band > div { min-width: 0; }   /* let grid children shrink — prevents horizontal overflow on mobile */
.docs-band h3 { color:#fff; font-size: clamp(24px,3.4vw,34px); }
.docs-band p { color: rgba(255,255,255,.85); margin-top: 16px; font-size: 14.5px; line-height: 1.65; }
.docs-band .lockrow { display:flex; gap: 14px; margin-top: 26px; flex-wrap: wrap; }
.doc-card { background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); border-radius: var(--radius); padding: 18px 20px; backdrop-filter: blur(4px); }
.doc-card .dt { font-family: var(--mono); font-size: 10px; letter-spacing:.16em; text-transform:uppercase; color: rgba(255,255,255,.62); }
.doc-card .dpath { font-family: var(--mono); font-size: 13px; color:#fff; margin-top: 7px; }
.doc-card .dmeta { font-size: 12px; color: rgba(255,255,255,.7); margin-top: 6px; display:flex; gap:7px; align-items:center; }
.doc-card .dmeta svg { width: 13px; height: 13px; }

/* document finder (private portal) */
.doc-finder { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius); padding: 22px; backdrop-filter: blur(4px); max-width: 100%; }
.doc-finder label { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.72); margin-bottom: 12px; }
/* unified rounded pill: field + button share one container (modern on mobile) */
.df-row { display: flex; align-items: center; gap: 6px; background: rgba(0,0,0,.22); border: 1px solid rgba(255,255,255,.22); border-radius: 13px; padding: 6px; transition: border-color .3s, background .3s; }
.df-row:focus-within { border-color: #fff; background: rgba(0,0,0,.32); }
.df-row input { flex: 1; min-width: 0; font-family: var(--mono); font-size: 16px; color: #fff; background: transparent; border: none; padding: 12px 14px; }
.df-row input::placeholder { color: rgba(255,255,255,.42); }
.df-row input:focus { outline: none; }
.df-row button { flex: none; height: 46px; padding: 0 20px; border: none; border-radius: 9px; background: #fff; color: var(--red); font-family: var(--mono); font-weight: 600; font-size: 12.5px; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: background .3s, color .3s; }
.df-row button:hover { background: var(--ink); color: #fff; }
.df-row button .arr { transition: transform .3s var(--ease); }
.df-row button:hover .arr { transform: translateX(3px); }
@media (max-width: 420px) { .df-row button .lbl { display: none; } .df-row button { padding: 0 16px; } }
.df-hint { display: flex; gap: 8px; align-items: flex-start; margin-top: 13px; font-size: 11.5px; color: rgba(255,255,255,.72); line-height: 1.45; }
.df-hint svg { width: 14px; height: 14px; flex: none; margin-top: 1px; }
.df-inquire { margin-top: 16px; font-size: 12.5px; color: rgba(255,255,255,.82); line-height: 1.55; }
.df-inquire a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact { background: var(--night); color: #fff; }
.contact .eyebrow { color: var(--red-bright); }
.contact .eyebrow::before { background: var(--red-bright); }
.contact h2.head { color:#fff; }
.contact h2.head .dim { color: rgba(255,255,255,.4); }
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,5vw,60px); margin-top: clamp(36px,5vw,58px); align-items:start; }

.form-tabs { display:flex; gap:8px; margin-bottom: 22px; background: rgba(255,255,255,.05); padding:5px; border-radius: var(--radius); border:1px solid rgba(255,255,255,.1); }
.form-tabs button { flex:1; font-family: var(--mono); font-size: 11.5px; letter-spacing:.1em; text-transform:uppercase; padding: 11px; background: transparent; color: rgba(255,255,255,.6); border:none; border-radius: 3px; cursor:pointer; transition: background .3s, color .3s; }
.form-tabs button.active { background: var(--red); color:#fff; }

.field { margin-bottom: 16px; }
.field label { display:block; font-family: var(--mono); font-size: 10.5px; letter-spacing:.14em; text-transform:uppercase; color: var(--faint); margin-bottom: 8px; }
.field input, .field textarea, .field select {
  width:100%; font-family: var(--sans); font-size: 15px; color:#fff;
  background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.16); border-radius: var(--radius);
  padding: 13px 15px; transition: border-color .3s, background .3s;
}
.field textarea { min-height: 120px; resize: vertical; }
.field input::placeholder, .field textarea::placeholder { color: rgba(255,255,255,.34); }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--red-bright); background: rgba(255,255,255,.07); }
.field select option { color: var(--ink); }
.field-row { display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-note { font-size: 12px; color: var(--faint); margin-top: 14px; line-height:1.5; }
.form-msg { margin-top: 16px; padding: 13px 16px; border-radius: var(--radius); font-size: 13.5px; display:none; }
.form-msg.ok { display:block; background: rgba(60,160,90,.14); border:1px solid rgba(60,160,90,.4); color:#9ee6b4; }
.form-msg.err { display:block; background: rgba(210,60,70,.14); border:1px solid rgba(210,60,70,.45); color:#f3a6ac; }
form.sending .btn { opacity:.6; pointer-events:none; }
.hp-field { position:absolute; left:-9999px; opacity:0; height:0; width:0; overflow:hidden; }

.contact-aside .info-block { border-top:1px solid rgba(255,255,255,.12); padding: 22px 0; }
.contact-aside .info-block:first-child { border-top:none; padding-top: 0; }
.info-block .k { font-family: var(--mono); font-size: 10.5px; letter-spacing:.16em; text-transform:uppercase; color: var(--faint); margin-bottom: 9px; }
.info-block .v { font-size: 16px; color:#fff; line-height: 1.6; }
.info-block .v a { color:#fff; }
.info-block .v a:hover { color: var(--red-bright); }
.map-wrap { margin-top: 8px; border-radius: var(--radius); overflow:hidden; border:1px solid rgba(255,255,255,.14); aspect-ratio: 16/10; }
.map-wrap iframe { width:100%; height:100%; border:0; filter: grayscale(.3) contrast(1.05); }

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer { background: #100a0b; color: rgba(255,255,255,.6); padding: clamp(50px,7vw,80px) 0 30px; border-top: 1px solid #241819; }
.foot-top { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: clamp(28px,5vw,60px); padding-bottom: 44px; border-bottom: 1px solid rgba(255,255,255,.08); }
.foot-brand .brand { color:#fff; }
.foot-brand .brand .logo { height: 34px; }
.foot-brand p { margin-top: 18px; font-size: 13.5px; max-width: 40ch; line-height:1.65; }
.foot-col h5 { font-family: var(--mono); font-size: 10.5px; letter-spacing:.18em; text-transform:uppercase; color: var(--faint); margin: 0 0 16px; font-weight: 500; }
.foot-col a { display:block; font-size: 14px; color: rgba(255,255,255,.7); padding: 6px 0; transition: color .3s, padding-left .3s; }
.foot-col a:hover { color:#fff; padding-left: 5px; }
.foot-bot { display:flex; justify-content: space-between; gap: 16px; flex-wrap:wrap; padding-top: 26px; font-family: var(--mono); font-size: 11px; letter-spacing:.08em; color: var(--faint); }
.foot-bot a { color: var(--faint); }
.foot-bot a:hover { color:#fff; }
.foot-bot .dot { color: var(--red); }

/* =========================================================================
   GENERIC PAGE / GATE / ADMIN shells (used by serve.php, admin)
   ========================================================================= */
.center-shell { min-height: 100svh; display:grid; place-items:center; padding: 40px 20px;
  background: radial-gradient(130% 120% at 80% 8%, var(--red-bright), var(--red) 42%, var(--red-deep) 100%); }
.gate-card { width: 100%; max-width: 430px; background: var(--paper); border-radius: 8px; padding: 40px 36px;
  box-shadow: 0 40px 90px -40px rgba(20,8,10,.7); }
.gate-card .mark { width: 46px; height: 46px; color: var(--red); margin-bottom: 22px; }
.gate-card h1 { font-size: 24px; }
.gate-card .sub { color: var(--muted); font-size: 14px; margin: 10px 0 26px; line-height:1.55; }
.gate-card .doc-ref { font-family: var(--mono); font-size: 12px; color: var(--red); background: var(--wash-red); padding: 10px 14px; border-radius: 4px; margin-bottom: 22px; word-break: break-all; }
.gate-card .field label { color: var(--muted); }
.gate-card .field input { color: var(--ink); background: var(--wash); border-color: var(--line-strong); }
.gate-card .field input:focus { border-color: var(--red); background:#fff; }
.gate-card .err-line { color: var(--red); font-size: 13px; margin-bottom: 16px; font-weight: 500; }
.gate-foot { margin-top: 24px; text-align:center; font-family: var(--mono); font-size: 10px; letter-spacing:.16em; text-transform:uppercase; color: var(--faint); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 960px) {
  .brand .logo { height: 25px; }       /* smaller logo on phones */
  .nav .link { display:none; }
  .nav > .btn { display:none; }            /* mobile: just [logo] vs [menu] */
  .nav-toggle { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border:1px solid rgba(255,255,255,.3); border-radius:4px; background:transparent; cursor:pointer; }
  .site-header.scrolled .nav-toggle { border-color: var(--line-strong); }
  .nav-toggle span { width:18px; height:1.6px; background:#fff; position:relative; display:block; transition: .3s; }
  .site-header.scrolled .nav-toggle span { background: var(--ink); }
  .nav-toggle span::before, .nav-toggle span::after { content:""; position:absolute; left:0; width:18px; height:1.6px; background:inherit; transition:.3s; }
  .nav-toggle span::before { top:-6px; } .nav-toggle span::after { top:6px; }
  body.menu-open .nav-toggle span { background: transparent; }
  body.menu-open .nav-toggle span::before { top:0; transform: rotate(45deg); }
  body.menu-open .nav-toggle span::after  { top:0; transform: rotate(-45deg); }

  /* blurred backdrop + centred card */
  .mobile-menu { position: fixed; inset: 0; z-index: 55; display:flex; align-items:center; justify-content:center; padding: 24px 22px;
    background: rgba(16,9,11,.5); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%);
    opacity: 0; pointer-events: none; transition: opacity .4s var(--ease); }
  body.menu-open .mobile-menu { opacity: 1; pointer-events: auto; }
  .mm-card { width: 100%; max-width: 360px; background: rgba(28,18,20,.9); border: 1px solid rgba(255,255,255,.12); border-radius: 20px;
    padding: 22px 20px; box-shadow: 0 40px 90px -30px rgba(0,0,0,.75); display:flex; flex-direction:column;
    transform: translateY(14px) scale(.97); transition: transform .45s var(--ease); }
  body.menu-open .mm-card { transform: none; }
  .mm-card > a { font-family: var(--display); font-size: 19px; font-weight: 600; color:#fff; text-align:center; padding: 13px 6px; border-bottom: 1px solid rgba(255,255,255,.08); transition: color .25s; }
  .mm-card > a:hover, .mm-card > a:active { color: var(--red-bright); }
  .mm-card > a b { color: var(--red-bright); }
  .mm-card .m-cta { margin-top: 18px; display:flex; flex-direction:column; gap:10px; }
  .mm-card .m-cta .btn { width:100%; justify-content:center; font-size: 11.5px; }

  .about-grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2,1fr); }
  .svc-grid { grid-template-columns: 1fr 1fr; }
  .clients-grid { grid-template-columns: 1fr 1fr; }
  .steps-row { grid-template-columns: 1fr; }
  .docs-band { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .foot-top { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 961px) { .mobile-menu { display:none; } }
@media (max-width: 560px) {
  .svc-grid { grid-template-columns: 1fr; }
  .clients-grid { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .foot-top { grid-template-columns: 1fr; }
  .hero-meta { font-size: 9.5px; }
  .btn { padding: 14px 20px; }
  .brand .logo { height: 23px; }
  .docs-band { padding: 26px 20px; }
  .doc-finder { padding: 18px; }
}
