/* ==========================================================================
   ATRIAD IP — Design System
   A certificate/ledger-inspired identity: paper, engraved brass, wax seal.
   ========================================================================== */

/* ---- Tokens ------------------------------------------------------------ */
:root{
  --paper:        #FAF9F4;
  --paper-dim:    #F1EFE6;
  --paper-line:   rgba(28, 23, 16, 0.12);
  --paper-line-soft: rgba(28, 23, 16, 0.07);

  --ink:          #1C1710;
  --ink-soft:     #55493A;
  --ink-faint:    #948A78;

  --navy:         #F2E4C0;
  --navy-2:       #ECD9A6;
  --navy-3:       #E3C87F;
  --on-navy:      #241C0C;
  --on-navy-soft: rgba(36, 28, 12, 0.68);
  --navy-line:    rgba(36, 28, 12, 0.16);

  --brass:        #B8860B;
  --brass-light:  #8B6308;
  --brass-dim:    #6E5008;
  --oxblood:      #7C2B2E;
  --oxblood-light:#9C4245;

  --font-display: 'Fraunces', 'Iowan Old Style', Georgia, serif;
  --font-body:    'IBM Plex Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;

  --container: 1180px;
  --radius: 2px;
  --ease: cubic-bezier(.22,.68,.18,1);
}

/* ---- Reset --------------------------------------------------------------*/
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,p,figure{ margin:0; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

:focus-visible{ outline:2px solid var(--brass); outline-offset:3px; }

/* ---- Type scale ----------------------------------------------------------*/
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; letter-spacing:-0.01em; color:var(--ink); }
.on-navy h1,.on-navy h2,.on-navy h3,.on-navy h4{ color:var(--on-navy); }

.h-display{ font-size:clamp(2.8rem, 6vw, 5.4rem); line-height:0.98; font-weight:560; letter-spacing:-0.02em; }
.h-1{ font-size:clamp(2.2rem, 4.4vw, 3.4rem); line-height:1.06; }
.h-2{ font-size:clamp(1.7rem, 3vw, 2.3rem); line-height:1.14; }
.h-3{ font-size:1.35rem; line-height:1.3; }
.lede{ font-size:clamp(1.05rem, 1.6vw, 1.25rem); line-height:1.6; color:var(--ink-soft); font-weight:400; }
.on-navy .lede{ color:var(--on-navy-soft); }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--brass-dim);
  display:inline-flex;
  align-items:center;
  gap:.55em;
}
.on-navy .eyebrow{ color:var(--brass-light); }
.eyebrow::before{
  content:"";
  width:22px; height:1px;
  background:currentColor;
  display:inline-block;
}

/* ---- Layout ---------------------------------------------------------- */
.container{ max-width:var(--container); margin:0 auto; padding:0 28px; }
.section{ padding:104px 0; position:relative; }
.section-tight{ padding:72px 0; }
@media (max-width:780px){
  .section{ padding:72px 0; }
  .section-tight{ padding:52px 0; }
}
.on-navy{ background:var(--navy); color:var(--on-navy); }
.on-paper-dim{ background:var(--paper-dim); }

.rule{ height:1px; background:var(--paper-line); border:0; margin:0; }
.on-navy .rule{ background:var(--navy-line); }

.grain{
  position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:multiply;
}

/* Guilloche-style engraved background used behind hero + section corners */
.ledger-bg{
  position:absolute; inset:0; pointer-events:none; opacity:.55;
}

