/* ============================================================
   A FRAME HOME SERVICES — Rebuild
   Design system: bold · reliable · veteran-owned · hands-on
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Barlow:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,600&family=Barlow+Semi+Condensed:wght@500;600;700&display=swap');

/* ---- Tokens ---- */
:root{
  --ink:#0E0F0C;          /* near-black, faint warm-green undertone */
  --ink-2:#16180F;        /* raised panel on dark */
  --ink-3:#22251A;        /* hairline / borders on dark */
  --paper:#F4F3EC;        /* warm off-white */
  --paper-2:#E8E7DD;      /* sunk paper */
  --paper-3:#D8D7CB;      /* paper border */
  --lime:#CAED00;         /* brand */
  --lime-2:#B6D400;       /* darker lime (hover) */
  --steel:#7C7F83;        /* logo gray */
  --steel-d:#3C3F42;
  --white:#FBFBF7;

  --txt-dark:#1A1C16;     /* text on paper */
  --txt-dim:#5C5F55;      /* muted text on paper */
  --txt-light:#F4F3EC;    /* text on ink */
  --txt-light-dim:#A7A99B;/* muted text on ink */

  --maxw:1280px;
  --gutter:clamp(20px,5vw,64px);
  --shadow:0 24px 60px -28px rgba(0,0,0,.55);

  --display:'Anton',system-ui,sans-serif;
  --body:'Barlow',system-ui,sans-serif;
  --cond:'Barlow Semi Condensed','Barlow',sans-serif;
}

/* ---- Reset ---- */
*{box-sizing:border-box;margin:0;padding:0}

/* ---- Accessibility ---- */
.skip-link{position:absolute;left:10px;top:-70px;z-index:400;background:var(--lime);color:#11130a;
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.9rem;
  padding:.75em 1.2em;transition:top .18s ease}
.skip-link:focus{top:0}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,
[tabindex]:focus-visible,.scrapcard:focus-visible,.port:focus-visible,.svc:focus-visible,.door:focus-visible{
  outline:3px solid var(--lime);outline-offset:3px;border-radius:2px}
:focus:not(:focus-visible){outline:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--txt-dark);
  line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,120px)}
.ink{background:var(--ink);color:var(--txt-light)}
.paper{background:var(--paper);color:var(--txt-dark)}

/* Eyebrow label with lime tick */
.eyebrow{
  font-family:var(--cond);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.82rem;
  display:inline-flex;align-items:center;gap:.7em;
  color:var(--txt-dim);
}
.ink .eyebrow{color:var(--txt-light-dim)}
.eyebrow::before{
  content:"";width:26px;height:3px;background:var(--lime);display:inline-block;
}

/* Display headings */
.display{
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  line-height:.94;
  letter-spacing:.005em;
}
.h-xl{font-size:clamp(2.7rem,7.5vw,6rem)}
.h-lg{font-size:clamp(2.1rem,5vw,4rem)}
.h-md{font-size:clamp(1.7rem,3.4vw,2.7rem)}
.lime{color:var(--lime)}
.measure{max-width:54ch}

/* ---- Buttons ---- */
.btn{
  --bg:var(--lime);--fg:#11130A;--bd:var(--lime);
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--cond);font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;font-size:1rem;
  padding:.95em 1.5em;background:var(--bg);color:var(--fg);
  border:2px solid var(--bd);cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease;
  line-height:1;
}
.btn:hover{background:var(--lime-2);transform:translateY(-2px)}
.btn .arr{font-size:1.1em;transition:transform .2s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--lime);border-color:var(--lime)}
.btn--ghost:hover{background:var(--lime);color:#11130A}
.btn--dark{background:var(--ink);color:var(--lime);border-color:var(--ink)}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--on-paper-ghost{background:transparent;color:var(--txt-dark);border-color:var(--txt-dark)}
.btn--on-paper-ghost:hover{background:var(--ink);color:var(--lime);border-color:var(--ink)}

/* ---- Top utility bar ---- */
.topbar{
  background:#0a0b08;color:var(--txt-light-dim);
  font-family:var(--cond);font-size:.86rem;letter-spacing:.04em;
  border-bottom:1px solid var(--ink-3);
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:42px;padding-block:6px}
.topbar a{color:var(--txt-light)}
.topbar .tb-left{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap}
.topbar .tb-right{display:flex;gap:1.4rem;align-items:center}
.topbar .pill{color:var(--lime);text-transform:uppercase;font-weight:700;letter-spacing:.12em;font-size:.78rem}
.topbar .sep{color:var(--ink-3)}

/* ---- Header / nav ---- */
.header{position:sticky;top:0;z-index:50;background:var(--ink);border-bottom:1px solid var(--ink-3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem;min-height:84px}
.nav__logo{margin-block:-10px}
.nav__logo img{height:90px;width:auto;display:block}
.nav__links{display:flex;align-items:center;gap:2.1rem}
.nav__links > li > a{
  font-family:var(--cond);font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;font-size:.95rem;color:var(--txt-light);
  padding-block:8px;position:relative;display:inline-flex;align-items:center;gap:.4em;
}
.nav__links > li > a::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--lime);
  transition:width .2s ease;
}
.nav__links > li > a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:1.1rem}
.nav__phone{font-family:var(--display);font-size:1.35rem;color:var(--lime);letter-spacing:.01em;white-space:nowrap}
.caret{font-size:.6em;opacity:.7}

