/* Stridel — shared site styles (company brand). */
:root{
  --ink:#00131B; --green:#348856; --green-deep:#1F5E3B; --bright:#54C998;
  --bone:#FAFAF7; --white:#fff; --mist:#ECEAE3; --line:#D9D9D2; --slate:#5B655F;
  --maxw:1120px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bone);color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.kick{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--green)}
.mono{font-family:"IBM Plex Mono",monospace}

/* nav */
header.nav{position:sticky;top:0;z-index:30;background:rgba(250,250,247,.82);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:18px;height:66px}
.nav img.logo{height:48px;display:block}
.nav nav{margin-left:auto;display:flex;gap:26px;align-items:center;font-size:15px;font-weight:500}
.nav nav a{text-decoration:none;opacity:.74;transition:opacity .15s}
.nav nav a:hover,.nav nav a.active{opacity:1}
.nav .cta{background:var(--ink);color:#fff;padding:9px 16px;border-radius:9px;font-weight:600;opacity:1}
.nav .cta:hover{background:var(--green-deep)}
@media(max-width:720px){.nav nav .hideable{display:none}}
/* nav dropdown */
.navdrop{position:relative;display:flex;align-items:center}
.navdrop-t{display:inline-flex;align-items:center;gap:5px;text-decoration:none}
.navdrop .caret{font-size:10px;opacity:.55;transition:transform .15s}
.navdrop:hover .caret,.navdrop:focus-within .caret{transform:rotate(180deg)}
.navdrop-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);
  min-width:244px;background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 16px 44px rgba(0,19,27,.12);padding:8px;opacity:0;visibility:hidden;
  transition:opacity .15s,transform .15s;z-index:40}
.navdrop-menu::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:10px}
.navdrop:hover .navdrop-menu,.navdrop:focus-within .navdrop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(8px)}
.navdrop-menu a{display:block;text-decoration:none;padding:9px 12px;border-radius:9px;opacity:1;font-weight:500}
.navdrop-menu a:hover{background:var(--mist)}
.navdrop-menu a b{display:block;font-weight:700;font-size:15px;color:var(--ink)}
.navdrop-menu a span{display:block;font-size:12px;color:var(--slate);margin-top:1px}
.navdrop-menu a.sub{font-size:13.5px;color:var(--slate);padding:7px 12px 7px 22px}
.navdrop-menu a.sub::before{content:"\21B3";margin-right:7px;opacity:.5}
.navdrop-menu a.all{border-top:1px solid var(--line);margin-top:6px;color:var(--green-deep);font-weight:600;font-size:14px}