/* ---- Buttons ----------------------------------------------------------*/
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono);
  font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  padding:15px 26px;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  position:relative; overflow:hidden;
  transition:color .35s var(--ease), border-color .35s var(--ease);
}
.btn::before{
  content:"";
  position:absolute; inset:0;
  background:var(--ink);
  transform:translateY(101%);
  transition:transform .35s var(--ease);
  z-index:-1;
}
.btn:hover{ color:var(--paper); }
.btn:hover::before{ transform:translateY(0); }
.btn-primary{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn-primary::before{ background:var(--brass-dim); }
.btn-primary:hover{ color:var(--paper); }

.on-navy .btn{ border-color:var(--brass-light); color:var(--on-navy); }
.on-navy .btn::before{ background:var(--brass); }
.on-navy .btn:hover{ color:var(--navy); }

.btn-arrow{ transition:transform .35s var(--ease); }
.btn:hover .btn-arrow{ transform:translateX(4px); }

.text-link{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:.78rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink); border-bottom:1px solid var(--brass); padding-bottom:3px;
  transition:gap .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.text-link:hover{ gap:13px; color:var(--brass-dim); }
.on-navy .text-link{ color:var(--on-navy); border-color:var(--brass-light); }
.on-navy .text-link:hover{ color:var(--brass-light); }

/* ---- Site header ---------------------------------------------------- */
.topbar{
  background:var(--navy); color:var(--on-navy-soft);
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.04em;
}
.topbar .container{ display:flex; justify-content:space-between; align-items:center; padding-top:9px; padding-bottom:9px; flex-wrap:wrap; gap:8px; }
.topbar a{ color:var(--on-navy-soft); transition:color .2s; }
.topbar a:hover{ color:var(--brass-light); }
.topbar-phones{ display:flex; gap:20px; }
.topbar-tag{ letter-spacing:.14em; text-transform:uppercase; color:var(--brass-light); }

.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(250,249,244,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--paper-line);
  transition:background .3s;
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; padding-top:16px; padding-bottom:16px; }

.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{ width:44px; height:44px; flex-shrink:0; }
.brand-mark img{ width:100%; height:100%; object-fit:contain; display:block; }
.brand-word{ font-family:var(--font-display); font-weight:600; font-size:1.28rem; letter-spacing:.01em; line-height:1; }
.brand-word small{ display:block; font-family:var(--font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); font-weight:400; margin-top:4px; }

.main-nav{ display:flex; align-items:center; gap:34px; }
.main-nav > ul{ display:flex; align-items:center; gap:30px; }
.main-nav > ul > li{ position:relative; }
.nav-link{
  font-family:var(--font-mono); font-size:.76rem; letter-spacing:.05em; text-transform:uppercase;
  padding:8px 0; position:relative;
}
.nav-link::after{
  content:""; position:absolute; left:0; right:0; bottom:2px; height:1px; background:var(--brass);
  transform:scaleX(0); transform-origin:right; transition:transform .3s var(--ease);
}
.nav-link:hover::after, .nav-link.is-active::after{ transform:scaleX(1); transform-origin:left; }
.nav-link.is-active{ color:var(--brass-dim); }

.has-dropdown{ display:flex; align-items:center; gap:5px; }
.dropdown{
  position:absolute; top:calc(100% + 18px); left:50%; transform:translateX(-50%) translateY(6px);
  width:560px; background:var(--paper); border:1px solid var(--paper-line);
  box-shadow:0 24px 48px rgba(14,20,36,.12);
  padding:22px; display:grid; grid-template-columns:1fr 1fr; gap:4px 22px;
  opacity:0; visibility:hidden; transition:opacity .25s var(--ease), transform .25s var(--ease);
}
li.has-dropdown:hover .dropdown, li.has-dropdown:focus-within .dropdown{
  opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
}
.dropdown a{
  display:flex; align-items:baseline; gap:10px; padding:10px 8px;
  font-family:var(--font-body); font-size:.87rem; color:var(--ink-soft);
  border-bottom:1px solid var(--paper-line-soft);
  transition:color .2s, padding-left .2s;
}
.dropdown a span.ref{ font-family:var(--font-mono); font-size:.64rem; color:var(--brass-dim); flex-shrink:0; }
.dropdown a:hover{ color:var(--ink); padding-left:14px; }

.header-cta{ display:flex; align-items:center; gap:22px; }
.header-phone{ font-family:var(--font-mono); font-size:.78rem; letter-spacing:.02em; display:flex; align-items:center; gap:8px; }
.header-phone .dot{ width:6px; height:6px; border-radius:50%; background:var(--oxblood); flex-shrink:0; animation:pulse-dot 2.4s infinite; }
@keyframes pulse-dot{ 0%,100%{ opacity:1; } 50%{ opacity:.35; } }

.menu-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px;
}
.menu-toggle span{ width:22px; height:1px; background:var(--ink); display:block; transition:transform .3s, opacity .3s; }

