/* RedEye Security — Editorial Minimal.
   Warm paper, ink black, one strong red. Big confident type, whitespace,
   hairline rules, real photography. Strong & minimal — not templated. */
:root{
  --paper:#ffffff;--paper-2:#f5f2ed;--ink:#16140f;--ink-2:#33302a;--mut:#7c766c;
  --line:#e6e1d8;--red:#d22d1f;--red-ink:#a81e12;
  --maxw:1200px;--gut:clamp(20px,5vw,64px);
  --disp:'Space Grotesk',-apple-system,Segoe UI,sans-serif;
  --body:'Inter',-apple-system,Segoe UI,sans-serif;
  --mono:'Space Grotesk',ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink-2);background:var(--paper);font-size:17px;line-height:1.68;-webkit-font-smoothing:antialiased}
.aurora{display:none}
a{color:var(--ink);text-decoration:none;transition:color .15s}
a:hover{color:var(--red)}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--disp);color:var(--ink);line-height:1.05;letter-spacing:-.02em;font-weight:700}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* mono label / two-tone */
.label{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--mut)}
.label .n{color:var(--red);margin-right:10px}
.two b{color:var(--red)}.two span{color:var(--ink)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.2) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:26px;padding:15px 0}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand img{height:54px;width:auto;display:block}
.brand b{font-family:var(--body);font-size:20px;font-weight:800;color:var(--ink);letter-spacing:-.5px;line-height:1}
.brand b span{font-weight:600;color:#94a3b8}
.nav-links{display:flex;gap:2px;flex:1;justify-content:flex-end}
.nav-links a{font-family:var(--mono);color:var(--ink-2);font-size:12.5px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:9px 13px;border-radius:2px}
.nav-links a:hover{color:var(--red)}
.nav-links a.ext::after{content:" ↗";opacity:.5}
.nav-cta{font-family:var(--mono);font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)!important;border:1.5px solid var(--ink);padding:10px 20px;white-space:nowrap;transition:.16s}
.nav-cta:hover{background:var(--red);border-color:var(--red);color:#fff!important}
.menu-btn{display:none;background:none;border:1.5px solid var(--ink);color:var(--ink);padding:7px 11px;font-size:16px;cursor:pointer}

/* hero — editorial split */
.hero{border-bottom:1px solid var(--line)}
.hero .wrap{padding-top:clamp(48px,7vw,90px);padding-bottom:clamp(40px,6vw,72px)}
.hero.split .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.hero .eyebrow{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--mut);display:block;margin-bottom:26px}
.hero h1{font-size:clamp(40px,6.4vw,82px);font-weight:700;text-transform:uppercase;letter-spacing:-.035em;line-height:.97;color:var(--ink)}
.hero h1 .accent{color:var(--red)}
.hero p.lede{font-size:clamp(17px,1.5vw,20px);color:var(--ink-2);max-width:520px;margin-top:24px}
.hero .redline{width:64px;height:4px;background:var(--red);margin:30px 0 0}
.hero-media{position:relative}
.hero-media img{width:100%;aspect-ratio:4/3.4;object-fit:cover;filter:grayscale(1) contrast(1.05)}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(210,45,31,.08))}
.hero-media .frame{position:absolute;inset:14px -14px -14px 14px;border:1.5px solid var(--red);z-index:-1}

.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-weight:600;font-size:13.5px;letter-spacing:.06em;text-transform:uppercase;padding:14px 26px;transition:.16s}
.btn-primary{background:var(--red);color:#fff!important}
.btn-primary:hover{background:var(--red-ink)}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)!important}
.btn-ghost:hover{background:var(--ink);color:#fff!important}

/* sections */
section{padding:clamp(56px,8vw,104px) 0;position:relative}
.section-soft{background:var(--paper-2)}
.kicker{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:16px;display:block}
section h2{font-size:clamp(28px,4vw,46px);font-weight:700;text-transform:uppercase;letter-spacing:-.025em;line-height:1.02;margin-bottom:18px;color:var(--ink)}
.lead{font-size:clamp(17px,1.4vw,19px);color:var(--ink-2);max-width:680px}

/* editorial service rows */
.svc{margin-top:48px;border-top:1px solid var(--line)}
.svc .row{display:grid;grid-template-columns:90px 1fr;gap:clamp(16px,4vw,48px);padding:32px 0;border-bottom:1px solid var(--line);align-items:start}
.svc .row .no{font-family:var(--disp);font-size:clamp(30px,4vw,46px);font-weight:700;color:var(--line);letter-spacing:-.03em;line-height:1}
.svc .row:hover .no{color:var(--red)}
.svc .row h3{font-family:var(--disp);font-size:clamp(20px,2.4vw,27px);font-weight:700;text-transform:uppercase;letter-spacing:-.02em;color:var(--ink);margin-bottom:10px}
.svc .row p{color:var(--ink-2);max-width:680px;font-size:16px}

/* generic grid + cards (used by inner pages) */
.grid{display:grid;gap:1px;margin-top:48px;background:var(--line);border:1px solid var(--line)}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:var(--paper);padding:30px}
.section-soft .card{background:var(--paper-2)}
.card .num{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.1em;color:var(--red)}
.card h3{font-family:var(--disp);font-size:20px;font-weight:700;margin:10px 0 10px;color:var(--ink);text-transform:uppercase;letter-spacing:-.01em}
.card p{color:var(--ink-2);font-size:15.5px}
ul.checks{list-style:none;margin-top:20px;display:grid;gap:13px}
ul.checks li{position:relative;padding-left:30px;color:var(--ink-2)}
ul.checks li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:2px;background:var(--red)}