/* dropdown */
.has-drop{position:relative}
.drop{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--ink-2);border:1px solid var(--ink-3);min-width:300px;
  padding:10px;opacity:0;visibility:hidden;transition:.18s ease;
  box-shadow:var(--shadow);
}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{
  display:flex;align-items:center;gap:.7em;padding:11px 14px;
  font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  font-size:.9rem;color:var(--txt-light);border-left:3px solid transparent;
}
.drop a:hover{background:var(--ink-3);border-left-color:var(--lime);color:var(--lime)}
.drop a .n{color:var(--steel);font-size:.78rem;min-width:1.6em}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:28px;height:3px;background:var(--lime);display:block}

/* ---- Hero ---- */
.hero{position:relative;background:#0b0c08;color:var(--txt-light);overflow:hidden}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:0;object-position:center;animation:skyFade 2.8s ease 3.4s forwards}
@keyframes skyFade{from{opacity:0}to{opacity:.46}}
@media(prefers-reduced-motion:reduce){.hero__bg img{animation:none;opacity:.46}}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(8,9,6,.5) 0%, rgba(8,9,6,.18) 34%, rgba(8,9,6,.28) 64%, rgba(8,9,6,.62) 100%),
    linear-gradient(90deg, rgba(8,9,6,.66) 0%, rgba(8,9,6,.38) 50%, rgba(8,9,6,.3) 100%);
}
/* faint blueprint grid */
.hero__grid{position:absolute;inset:0;z-index:1;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(202,237,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(202,237,0,.05) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(120% 90% at 75% 40%,#000 30%,transparent 80%)}
.hero__inner{position:relative;z-index:2;padding-block:clamp(64px,9vw,120px);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero__copy{max-width:none}
.hero__eyebrow{margin-bottom:1.6rem}
.hero h1{margin-bottom:1.5rem;max-width:16ch;text-shadow:0 3px 26px rgba(0,0,0,.5)}
.hero h1 em{font-style:normal;color:var(--lime)}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:46ch;color:#E4E5DA;margin-bottom:2.4rem;text-shadow:0 2px 18px rgba(0,0,0,.55)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero__trust{
  position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.14);
  display:flex;flex-wrap:wrap;gap:1.4rem 2.6rem;padding-block:22px;
}
.hero__trust .ht{
  display:flex;align-items:center;gap:.6em;font-family:var(--cond);
  text-transform:uppercase;letter-spacing:.08em;font-size:.9rem;color:#CFD0C4;font-weight:600;
}
.hero__trust .ht b{color:var(--lime);font-weight:700}
.hero__trust .dot{width:7px;height:7px;background:var(--lime);transform:rotate(45deg);flex:none}

/* ---- Who we are ---- */
.who{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.who__body p{color:var(--txt-dim);font-size:1.08rem;margin-bottom:1.2rem;max-width:52ch}
.who__body h2{margin:1rem 0 1.4rem}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.5rem;margin:1.8rem 0 2.2rem}
.checks li{display:flex;gap:.7em;align-items:flex-start;font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:1rem}
.checks .tick{color:var(--lime);font-weight:700;flex:none;font-size:1.1em;line-height:1.3}
.who__media{position:relative}
.who__slides{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--paper-2)}
.who__slides img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 1.1s ease, transform 5s ease;transform:scale(1.02)}
.who__slides img.active{opacity:1;transform:scale(1.09)}
.who__dots{position:absolute;z-index:3;right:14px;bottom:14px;display:flex;gap:7px}
.who__dots button{width:9px;height:9px;border:0;padding:0;cursor:pointer;background:rgba(255,255,255,.45);transition:.2s}
.who__dots button.on{background:var(--lime);width:22px}
.bracket{position:absolute;inset:0;pointer-events:none}
.bracket::before,.bracket::after{content:"";position:absolute;width:64px;height:64px;border:4px solid var(--lime)}
.bracket::before{top:-14px;left:-14px;border-right:0;border-bottom:0}
.bracket::after{bottom:-14px;right:-14px;border-left:0;border-top:0}
.stat-badge{
  position:absolute;left:-18px;bottom:38px;background:var(--lime);color:#11130A;
  padding:18px 22px;box-shadow:var(--shadow);
}
.stat-badge .big{font-family:var(--display);font-size:2.6rem;line-height:.9}
.stat-badge .lbl{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem}

/* ---- Why strip ---- */
.why{border-top:1px solid var(--paper-3);margin-top:clamp(48px,7vw,90px);padding-top:clamp(40px,5vw,64px)}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.4rem}
.why__item .n{font-family:var(--display);color:var(--lime);font-size:1.5rem;-webkit-text-stroke:1px var(--steel-d)}
.why__item h3{font-family:var(--cond);text-transform:uppercase;letter-spacing:.04em;font-size:1.25rem;margin:.5rem 0 .5rem}
.why__item p{color:var(--txt-dim);font-size:.98rem}