@media (max-width:1080px){
  .main-nav{ display:none; }
  .header-phone{ display:none; }
  .menu-toggle{ display:flex; }
}

/* Mobile drawer */
.mobile-nav{
  position:fixed; inset:0; z-index:200; background:var(--navy);
  display:flex; flex-direction:column;
  transform:translateY(-100%); transition:transform .45s var(--ease);
  overflow-y:auto;
}
.mobile-nav.is-open{ transform:translateY(0); }
.mobile-nav .container{ padding-top:20px; }
.mobile-nav-head{ display:flex; justify-content:space-between; align-items:center; padding:8px 0 30px; }
.mobile-nav-close{ background:none; border:1px solid var(--navy-line); color:var(--on-navy); width:40px; height:40px; font-size:1.2rem; }
.mobile-nav a{ color:var(--on-navy); }
.mobile-nav-list > li{ border-top:1px solid var(--navy-line); }
.mobile-nav-list > li:last-child{ border-bottom:1px solid var(--navy-line); }
.mobile-nav-list > li > a, .mobile-nav-list .mnav-toggle{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-display); font-size:1.5rem; padding:18px 0;
}
.mnav-toggle{ background:none; border:0; width:100%; text-align:left; color:var(--on-navy); }
.mobile-sub{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.mobile-sub.is-open{ max-height:600px; }
.mobile-sub li a{ display:flex; gap:10px; padding:10px 0 10px 6px; font-family:var(--font-body); font-size:.95rem; color:var(--on-navy-soft); }
.mobile-sub li a span{ font-family:var(--font-mono); font-size:.68rem; color:var(--brass-light); }
.mobile-nav-foot{ margin-top:auto; padding:26px 0 40px; border-top:1px solid var(--navy-line); font-family:var(--font-mono); font-size:.85rem; color:var(--on-navy-soft); display:flex; flex-direction:column; gap:10px; }
.mobile-nav-foot a{ color:var(--brass-light); }

/* ---- Seal / signature mark -------------------------------------------- */
.seal{ position:relative; }
.seal svg{ width:100%; height:100%; display:block; }
.seal-ring{ animation: seal-spin 46s linear infinite; transform-origin:50% 50%; }
@keyframes seal-spin{ to{ transform:rotate(360deg); } }
.seal-stamp{
  transform-origin:50% 50%;
  animation: seal-in .9s var(--ease) both;
}
@keyframes seal-in{
  0%{ transform:scale(.6) rotate(-8deg); opacity:0; }
  55%{ transform:scale(1.06) rotate(1deg); opacity:1; }
  100%{ transform:scale(1) rotate(0); opacity:1; }
}

/* ---- Hero (home) ------------------------------------------------------ */
.hero{
  position:relative; overflow:hidden;
  background:var(--paper);
  padding:64px 0 88px;
  border-bottom:1px solid var(--paper-line);
}
.hero .container{ position:relative; z-index:2; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:60px; align-items:center; }
.hero-copy .eyebrow{ margin-bottom:24px; }
.hero-copy h1{ margin-bottom:26px; }
.hero-copy .lede{ max-width:46ch; margin-bottom:38px; }
.hero-actions{ display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.hero-seal-wrap{ display:flex; justify-content:center; align-items:center; }
.hero-seal-wrap .seal{ width:min(340px, 80vw); aspect-ratio:1; }

/* Framed real photography — hero + about figure */
.photo-frame{ position:relative; overflow:hidden; border:1px solid var(--paper-line); background:var(--paper-dim); }
.photo-frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-frame .corner{ position:absolute; width:26px; height:26px; border:1px solid var(--brass); opacity:.8; z-index:2; }
.photo-frame .corner.tl{ top:14px; left:14px; border-right:0; border-bottom:0; }
.photo-frame .corner.br{ bottom:14px; right:14px; border-left:0; border-top:0; }

.hero-photo-wrap{ display:flex; flex-direction:column; gap:14px; }
.hero-photo-frame{ aspect-ratio:3/4; width:100%; max-width:380px; margin:0 auto; box-shadow:0 30px 60px rgba(28,23,16,.14); }
.hero-photo-caption{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); max-width:380px; margin:0 auto; width:100%; }

@media (max-width:900px){
  .hero-photo-frame{ max-width:280px; }
  .hero-photo-caption{ max-width:280px; }
}

.hero-tags{ display:flex; gap:10px; flex-wrap:wrap; margin-top:44px; }
.hero-tag{
  font-family:var(--font-mono); font-size:.7rem; letter-spacing:.04em; text-transform:uppercase;
  border:1px solid var(--paper-line); padding:8px 14px; color:var(--ink-soft);
}

@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-seal-wrap{ order:-1; margin-bottom:12px; }
  .hero-seal-wrap .seal{ width:200px; }
}