/* full-bleed feature band with photo */
.band{position:relative;color:#fff;border-top:1px solid var(--line)}
.band img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.42)}
.band .wrap{position:relative;z-index:1;padding:clamp(64px,9vw,120px) var(--gut)}
.band .kicker{color:#ff7a6e}
.band h2{color:#fff;max-width:780px}
.band .lead{color:#e6e3dd}

/* prose */
.prose{max-width:760px}
.prose h2{margin-top:10px}
.prose h3{font-family:var(--disp);font-size:22px;font-weight:700;margin:34px 0 10px;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink)}
.prose p{margin:14px 0;color:var(--ink-2)}
.prose ul{margin:14px 0 14px 22px;color:var(--ink-2)}
.prose li{margin:7px 0}
.prose hr{border:none;border-top:1px solid var(--line);margin:36px 0}
.prose blockquote,blockquote{border-left:3px solid var(--red);padding:6px 0 6px 24px;margin:28px 0;color:var(--ink);font-family:var(--disp);font-size:20px;font-style:normal;line-height:1.4}
blockquote footer,blockquote cite{display:block;margin-top:12px;font-family:var(--mono);font-style:normal;color:var(--mut);font-size:12px;letter-spacing:.06em;text-transform:uppercase}

/* leadership */
.lead-hero{display:grid;grid-template-columns:280px 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.headshot{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top;filter:grayscale(1) contrast(1.04);border:1px solid var(--line)}

/* phases / callout */
.callout{border:1px solid var(--ink);background:var(--ink);color:#fff;padding:38px;margin:44px 0}
.callout h3{color:#fff;font-family:var(--disp);font-size:24px;text-transform:uppercase;letter-spacing:-.02em}
.callout p{color:#d9d6cf;margin-top:12px}
.phase{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;padding:24px 0;border-bottom:1px solid var(--line)}
.phase .tag{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--red);white-space:nowrap;padding-top:3px}
.phase em{font-style:normal;color:var(--mut);font-family:var(--mono);font-size:12px;letter-spacing:.04em}

/* form */
.form{border:1px solid var(--line);background:var(--paper);padding:34px;max-width:660px}
.form label{display:block;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:18px 0 7px}
.form input,.form textarea,.form select{width:100%;font-family:inherit;font-size:15.5px;padding:13px 15px;border:1px solid var(--line);background:#fcfbf9;color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--red)}
.form textarea{min-height:140px;resize:vertical}
.form button{margin-top:24px;width:100%;font-family:var(--mono);background:var(--red);color:#fff;font-weight:600;font-size:14px;letter-spacing:.08em;text-transform:uppercase;padding:16px;border:none;cursor:pointer;transition:.15s}
.form button:hover{background:var(--red-ink)}
.form .note{font-size:13px;color:var(--mut);margin-top:16px}
.form-status{margin-top:16px;font-weight:600;display:none}

/* footer — ink */
footer.site{background:var(--ink);color:#a8a298;padding:72px 0 36px;font-size:14.5px;border-top:4px solid var(--red)}
footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:42px}
footer h4{font-family:var(--mono);color:#fff;font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
footer a{color:#cfcabf;display:block;padding:5px 0}
footer a:hover{color:#fff}
footer .eco a::after{content:" ↗";opacity:.5}
footer .about .brand{display:flex;align-items:center;gap:11px;margin-bottom:14px}
footer .about .brand img{height:50px}
footer .about .brand b{font-family:var(--body);color:#fff;font-size:20px;font-weight:800;letter-spacing:-.5px}
footer .about .brand b span{color:#94a3b8;font-weight:600}
footer .about p{color:#8f897e;max-width:360px;margin-top:6px}
footer .legal{margin-top:50px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--mono);color:#6f6a60;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase}

@media(max-width:860px){
  .brand img{height:44px}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:12px var(--gut);border-bottom:1px solid var(--line);gap:0}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 4px;border-bottom:1px solid var(--line)}
  .menu-btn{display:block;margin-left:auto}
  .nav-cta{display:none}
  .hero.split .wrap{grid-template-columns:1fr;gap:30px}
  .hero-media{order:-1}.hero-media .frame{display:none}
  .lead-hero{grid-template-columns:1fr;text-align:left}.headshot{max-width:240px}
  footer .cols{grid-template-columns:1fr;gap:30px}
  .svc .row{grid-template-columns:54px 1fr;gap:16px}
}