/* buttons */
.btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.btn{display:inline-block;padding:14px 24px;border-radius:11px;font-weight:600;font-size:16px;text-decoration:none;transition:.15s}
.btn.p{background:var(--green);color:#fff}.btn.p:hover{background:var(--green-deep)}
.btn.s{border:1.5px solid var(--ink);color:var(--ink)}.btn.s:hover{background:var(--ink);color:#fff}
.lnk{font-weight:600;text-decoration:none;color:var(--green-deep);border-bottom:2px solid var(--bright);padding-bottom:2px}
.lnk:hover{color:var(--ink)}

/* page hero (sub pages) */
.phead{border-bottom:1px solid var(--line);background:var(--bone)}
.phead .wrap{padding:64px 28px 56px}
.phead .crumb{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.06em;color:var(--slate);margin-bottom:18px}
.phead .crumb a{text-decoration:none;color:var(--green-deep)}
.phead h1{font-size:clamp(36px,5.5vw,60px);font-weight:800;letter-spacing:-.025em;line-height:1.05;margin:8px 0 0;max-width:18ch}
.phead p.lead{font-size:clamp(17px,2.2vw,21px);color:#27352e;max-width:60ch;margin:20px 0 0}

/* sections */
section{padding:80px 0}
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eyebrow::after{content:"";height:1px;flex:1;background:var(--line)}
h2.sec{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0;max-width:18ch}
.sec-lead{font-size:18px;color:#27352e;max-width:62ch;margin:18px 0 0}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.cards.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.cards,.cards.two{grid-template-columns:1fr}}
.card{background:var(--white);border:1px solid var(--line);border-radius:16px;padding:30px 28px}
.card .num{font-family:"IBM Plex Mono",monospace;font-size:12px;color:var(--green);letter-spacing:.1em}
.card h3{font-size:21px;font-weight:700;margin:14px 0 8px;letter-spacing:-.01em}
.card p{font-size:15.5px;color:#3a463f;margin:0}

/* work cards (linked) */
.work-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:18px;
  padding:32px 30px;text-decoration:none;color:inherit;transition:.16s;min-height:230px}
.work-card:hover{border-color:var(--green);transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,19,27,.06)}
.work-card .tag{font-family:"IBM Plex Mono",monospace;font-size:12px;color:var(--green);letter-spacing:.08em}
.work-card h2{font-size:25px;font-weight:800;letter-spacing:-.01em;margin:14px 0 8px}
.work-card p{color:#3a463f;margin:0 0 18px;font-size:15.5px}
.work-card .go{margin-top:auto;font-weight:600;color:var(--green-deep)}
.status{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;font-family:"IBM Plex Mono",monospace;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--slate);border:1px solid var(--line);border-radius:999px;padding:5px 11px}
.status .d{width:7px;height:7px;border-radius:50%;background:var(--green)}
.status.live .d{animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}

/* dark band */
.band{background:var(--ink);color:#eafff4}
.band .kick{color:var(--bright)}
.band h2.sec{color:#fff}.band .sec-lead{color:#b9c9c0}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
@media(max-width:820px){.steps{grid-template-columns:1fr 1fr}}
.step{border:1px solid #21343b;border-radius:14px;padding:22px}
.step .s{font-family:"IBM Plex Mono",monospace;color:var(--bright);font-size:13px}
.step h3{margin:12px 0 6px;font-size:17px;color:#fff;font-weight:700}
.step p{margin:0;font-size:14px;color:#9fb3a8}

/* timeline */
.tl{list-style:none;margin:36px 0 0;padding:0 0 0 26px;position:relative}
.tl::before{content:"";position:absolute;left:7px;top:6px;bottom:10px;width:2px;background:var(--line)}
.tl li{position:relative;padding:0 0 26px 24px}
.tl li::before{content:"";position:absolute;left:-24px;top:5px;width:14px;height:14px;border-radius:50%;background:var(--bone);border:2.5px solid var(--ink)}
.tl li.done::before{background:var(--green);border-color:var(--green)}
.tl li.now::before{background:var(--bright);border-color:var(--green);box-shadow:0 0 0 4px rgba(84,201,152,.25)}
.tl li .dt{font-family:"IBM Plex Mono",monospace;font-size:12px;color:var(--green);letter-spacing:.06em}
.tl li h3{margin:4px 0 4px;font-size:18px;font-weight:700}
.tl li p{margin:0;color:#3a463f;font-size:15px;max-width:60ch}

/* stat row */
.stats{display:flex;gap:46px;flex-wrap:wrap;margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.stat .n{font-family:"IBM Plex Mono",monospace;font-size:clamp(24px,3vw,32px);font-weight:500}
.stat .l{font-size:13px;color:var(--slate);margin-top:3px;max-width:22ch}

/* cta band */
.cta-band{background:var(--green-deep);color:#fff;border-radius:24px;padding:56px 44px;text-align:center}
.cta-band h2{font-size:clamp(26px,4vw,40px);font-weight:800;letter-spacing:-.02em;margin:0 0 12px;color:#fff}
.cta-band p{color:#cdeede;max-width:48ch;margin:0 auto 26px}
.email{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);
  border-radius:11px;padding:12px 18px;font-family:"IBM Plex Mono",monospace;color:#fff;cursor:pointer;font-size:15px;text-decoration:none}
.email:hover{background:rgba(255,255,255,.18)}

/* footer */
footer.site{padding:48px 0 60px;border-top:1px solid var(--line);margin-top:88px}
footer.site .wrap{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
footer.site img{height:24px}
footer.site .fnav{margin-left:auto;display:flex;gap:22px;font-size:14px}
footer.site a{text-decoration:none;opacity:.7}footer.site a:hover{opacity:1}
footer.site .meta{width:100%;font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--slate);letter-spacing:.04em;margin-top:8px}

.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,8px);background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:999px;font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.1em;
  opacity:0;transition:.25s;pointer-events:none;z-index:50}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* keyboard focus — shared brand ring (only shows for keyboard users, not mouse clicks) */
:focus-visible{outline:2px solid var(--green-deep);outline-offset:2px}
/* lighter ring on dark/green surfaces for contrast */
.band a:focus-visible,.email:focus-visible,.cta-band :focus-visible{outline-color:var(--bright)}