/* ---- Generic inner-page hero -------------------------------------------*/
.page-hero{
  position:relative; background:var(--navy); color:var(--on-navy); overflow:hidden;
  padding:150px 0 90px;
}
.page-hero .eyebrow{ color:var(--brass-light); margin-bottom:22px; }
.page-hero h1{ max-width:16ch; }
.page-hero .lede{ margin-top:22px; max-width:56ch; }
.page-hero-meta{ display:flex; gap:28px; margin-top:46px; flex-wrap:wrap; }
.page-hero-meta div{ font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--on-navy-soft); border-left:1px solid var(--navy-line); padding-left:14px; }
.page-hero-meta strong{ display:block; font-family:var(--font-display); font-size:1.2rem; color:var(--on-navy); letter-spacing:0; text-transform:none; margin-top:4px; font-weight:500; }
.page-hero-watermark{ position:absolute; right:-60px; top:50%; transform:translateY(-50%); width:420px; max-width:46vw; opacity:.14; pointer-events:none; z-index:0; }
.page-hero .container{ position:relative; z-index:1; }
.page-hero-ref{
  position:absolute; top:40px; right:28px; font-family:var(--font-mono); font-size:.72rem; color:var(--brass-light);
  letter-spacing:.1em; text-align:right; opacity:.7;
}
.breadcrumb{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.05em; text-transform:uppercase; color:var(--on-navy-soft); display:flex; gap:8px; margin-bottom:26px; }
.breadcrumb a:hover{ color:var(--brass-light); }

/* ---- Stats strip -------------------------------------------------------*/
.stats{ background:var(--navy); color:var(--on-navy); }
.stats-grid{ display:grid; grid-template-columns:repeat(6,1fr); }
.stat{ padding:44px 22px; border-left:1px solid var(--navy-line); text-align:left; }
.stat:first-child{ border-left:0; }
.stat-num{ font-family:var(--font-display); font-size:2.6rem; color:var(--on-navy); line-height:1; display:flex; align-items:baseline; gap:2px; }
.stat-num .plus{ font-size:1.4rem; color:var(--brass-light); }
.stat-label{ margin-top:10px; font-family:var(--font-mono); font-size:.68rem; letter-spacing:.05em; text-transform:uppercase; color:var(--on-navy-soft); }
.stat-sub{ margin-top:6px; font-size:.82rem; color:var(--on-navy-soft); max-width:20ch; }
@media (max-width:980px){ .stats-grid{ grid-template-columns:repeat(3,1fr); } .stat:nth-child(3n+1){ border-left:0; } }
@media (max-width:600px){ .stats-grid{ grid-template-columns:repeat(2,1fr); } .stat:nth-child(2n+1){ border-left:0; } }

/* ---- Section headers ----------------------------------------------------*/
.section-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:56px; }
.section-head .lede{ max-width:46ch; }
@media (max-width:780px){ .section-head{ flex-direction:column; align-items:flex-start; gap:18px; } }