/* ---- Services ---- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:clamp(34px,4vw,56px);flex-wrap:wrap}
.sec-head .display{margin-top:.7rem}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{
  position:relative;display:block;overflow:hidden;background:var(--ink-2);
  min-height:300px;border:1px solid var(--ink-3);
}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;transition:transform .5s ease,opacity .3s ease}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,6,.1) 30%,rgba(8,9,6,.92) 100%)}
.svc:hover img{transform:scale(1.06);opacity:.5}
.svc__in{position:relative;z-index:2;height:100%;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;padding:22px}
.svc__n{position:absolute;top:18px;left:22px;font-family:var(--display);font-size:1.2rem;color:var(--lime);z-index:3}
.svc h3{font-family:var(--cond);text-transform:uppercase;letter-spacing:.03em;font-size:1.5rem;line-height:1.02;color:#fff}
.svc p{color:var(--txt-light-dim);font-size:.95rem;margin-top:.4rem;max-width:34ch;
  max-height:0;opacity:0;overflow:hidden;transition:.35s ease}
.svc__more{display:inline-flex;align-items:center;gap:.5em;margin-top:1rem;color:var(--lime);
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}
.svc__more .arr{transition:transform .2s ease}
.svc:hover p{max-height:80px;opacity:1;margin-top:.6rem}
.svc:hover .svc__more .arr{transform:translateX(5px)}
.svc--wide{grid-column:span 1}

/* ---- Portfolio ---- */
.port-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:220px;gap:14px}
.port{position:relative;overflow:hidden;display:block;background:var(--paper-2)}
.port img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.port:hover img{transform:scale(1.05)}
.port::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,6,0) 40%,rgba(8,9,6,.85) 100%);opacity:.85;transition:opacity .3s}
.port__cap{position:absolute;z-index:2;left:0;bottom:0;padding:22px}
.port__cap .loc{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;color:var(--lime);font-weight:700}
.port__cap h3{font-family:var(--cond);text-transform:uppercase;font-size:1.5rem;color:#fff;line-height:1;margin-top:.25rem}
.port--a{grid-column:span 4;grid-row:span 2}
.port--b{grid-column:span 2;grid-row:span 1}
.port--c{grid-column:span 2;grid-row:span 1}
.port--d{grid-column:span 3;grid-row:span 1}
.port--e{grid-column:span 3;grid-row:span 1}

/* ---- Testimonials ---- */
.quotes{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px}
.q{border:1px solid var(--ink-3);background:var(--ink-2);padding:30px;display:flex;flex-direction:column}
.q .mark{font-family:var(--display);color:var(--lime);font-size:3rem;line-height:.6;height:.6em}
.q p{color:#E4E5DA;font-size:1.02rem;margin:1rem 0 1.4rem}
.q--lead{grid-row:span 1}
.q--lead p{font-size:1.3rem;line-height:1.4}
.q__by{margin-top:auto;font-family:var(--cond);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:.9rem}
.q__by span{color:var(--steel)}
.stars{color:var(--lime);letter-spacing:.15em;font-size:.95rem;margin-bottom:.2rem}

/* ---- CTA band ---- */
.ctaband{background:var(--lime);color:#11130A}
.ctaband .wrap{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-block:clamp(26px,4vw,42px)}
.ctaband .display{font-size:clamp(1.8rem,3.6vw,3rem)}
.ctaband p{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-size:.95rem;margin-bottom:.5rem}

/* ---- Trust badges ---- */
.badges{background:var(--paper-2);border-block:1px solid var(--paper-3)}
.badges .wrap{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-block:34px}
.badges__lbl{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-weight:700;color:var(--txt-dim);font-size:.82rem;max-width:12ch}
.badges__row{display:flex;align-items:center;gap:clamp(24px,4vw,56px);flex-wrap:wrap}
.badges__row img{height:74px;width:auto;filter:saturate(1)}

/* ---- Footer ---- */
.footer{background:#0a0b08;color:var(--txt-light-dim);padding-top:clamp(56px,7vw,84px)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2.5rem;padding-bottom:48px;border-bottom:1px solid var(--ink-3)}
.footer__logo{height:58px;margin-bottom:1.2rem}
.footer__brand p{font-size:.98rem;max-width:34ch;color:var(--txt-light-dim)}
.footer h4{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;color:#fff;font-size:.95rem;margin-bottom:1.1rem}
.footer a:hover{color:var(--lime)}
.footer__links li{margin-bottom:.6rem;font-family:var(--cond);text-transform:uppercase;letter-spacing:.04em;font-size:.95rem}
.footer__contact li{margin-bottom:.9rem;display:flex;gap:.7em;align-items:flex-start;font-size:.98rem}
.footer__contact .ic{color:var(--lime);flex:none;font-weight:700}
.footer__contact a{color:#fff}
.hours{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;padding:.3rem 0;border-bottom:1px dashed var(--ink-3)}
.hours b{color:#fff;font-weight:600}
.socials{display:flex;gap:.6rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border:1px solid var(--ink-3);display:flex;align-items:center;justify-content:center;
  font-family:var(--cond);font-weight:700;font-size:.8rem;color:#fff;transition:.2s}
.socials a:hover{background:var(--lime);color:#11130A;border-color:var(--lime)}

/* contact socials — vertical accordion reveal on hover */
.socials--contact{margin-top:1.6rem}
.socials--contact a{flex-direction:column;height:auto;min-height:42px;padding:0;overflow:hidden;gap:0}
.socials--contact a .ab{display:flex;align-items:center;justify-content:center;height:42px;width:100%;flex:none}
.socials--contact a .full{max-height:0;opacity:0;overflow:hidden;font-size:.52rem;letter-spacing:.04em;text-transform:uppercase;
  transition:max-height .28s ease,opacity .2s ease,padding .28s ease;width:100%;text-align:center;padding:0 2px;white-space:nowrap}
.socials--contact a:hover{align-self:flex-start}
.socials--contact a:hover .full{max-height:40px;opacity:1;padding:0 6px 7px}
.footer__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-block:24px;font-size:.85rem;font-family:var(--cond);letter-spacing:.04em}
.footer__bottom .vet{color:var(--lime);text-transform:uppercase;font-weight:700;letter-spacing:.1em}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- Responsive ---- */
@media(max-width:1080px){
  .why__grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .quotes{grid-template-columns:1fr 1fr}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav__links,.nav__phone{display:none}
  .burger{display:flex}
  .who{grid-template-columns:1fr}
  .who__media{order:-1;max-width:480px}
  .port-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .port--a,.port--b,.port--c,.port--d,.port--e{grid-column:span 2;grid-row:span 1}
  .port--a{grid-row:span 2}
  .topbar .tb-left .hide-sm{display:none}
}
@media(max-width:620px){
  body{font-size:16px}
  .checks{grid-template-columns:1fr}
  .why__grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .port-grid{grid-template-columns:1fr}
  .port--a,.port--a{grid-row:span 1}
  .badges .wrap{justify-content:center;text-align:center}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
}

/* ============================================================
   HERO BUILD ANIMATION (A-frame house assembling in profile)
   ============================================================ */
.build-wrap{position:relative;width:100%;max-width:560px;margin-inline:auto;aspect-ratio:560/440}
.build-svg{width:100%;height:100%;overflow:visible}
.build-svg .beam{fill:#8a8d80}
.build-svg .beam-d{fill:#5f6257}
.build-svg .ln{fill:none;stroke:#9b9e90;stroke-width:13;stroke-linecap:square}
.build-svg .lime-ln{fill:none;stroke:var(--lime);stroke-width:6;stroke-linecap:square}
.build-svg .lime-fl{fill:var(--lime)}
.build-svg .open{fill:none;stroke:var(--lime);stroke-width:4}
.build-svg .crane{fill:none;stroke:#6f7266;stroke-width:7;stroke-linecap:square}
.build-svg .cable{stroke:var(--lime);stroke-width:2.5;stroke-dasharray:4 5}
.build-svg .ground{stroke:#5f6257;stroke-width:4;stroke-linecap:round}

/* base hidden state */
.build .piece{opacity:0}
.build .drawn{opacity:0}

/* play state */
.build.play .piece{animation:bDrop .7s cubic-bezier(.32,1.25,.5,1) both;animation-delay:var(--d);opacity:1}
.build.play .drawn{stroke-dashoffset:var(--len);animation:bDraw .55s ease forwards;animation-delay:var(--d);opacity:1}
.build.play .crane-grp{animation:bFade .7s ease backwards;animation-delay:.05s}
.build.play .cable{animation:bBob 2.4s ease-in-out 1.2s infinite}
.build.play .hook{animation:bHook 2.4s ease-in-out 1.2s infinite}
.build.play .apex-pulse{animation:bPulse 2.8s ease-in-out 4s infinite}

@keyframes bFade{from{opacity:0}to{opacity:1}}

@keyframes bDrop{from{transform:translateY(-280px);opacity:0}55%{opacity:1}to{transform:translateY(0);opacity:1}}
@keyframes bDraw{from{stroke-dashoffset:var(--len)}to{stroke-dashoffset:0}}
@keyframes bBob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@keyframes bHook{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@keyframes bPulse{0%,100%{opacity:1}50%{opacity:.45}}
.drawn{stroke-dasharray:var(--len)}

.build__tag{position:absolute;left:0;bottom:-6px;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:.18em;font-size:.72rem;color:var(--txt-light-dim)}
.build__tag b{color:var(--lime)}
@media(prefers-reduced-motion:reduce){
  .build .piece,.build .drawn{opacity:1;animation:none!important;stroke-dashoffset:0!important}
}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{background:var(--ink-2);border-block:1px solid var(--ink-3)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ink-3)}
.stat{background:var(--ink);padding:clamp(26px,3.5vw,42px) clamp(20px,2.5vw,32px);text-align:center}
.stat .num{font-family:var(--display);font-size:clamp(2.4rem,4.4vw,3.6rem);color:#fff;line-height:1}
.stat .num span{color:var(--lime)}
.stat .lbl{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:var(--txt-light-dim);margin-top:.5rem}
@media(max-width:760px){.stats .wrap{grid-template-columns:1fr 1fr}}

/* ============================================================
   FOUNDER — then & now
   ============================================================ */
.founder{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(32px,5vw,72px);align-items:center}
.founder__photos{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:end}
.fphoto{position:relative}
.fphoto img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:grayscale(.15)}
.fphoto--then img{aspect-ratio:3/4}
.fphoto--now{margin-bottom:26px}
.fphoto__cap{font-family:var(--cond);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--txt-dim);margin-top:.7rem;display:flex;align-items:center;gap:.5em}
.fphoto__cap::before{content:"";width:18px;height:2px;background:var(--lime)}
.fslot{width:100%;aspect-ratio:3/4;background:
  repeating-linear-gradient(45deg,#1a1c14 0 12px,#15170f 12px 24px);
  border:2px dashed var(--steel-d);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;padding:16px;color:var(--txt-light-dim)}
.fslot .ic{font-size:1.6rem;color:var(--lime)}
.fslot .t{font-family:var(--mono,monospace);font-size:.72rem;letter-spacing:.05em;line-height:1.5}
.founder__body .display{margin:.8rem 0 1.2rem}
.founder__body p{color:var(--txt-dim);margin-bottom:1.1rem;max-width:50ch}
.ink .founder__body p,.founder__body .founder__story p{color:#D5D6CB;max-width:58ch;font-size:1.04rem;line-height:1.62}
.ink .founder__body .founder__story strong.lime{font-weight:600}
.ink .founder__body .sign{color:#fff}
.founder__body .sign{font-family:var(--display);color:var(--txt-dark);font-size:1.3rem;letter-spacing:.02em;margin-top:1.4rem}
.founder__body .sign span{display:block;font-family:var(--cond);font-size:.82rem;letter-spacing:.14em;color:var(--txt-dim);text-transform:uppercase;margin-top:.2rem}
.vet-tag{display:inline-flex;align-items:center;gap:.6em;background:var(--ink);color:var(--lime);
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;padding:.5em 1em;margin-bottom:.4rem}
@media(max-width:860px){.founder{grid-template-columns:1fr}.founder__photos{max-width:480px}}

/* ============================================================
   CONTACT (with plugin form slot)
   ============================================================ */
.contact{position:relative;background:var(--ink);color:var(--txt-light);overflow:hidden}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,5vw,72px)}
.contact__info .display{margin:.8rem 0 1.4rem}
.contact__info p{color:var(--txt-light-dim);max-width:42ch;margin-bottom:2rem}
.cinfo{display:flex;flex-direction:column;gap:1.3rem;margin-bottom:2rem}
.cinfo__row{display:flex;gap:1rem;align-items:flex-start}
.cinfo__ic{width:46px;height:46px;flex:none;background:var(--ink-2);border:1px solid var(--ink-3);display:flex;align-items:center;justify-content:center;color:var(--lime);font-weight:700}
.cinfo__row .k{font-family:var(--cond);text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--txt-light-dim)}
.cinfo__row .v{font-size:1.15rem;color:#fff;font-weight:600}
.cinfo__row .v a:hover{color:var(--lime)}
.note{font-size:.85rem;color:var(--txt-light-dim);border-left:3px solid var(--lime);padding-left:1rem;max-width:44ch}

/* form plugin slot */
.formslot{background:var(--ink-2);border:1px solid var(--ink-3);padding:clamp(26px,3vw,40px)}
.formslot__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.formslot__head h3{font-family:var(--cond);text-transform:uppercase;letter-spacing:.04em;font-size:1.4rem;color:#fff}
.plugin-pill{font-family:var(--mono,monospace);font-size:.68rem;letter-spacing:.06em;color:var(--lime);border:1px solid var(--ink-3);background:#0d0f09;padding:.45em .7em;text-transform:uppercase}
/* dummy fields to show intended shape; real plugin replaces this block */
.ff{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ff .full{grid-column:1/-1}
.field label{display:block;font-family:var(--cond);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--txt-light-dim);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;background:#0d0f09;border:1px solid var(--ink-3);color:#fff;
  padding:.85em .9em;font-family:var(--body);font-size:1rem;outline:none;transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--lime)}
.field textarea{resize:vertical;min-height:110px}
.formslot .btn{width:100%;justify-content:center;margin-top:4px}

/* ---- Contact Form 7 output (when the CF7 shortcode replaces the dummy form) ---- */
.formslot .wpcf7-form-control-wrap{display:block;width:100%}
.formslot .ff p{margin:0}
.formslot .wpcf7-form-control{width:100%}
.formslot .wpcf7-not-valid-tip{color:#ff7a6b;font-family:var(--body);font-size:.82rem;margin-top:.35rem;text-transform:none;letter-spacing:0}
.formslot input.wpcf7-not-valid,.formslot textarea.wpcf7-not-valid,.formslot select.wpcf7-not-valid{border-color:#ff7a6b}
.formslot .wpcf7-response-output{margin:1.2rem 0 0;border:1px solid var(--ink-3);padding:.8em 1em;font-family:var(--cond);
  text-transform:uppercase;letter-spacing:.06em;font-size:.85rem;color:var(--txt-light)}
.formslot .wpcf7-mail-sent-ok{border-color:var(--lime);color:var(--lime)}
.formslot .wpcf7-spinner{background:var(--lime)}
.formslot .wpcf7 .ajax-loader{margin-top:.6rem}
.slot-overlay{display:flex;align-items:center;gap:.6em;font-family:var(--mono,monospace);font-size:.72rem;color:var(--txt-light-dim);margin-top:1rem;border-top:1px dashed var(--ink-3);padding-top:1rem}
.slot-overlay b{color:var(--lime)}
@media(max-width:860px){.contact__grid{grid-template-columns:1fr}.ff{grid-template-columns:1fr}}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:100;background:var(--ink);transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding:24px var(--gutter)}
.mobile-menu.open{transform:none}
.mobile-menu__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
.mobile-menu__head img{height:46px}
.mobile-menu a{font-family:var(--cond);text-transform:uppercase;letter-spacing:.06em;font-size:1.4rem;color:#fff;padding:14px 0;border-bottom:1px solid var(--ink-3);display:block}
.mobile-menu .close{background:none;border:0;color:var(--lime);font-size:2rem;cursor:pointer;line-height:1}
.mobile-menu__sub a{font-size:1rem;color:var(--txt-light-dim);padding:8px 0;border:0}

/* ============================================================
   SERVICE SUBPAGE
   ============================================================ */
.phero{position:relative;background:#0b0c08;color:var(--txt-light);overflow:hidden}
.phero__bg{position:absolute;inset:0}
.phero__bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.phero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(8,9,6,.95) 0%,rgba(8,9,6,.72) 55%,rgba(8,9,6,.5) 100%)}
.phero__in{position:relative;z-index:2;padding-block:clamp(48px,7vw,92px);
  display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(28px,4vw,60px);align-items:center}
.phero__media{position:relative}
.phero__media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.phero__media .badge-tab{position:absolute;left:-12px;top:24px;background:var(--lime);color:#11130A;
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;padding:.5em .9em;white-space:nowrap}
@media(max-width:860px){.phero__in{grid-template-columns:1fr}.phero__media{max-width:520px}}
.crumb{display:flex;gap:.6em;align-items:center;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;color:var(--txt-light-dim);margin-bottom:1.4rem}
.crumb a:hover{color:var(--lime)}
.crumb .sep{color:var(--steel-d)}
.crumb .here{color:var(--lime)}
.phero .svc-no{font-family:var(--cond);font-weight:700;letter-spacing:.14em;color:var(--lime);font-size:.85rem;text-transform:uppercase}
.phero h1{margin:.8rem 0 1.2rem;max-width:18ch}
.phero__sub{font-size:clamp(1.05rem,1.6vw,1.28rem);color:#D9DACF;max-width:60ch;margin-bottom:2rem}
.phero__cta{display:flex;gap:1rem;flex-wrap:wrap}

/* lead statement */
.lead{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,3vw,40px);align-items:start}
.lead__bar{width:5px;background:var(--lime);align-self:stretch;min-height:100%}
.lead p{font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.4;font-weight:500;color:var(--txt-dark);max-width:30ch;font-family:var(--body)}
.lead .lead__body{color:var(--txt-dim);font-size:1.08rem;max-width:60ch;font-weight:400}
.lead .lead__body p{font-size:1.08rem;font-weight:400;color:var(--txt-dim);max-width:62ch;margin-bottom:1rem}

/* lead + before/after split */
.lead-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.lead-split .lead{grid-template-columns:auto 1fr}
.lead-split__copy .eyebrow{margin-bottom:1rem}
.lead-split__copy .display{margin:.4rem 0 1.2rem}
.lead-split__copy p{color:var(--txt-dim);font-size:1.08rem;max-width:48ch;margin-bottom:1rem}
@media(max-width:860px){.lead-split{grid-template-columns:1fr}}

/* before / after slider */
.ba{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--paper-2);
  border:1px solid var(--paper-3);user-select:none;touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ba__before{position:absolute;inset:0;z-index:2}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--lime);z-index:4;transform:translateX(-50%);pointer-events:none}
.ba__handle::after{content:"⟺";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:42px;height:42px;background:var(--lime);color:#11130A;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;box-shadow:var(--shadow)}
.ba__range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5}
.ba__tag{position:absolute;bottom:14px;z-index:3;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:.12em;font-size:.74rem;font-weight:700;color:#fff;background:rgba(11,13,8,.72);padding:.4em .8em}
.ba__tag--b{left:14px}
.ba__tag--a{right:14px}

/* two-up cards (Replacement / Repair) */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:clamp(34px,4vw,52px)}
.duocard{background:var(--paper);border:1px solid var(--paper-3);overflow:hidden;display:flex;flex-direction:column}
.ink .duocard{background:var(--ink-2);border-color:var(--ink-3)}
.duocard__img{position:relative;aspect-ratio:16/10;overflow:hidden}
.duocard__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.duocard:hover .duocard__img img{transform:scale(1.05)}
.duocard__tag{position:absolute;top:0;left:0;background:var(--lime);color:#11130A;font-family:var(--cond);
  font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;padding:.5em 1em}
.duocard__b{padding:clamp(22px,2.5vw,32px)}
.duocard__b h3{font-family:var(--cond);text-transform:uppercase;font-size:1.6rem;margin-bottom:.7rem;letter-spacing:.02em}
.ink .duocard__b h3{color:#fff}
.duocard__b p{color:var(--txt-dim);font-size:1.02rem}
.ink .duocard__b p{color:var(--txt-light-dim)}

/* included checklist */
.incl{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 28px;margin-top:clamp(28px,3vw,40px)}
.incl li{display:flex;gap:.7em;align-items:flex-start;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:.03em;font-size:1.02rem;color:var(--txt-light);padding-bottom:14px;border-bottom:1px solid var(--ink-3)}
.incl .tick{color:var(--lime);font-weight:700;flex:none}
.paper .incl li{color:var(--txt-dark);border-color:var(--paper-3)}

/* gallery slideshow (landscape) */
.gallery{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--ink-2);border:1px solid var(--ink-3)}
.gallery img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease,transform 6s ease;transform:scale(1.04)}
.gallery img.active{opacity:1;transform:scale(1.1)}
.gallery::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(8,9,6,.55) 100%)}
.gallery__dots{position:absolute;z-index:3;right:18px;bottom:18px;display:flex;gap:8px}
.gallery__dots button{width:10px;height:10px;border:0;padding:0;cursor:pointer;background:rgba(255,255,255,.4);transition:.2s}
.gallery__dots button.on{background:var(--lime);width:26px}
.gallery__cap{position:absolute;z-index:3;left:18px;bottom:16px;font-family:var(--cond);text-transform:uppercase;
  letter-spacing:.12em;font-size:.82rem;color:#fff}
.gallery__cap b{color:var(--lime)}

@media(max-width:860px){
  .lead{grid-template-columns:auto 1fr}
  .duo{grid-template-columns:1fr}
  .incl{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .lead{grid-template-columns:1fr}
  .lead__bar{display:none}
  .incl{grid-template-columns:1fr}
}

/* ============================================================
   MOBILE & TABLET REFINEMENTS  (desktop ≥861px is untouched)
   ============================================================ */
.topbar .pill{white-space:nowrap}

@media(max-width:860px){
  /* header: logo back to a sane size once the hamburger appears */
  .nav{min-height:66px;gap:1rem}
  .nav__logo{margin-block:0}
  .nav__logo img{height:54px}
  /* hero stacks: copy, then the build animation, THEN the CTAs (read → watch → act) */
  .hero__inner{grid-template-columns:1fr;gap:0;padding-block:clamp(44px,9vw,76px)}
  .hero__copy{display:contents}
  .hero__eyebrow{order:1}
  .hero h1{order:2}
  .hero__sub{order:3}
  .build-wrap{order:4;max-width:380px;margin-top:.4rem}
  .hero__cta{order:5;margin-top:2rem}
  .hero__grid{display:none}
  /* collapse inline 3-col grids (why-us / service-area) — beat inline styles */
  .why__grid{grid-template-columns:1fr 1fr!important}
  .incl{grid-template-columns:1fr 1fr!important}
}

@media(max-width:620px){
  /* drop the header quote button — the hamburger menu carries it */
  .nav__cta{display:none}
  .hero h1{max-width:14ch}
  .why__grid{grid-template-columns:1fr!important}
  .incl{grid-template-columns:1fr!important}
  /* CTA band stacks cleanly with a full-width button */
  .ctaband .wrap{flex-direction:column;align-items:flex-start;gap:1.1rem}
  .ctaband .btn{width:100%;justify-content:center}
  .build-wrap{max-width:320px}
}

@media(max-width:520px){
  .topbar .pill{font-size:.68rem;letter-spacing:.05em}
  .topbar .tb-right a{font-size:.78rem}
}

/* ============================================================
   PORTFOLIO — clickable tiles + scrapbook page + lightbox
   ============================================================ */

/* make home portfolio tiles read as openable */
.port{cursor:pointer}
.port__open{position:absolute;z-index:3;top:14px;right:14px;display:flex;align-items:center;gap:.45em;
  background:var(--lime);color:#11130A;font-family:var(--cond);font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;font-size:.72rem;padding:.4em .7em;opacity:0;transform:translateY(-6px);transition:.25s ease}
.port:hover .port__open{opacity:1;transform:none}

/* ---- Scope-of-work overlay: reusable on ANY gallery front image ----
   Drop a <ul class="port__scope"><li>…</li></ul> inside a .port tile or a
   .scrapcard__photo. Text + spacing auto-scale to the card via container queries. */
.port,.scrapcard__photo{container-type:inline-size}
.port__scope{position:absolute;z-index:3;top:clamp(8px,2.2cqi,18px);right:clamp(8px,2.2cqi,18px);
  display:flex;flex-direction:column;align-items:flex-end;gap:clamp(4px,.9cqi,7px);pointer-events:none;
  max-width:88%}
.port__scope li{font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  line-height:1;color:#fff;background:rgba(11,13,8,.62);backdrop-filter:blur(2px);
  padding:.5em .7em;border-right:3px solid var(--lime);text-align:right;white-space:nowrap;
  font-size:clamp(.66rem,2.35cqi,1.05rem);max-width:100%;overflow:hidden;text-overflow:ellipsis}
/* if a tile/card has a populated scope list, move its top-right badge/pin to the left to avoid overlap */
.port:has(.port__scope li) .port__open{left:18px;right:auto}
.scrapcard:has(.port__scope li) .pin{left:10px;right:auto}
.port__count{font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  font-size:.72rem;color:var(--lime);margin-top:.3rem;display:block}

/* ---- Scrapbook layout (portfolio.html) ---- */
.scrap-intro{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(30px,4vw,52px)}
.scrap-band{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-weight:700;
  font-size:.8rem;color:var(--txt-dim);display:flex;align-items:center;gap:.7em;margin:clamp(40px,5vw,64px) 0 clamp(22px,3vw,34px)}
.scrap-band::before{content:"";width:30px;height:3px;background:var(--lime)}
.scrap-band::after{content:"";flex:1;height:1px;background:var(--paper-3)}

.scrap{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(18px,2.4vw,30px)}
.scrapcard{position:relative;background:#fff;padding:12px 12px 0;box-shadow:0 14px 32px -16px rgba(0,0,0,.5);
  cursor:pointer;transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s ease;display:block}
.scrapcard__photo{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--paper-2)}
.scrapcard__photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.scrapcard:hover{transform:rotate(0deg) translateY(-6px) scale(1.015)!important;box-shadow:0 26px 50px -18px rgba(0,0,0,.6);z-index:5}
.scrapcard:hover .scrapcard__photo img{transform:scale(1.05)}
/* tape accent */
.scrapcard::before{content:"";position:absolute;top:-11px;left:50%;transform:translateX(-50%) rotate(-2.5deg);
  width:88px;height:24px;background:rgba(202,237,0,.42);border:1px solid rgba(202,237,0,.55);
  box-shadow:0 2px 5px rgba(0,0,0,.12)}
.scrapcard__cap{padding:14px 4px 16px}
.scrapcard__cap .loc{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--steel);font-weight:700}
.scrapcard__cap h3{font-family:var(--cond);text-transform:uppercase;font-size:1.35rem;line-height:1;color:var(--txt-dark);margin-top:.2rem}
.scrapcard__cap .n{font-family:var(--cond);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--lime);margin-top:.45rem;display:inline-flex;align-items:center;gap:.4em;white-space:nowrap}
.scrapcard .pin{position:absolute;top:10px;right:10px;z-index:3;background:#11130A;color:var(--lime);
  font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.64rem;padding:.35em .6em}

/* featured = larger spans; alternate tilt for scrapbook feel */
.scrap--featured .scrapcard:nth-child(1){grid-column:span 7;transform:rotate(-1.2deg)}
.scrap--featured .scrapcard:nth-child(2){grid-column:span 5;transform:rotate(1.4deg)}
.scrap--featured .scrapcard:nth-child(3){grid-column:span 5;transform:rotate(1deg)}
.scrap--featured .scrapcard:nth-child(4){grid-column:span 4;transform:rotate(-1.6deg)}
.scrap--featured .scrapcard:nth-child(5){grid-column:span 3;transform:rotate(1.2deg)}
.scrap--more .scrapcard{grid-column:span 4;transform:rotate(-1deg)}
.scrap--more .scrapcard:nth-child(even){transform:rotate(1.3deg)}

@media(max-width:860px){
  .scrap--featured .scrapcard:nth-child(n){grid-column:span 6}
  .scrap--more .scrapcard{grid-column:span 6}
}
@media(max-width:560px){
  .scrap--featured .scrapcard:nth-child(n),.scrap--more .scrapcard{grid-column:span 12;transform:rotate(0deg)}
  .scrap{gap:24px}
}

/* ---- Lightbox ---- */
.lb{position:fixed;inset:0;z-index:300;background:rgba(7,8,5,.97);display:none;flex-direction:column}
.lb.open{display:flex}
.lb__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:18px clamp(16px,4vw,40px);
  border-bottom:1px solid var(--ink-3)}
.lb__meta .t{font-family:var(--cond);text-transform:uppercase;letter-spacing:.04em;font-size:1.25rem;color:#fff;line-height:1}
.lb__meta .s{font-family:var(--cond);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--lime);margin-top:.2rem}
.lb__count{font-family:var(--cond);letter-spacing:.1em;color:var(--txt-light-dim);font-size:.85rem}
.lb__close{background:none;border:1px solid var(--ink-3);color:#fff;width:44px;height:44px;cursor:pointer;
  font-size:1.4rem;line-height:1;transition:.2s;flex:none}
.lb__close:hover{background:var(--lime);color:#11130A;border-color:var(--lime)}
.lb__stage{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:clamp(10px,2vw,24px)}
.lb__img{max-width:94vw;max-height:74vh;object-fit:contain;box-shadow:0 30px 80px -30px #000;background:#0c0d09}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(20,22,15,.7);border:1px solid var(--ink-3);
  color:#fff;width:54px;height:54px;cursor:pointer;font-size:1.6rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:.2s}
.lb__nav:hover{background:var(--lime);color:#11130A;border-color:var(--lime)}
.lb__nav--prev{left:clamp(8px,2vw,24px)}
.lb__nav--next{right:clamp(8px,2vw,24px)}
.lb__thumbs{display:flex;gap:8px;padding:14px clamp(16px,4vw,40px);overflow-x:auto;border-top:1px solid var(--ink-3);scrollbar-width:thin}
.lb__thumbs img{height:58px;width:80px;object-fit:cover;opacity:.45;cursor:pointer;transition:.2s;flex:none;border:2px solid transparent}
.lb__thumbs img:hover{opacity:.8}
.lb__thumbs img.on{opacity:1;border-color:var(--lime)}
@media(max-width:620px){
  .lb__nav{width:44px;height:44px;font-size:1.3rem}
  .lb__img{max-height:64vh}
  .lb__thumbs img{height:46px;width:64px}
}