/* ---- About section -------------------------------------------------- */
.about-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:70px; align-items:start; }
.about-figure{ position:relative; }
.about-figure-frame{
  aspect-ratio:4/5; border:1px solid var(--paper-line); position:relative; overflow:hidden;
  background:linear-gradient(160deg, var(--paper-dim), var(--paper));
}
.about-figure-frame .corner{ position:absolute; width:26px; height:26px; border:1px solid var(--brass); opacity:.7; }
.about-figure-frame .corner.tl{ top:14px; left:14px; border-right:0; border-bottom:0; }
.about-figure-frame .corner.br{ bottom:14px; right:14px; border-left:0; border-top:0; }
.about-figure-caption{ margin-top:16px; font-family:var(--font-mono); font-size:.72rem; color:var(--ink-faint); display:flex; justify-content:space-between; }
.about-copy p{ color:var(--ink-soft); margin-bottom:20px; }
.about-copy p:last-child{ margin-bottom:0; }
.about-founders{ display:flex; gap:26px; margin-top:34px; flex-wrap:wrap; }
.founder-chip{ display:flex; align-items:center; gap:12px; border:1px solid var(--paper-line); padding:10px 16px 10px 10px; }
.founder-avatar{ width:38px; height:38px; border-radius:50%; background:var(--navy); color:var(--on-navy); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:.95rem; overflow:hidden; flex-shrink:0; }
.founder-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
.founder-chip strong{ display:block; font-size:.85rem; }
.founder-chip span{ font-family:var(--font-mono); font-size:.66rem; color:var(--ink-faint); text-transform:uppercase; letter-spacing:.04em; }

/* ---- Services grid (home) ---------------------------------------------*/
.services-grid{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--paper-line); border-left:1px solid var(--paper-line); }
.service-card{
  border-right:1px solid var(--paper-line); border-bottom:1px solid var(--paper-line);
  padding:38px 30px; min-height:250px; display:flex; flex-direction:column; justify-content:space-between;
  position:relative; overflow:hidden; background:var(--paper);
  transition:background .4s var(--ease);
}
.service-card::before{
  content:""; position:absolute; inset:0; background:var(--navy);
  transform:translateY(100%); transition:transform .45s var(--ease); z-index:0;
}
.service-card:hover::before{ transform:translateY(0); }
.service-card > *{ position:relative; z-index:1; }
.service-card .ref{ font-family:var(--font-mono); font-size:.68rem; color:var(--brass-dim); letter-spacing:.08em; transition:color .4s; }
.service-card:hover .ref{ color:var(--brass-light); }
.service-card h3{ font-size:1.28rem; margin-top:60px; transition:color .4s; }
.service-card:hover h3{ color:var(--on-navy); }
.service-card p{ margin-top:12px; font-size:.9rem; color:var(--ink-soft); line-height:1.55; transition:color .4s; }
.service-card:hover p{ color:var(--on-navy-soft); }
.service-card .card-arrow{
  margin-top:22px; width:30px; height:30px; border:1px solid var(--paper-line); display:flex; align-items:center; justify-content:center;
  transition:border-color .4s, transform .4s var(--ease), background .4s;
}
.service-card:hover .card-arrow{ border-color:var(--brass); transform:translateX(6px); background:var(--brass); }
.service-card .card-arrow svg{ width:14px; height:14px; stroke:var(--ink); transition:stroke .4s; }
.service-card:hover .card-arrow svg{ stroke:var(--navy); }

@media (max-width:980px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .services-grid{ grid-template-columns:1fr; } }

/* ---- Numbered process / directions -------------------------------------*/
.process-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--paper-line); }
.process-item{ background:var(--paper); padding:36px 28px; }
.process-num{ font-family:var(--font-mono); color:var(--brass-dim); font-size:.85rem; }
.process-item h4{ margin-top:20px; font-size:1.1rem; }
.process-item p{ margin-top:10px; font-size:.88rem; color:var(--ink-soft); }
@media (max-width:900px){ .process-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .process-grid{ grid-template-columns:1fr; } }

/* ---- Vertical timeline (service pages: registration process) ----------*/
.timeline{ position:relative; margin-top:10px; }
.timeline::before{ content:""; position:absolute; left:19px; top:8px; bottom:8px; width:1px; background:var(--paper-line); }
.timeline-step{ position:relative; padding:0 0 44px 64px; }
.timeline-step:last-child{ padding-bottom:0; }
.timeline-num{
  position:absolute; left:0; top:0; width:40px; height:40px; border-radius:50%;
  border:1px solid var(--ink); background:var(--paper); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:.82rem;
}
.timeline-step h4{ font-size:1.18rem; }
.timeline-step p{ margin-top:8px; color:var(--ink-soft); max-width:64ch; }

/* ---- Feature / content cards (used in "what can be protected" etc) -----*/
.card-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); }
.card-grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.feature-card{ background:var(--paper); padding:32px; }
.feature-card h4{ font-size:1.08rem; display:flex; align-items:baseline; gap:10px; }
.feature-card h4 .mk{ color:var(--brass); font-family:var(--font-mono); font-size:.8rem; }
.feature-card ul{ margin-top:16px; display:flex; flex-direction:column; gap:9px; }
.feature-card ul li{ font-size:.9rem; color:var(--ink-soft); padding-left:16px; position:relative; }
.feature-card ul li::before{ content:"—"; position:absolute; left:0; color:var(--brass-dim); }
.feature-card p{ margin-top:14px; font-size:.9rem; color:var(--ink-soft); }
@media (max-width:900px){ .card-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .card-grid, .card-grid.cols-2{ grid-template-columns:1fr; } }

/* ---- Two-column list block (why it matters / benefits) ------------------*/
.check-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px 40px; }
.check-item{ display:flex; gap:14px; padding:16px 0; border-top:1px solid var(--paper-line); }
.on-navy .check-item{ border-color:var(--navy-line); }
.check-mark{ font-family:var(--font-mono); font-size:.72rem; color:var(--brass); flex-shrink:0; padding-top:3px; }
.check-item p{ font-size:.95rem; }
@media (max-width:700px){ .check-grid{ grid-template-columns:1fr; } }

/* ---- Compare table (patent vs trade secret style content) --------------*/
.compare{ display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--paper-line); }
.compare > div{ padding:34px; }
.compare > div:first-child{ border-right:1px solid var(--paper-line); }
.compare h4{ font-size:1.05rem; margin-bottom:16px; }
.compare .eyebrow{ margin-bottom:10px; }
@media (max-width:700px){ .compare{ grid-template-columns:1fr; } .compare > div:first-child{ border-right:0; border-bottom:1px solid var(--paper-line); } }

/* ---- Pull quote / vision block -----------------------------------------*/
.pull{ border-left:2px solid var(--brass); padding-left:32px; }
.pull p{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.3rem,2.4vw,1.7rem); line-height:1.45; color:var(--ink); }
.on-navy .pull p{ color:var(--on-navy); }

/* ---- Team ---------------------------------------------------------------*/
.team-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); }
.team-card{ background:var(--paper); padding:42px; display:flex; gap:26px; align-items:flex-start; }
.team-photo{ width:88px; height:88px; border-radius:50%; background:var(--navy); color:var(--on-navy); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:1.6rem; flex-shrink:0; overflow:hidden; border:1px solid var(--brass); }
.team-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.team-card h4{ font-size:1.2rem; }
.team-card .role{ font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; color:var(--brass-dim); margin-top:6px; display:block; }
.team-card .cred{ margin-top:12px; font-size:.87rem; color:var(--ink-soft); }
@media (max-width:700px){ .team-grid{ grid-template-columns:1fr; } .team-card{ flex-direction:column; } }

/* ---- Testimonials --------------------------------------------------------*/
.testi-track{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); }
.testi-card{ background:var(--paper); padding:30px; display:flex; flex-direction:column; gap:18px; }
.testi-mark{ font-family:var(--font-display); font-size:2.4rem; color:var(--brass); line-height:1; }
.testi-card p{ font-size:.9rem; color:var(--ink-soft); flex-grow:1; }
.testi-name{ display:flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.03em; padding-top:14px; border-top:1px solid var(--paper-line); }
@media (max-width:980px){ .testi-track{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .testi-track{ grid-template-columns:1fr; } }

/* ---- CTA band -------------------------------------------------------- */
.cta-band{ background:var(--navy); color:var(--on-navy); position:relative; overflow:hidden; }
.cta-band .container{ display:grid; grid-template-columns:1.3fr .7fr; gap:40px; align-items:center; }
.cta-band h2{ max-width:16ch; }
.cta-form{ display:flex; flex-direction:column; gap:14px; }
.cta-actions{ display:flex; gap:16px; flex-wrap:wrap; }
@media (max-width:900px){ .cta-band .container{ grid-template-columns:1fr; } }

/* Simple contact form styling shared by CTA + contact page */
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-faint); }
.on-navy .field label{ color:var(--on-navy-soft); }
.field input, .field textarea, .field select{
  background:transparent; border:0; border-bottom:1px solid var(--paper-line);
  padding:10px 2px; font-family:var(--font-body); font-size:.98rem; color:var(--ink);
  transition:border-color .25s;
}
.on-navy .field input, .on-navy .field textarea, .on-navy .field select{ border-color:var(--navy-line); color:var(--on-navy); }
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--brass); }
.field textarea{ resize:vertical; min-height:90px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:.78rem; color:var(--ink-faint); }
.on-navy .consent{ color:var(--on-navy-soft); }
.consent input{ margin-top:3px; }
.form-note{ font-family:var(--font-mono); font-size:.72rem; color:var(--ink-faint); }

/* ---- Footer --------------------------------------------------------------*/
.site-footer{ background:var(--navy); color:var(--on-navy); padding-top:88px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:50px; padding-bottom:60px; }
.footer-brand .brand-word{ color:var(--on-navy); }
.footer-brand p{ margin-top:20px; color:var(--on-navy-soft); font-size:.92rem; max-width:32ch; }
.footer-social{ margin-top:26px; display:flex; gap:12px; }
.footer-social a{ width:38px; height:38px; border:1px solid var(--navy-line); display:flex; align-items:center; justify-content:center; transition:border-color .3s, background .3s; }
.footer-social a:hover{ border-color:var(--brass); background:var(--brass); }
.footer-social svg{ width:16px; height:16px; }
.footer-col h5{ font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.08em; color:var(--brass-light); margin-bottom:20px; }
.footer-col ul{ display:flex; flex-direction:column; gap:12px; }
.footer-col a{ color:var(--on-navy-soft); font-size:.9rem; transition:color .2s, padding-left .2s; }
.footer-col a:hover{ color:var(--on-navy); padding-left:4px; }
.footer-col address{ font-style:normal; color:var(--on-navy-soft); font-size:.9rem; line-height:1.7; }
.footer-bottom{ border-top:1px solid var(--navy-line); padding:26px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; font-family:var(--font-mono); font-size:.72rem; color:var(--on-navy-soft); }
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

/* ---- Reveal-on-scroll ------------------------------------------------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal-stagger > *{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal-stagger.is-visible > *{ opacity:1; transform:translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1){ transition-delay:.02s; }
.reveal-stagger.is-visible > *:nth-child(2){ transition-delay:.08s; }
.reveal-stagger.is-visible > *:nth-child(3){ transition-delay:.14s; }
.reveal-stagger.is-visible > *:nth-child(4){ transition-delay:.20s; }
.reveal-stagger.is-visible > *:nth-child(5){ transition-delay:.26s; }
.reveal-stagger.is-visible > *:nth-child(6){ transition-delay:.32s; }
.reveal-stagger.is-visible > *:nth-child(7){ transition-delay:.38s; }
.reveal-stagger.is-visible > *:nth-child(8){ transition-delay:.44s; }

/* ---- Misc utility -------------------------------------------------------*/
.mt-0{ margin-top:0 !important; }
.center{ text-align:center; }
.tag-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }
.tag-pill{ font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.05em; border:1px solid var(--paper-line); padding:7px 13px; color:var(--ink-soft); }
.side-note{ background:var(--paper-dim); border-left:2px solid var(--oxblood); padding:22px 26px; font-size:.92rem; color:var(--ink-soft); }
.side-note strong{ color:var(--ink); }

.related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--paper-line); border:1px solid var(--paper-line); }
.related-card{ background:var(--paper); padding:28px; transition:background .3s; }
.related-card:hover{ background:var(--paper-dim); }
.related-card .ref{ font-family:var(--font-mono); font-size:.66rem; color:var(--brass-dim); }
.related-card h4{ margin-top:14px; font-size:1.05rem; }
.related-card p{ margin-top:8px; font-size:.85rem; color:var(--ink-soft); }
@media (max-width:800px){ .related-grid{ grid-template-columns:1fr; } }

/* back to top */
.to-top{
  position:fixed; right:26px; bottom:26px; z-index:90;
  width:44px; height:44px; border-radius:50%; background:var(--navy); border:1px solid var(--brass);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:opacity .3s, transform .3s, visibility .3s;
}
.to-top.is-visible{ opacity:1; visibility:visible; transform:translateY(0); }
.to-top svg{ width:16px; height:16px; stroke:var(--brass-light); }
