/* ============================================================
   SOLICA — Direction 2: CIVIC
   Solid, institutional, timeless. Wide grotesque headlines,
   strong structural grid, confident crimson color-blocking.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700&family=Archivo+Expanded:wght@600;700;800&display=swap');

:root{
  --crimson:#C61130;
  --crimson-deep:#A20E27;
  --orange:#F4901E;
  --ink:#171513;
  --ink-2:#2c2825;
  --slate:#6B7280;
  --paper:#FFFFFF;
  --bone:#F3F0EB;
  --line:#E2DCD2;
  --line-dk:#1f1c19;

  --sans:'Archivo', system-ui, sans-serif;
  --wide:'Archivo Expanded','Archivo', system-ui, sans-serif;

  --maxw:1320px;
  --gutter:clamp(20px,5vw,64px);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.6;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}

/* type */
.label{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--crimson);display:inline-flex;align-items:center;gap:10px;}
.label .no{font-variant-numeric:tabular-nums;color:var(--ink);}
.label.light{color:#fff;}
.label.light .no{color:rgba(255,255,255,.55);}
.disp{font-family:var(--wide);font-weight:700;text-transform:uppercase;line-height:.98;letter-spacing:-.005em;}
h1.disp{font-size:clamp(40px,6.4vw,86px);}
h2.disp{font-size:clamp(30px,4.2vw,58px);}
h3.disp{font-size:clamp(20px,2.2vw,26px);}
.lead{font-size:clamp(19px,1.9vw,23px);line-height:1.5;color:var(--ink-2);font-weight:500;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:16px 28px;transition:background .18s,color .18s,transform .15s;}
.btn .arr{transition:transform .2s;}
.btn:hover .arr{transform:translateX(4px);}
.btn-solid{background:var(--crimson);color:#fff;}
.btn-solid:hover{background:var(--crimson-deep);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;}
.btn-out{border:2px solid var(--ink);color:var(--ink);}
.btn-out:hover{background:var(--ink);color:#fff;}
.txtlink{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--crimson);display:inline-flex;align-items:center;gap:9px;}
.txtlink .arr{transition:transform .2s;}
.txtlink:hover .arr{transform:translateX(4px);}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:50;background:#fff;border-bottom:2px solid var(--ink);}
.nav-top{height:4px;background:var(--crimson);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand .sun{width:30px;height:30px;flex:none;}
.brand .word{font-family:var(--wide);font-weight:800;letter-spacing:.12em;font-size:18px;text-transform:uppercase;}
.nav-links{display:flex;gap:30px;}
.nav-links a{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);padding:4px 0;border-bottom:2px solid transparent;transition:border-color .18s,color .18s;}
.nav-links a:hover,.nav-links a.active{color:var(--crimson);border-color:var(--crimson);}
.switcher{display:flex;align-items:center;border:2px solid var(--ink);}
.switcher .lbl{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);padding:0 10px;}
.switcher a{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:8px 13px;color:var(--ink-2);border-left:2px solid var(--ink);transition:background .15s,color .15s;}
.switcher a:hover{background:var(--bone);}
.switcher a.on{background:var(--ink);color:#fff;}

/* ===== HERO ===== */
.hero{position:relative;border-bottom:2px solid var(--ink);}
.hero-img{position:relative;height:min(80vh,720px);overflow:hidden;background:var(--ink);}
.hero-img img{width:100%;height:100%;object-fit:cover;}
.hero-img .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,18,16,.6),rgba(20,18,16,.15) 55%,transparent);}
.hero-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;}
.hero-card{background:var(--crimson);color:#fff;padding:clamp(26px,3.4vw,46px);max-width:min(620px,84vw);margin-bottom:0;border-top:6px solid var(--orange);}
.hero-card h1{color:#fff;margin:14px 0 18px;}
.hero-card .lead{color:rgba(255,255,255,.92);font-weight:500;}
.hero-bar{display:grid;grid-template-columns:repeat(3,1fr);}
.hero-bar .hb{padding:22px var(--gutter);border-right:2px solid var(--ink);}
.hero-bar .hb:last-child{border-right:0;}
.hero-bar .hk{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);}
.hero-bar .hv{font-family:var(--wide);font-weight:700;font-size:clamp(18px,2vw,24px);text-transform:uppercase;margin-top:4px;}

/* ===== STORY ===== */
.story{padding:clamp(60px,8vw,118px) 0;}
.story-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.25fr);gap:clamp(30px,6vw,90px);align-items:start;}
.story-grid .sticky{position:sticky;top:110px;}
.story p{margin-bottom:1.1em;font-size:clamp(18px,1.7vw,21px);line-height:1.62;}
.story p strong{font-weight:700;}
.barside{border-left:4px solid var(--crimson);padding-left:22px;}

/* ===== FEATURED ===== */
.featured{padding:clamp(48px,6vw,90px) 0;background:var(--bone);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(30px,4vw,52px);}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--ink);background:var(--ink);}
.card{background:#fff;display:flex;flex-direction:column;}
.cards .card{border-right:2px solid var(--ink);}
.cards .card:last-child{border-right:0;}
.card .cimg{aspect-ratio:4/3;overflow:hidden;background:var(--bone);border-bottom:2px solid var(--ink);position:relative;}
.card .cimg img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.card:hover .cimg img{transform:scale(1.05);}
.card .cidx{position:absolute;top:0;left:0;background:var(--crimson);color:#fff;font-family:var(--wide);font-weight:700;font-size:14px;padding:8px 14px;letter-spacing:.05em;}
.card .cbody{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.card .cname{font-family:var(--wide);font-weight:700;text-transform:uppercase;font-size:22px;line-height:1;margin-bottom:14px;}
.card .cmeta{font-size:13px;color:var(--slate);line-height:1.85;border-top:1px solid var(--line);padding-top:12px;margin-bottom:18px;}
.card .cmeta b{color:var(--ink);font-weight:600;}
.card .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(135deg,var(--bone),var(--bone) 12px,#e8e1d6 12px,#e8e1d6 24px);}
.card .ph span{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);background:#fff;padding:6px 12px;border:1px solid var(--line);}
.card .ctail{margin-top:auto;}

/* ===== NUMBERS (crimson band) ===== */
.numbers{background:var(--crimson);color:#fff;padding:clamp(54px,7vw,100px) 0;}
.num-grid{display:grid;grid-template-columns:repeat(3,1fr);margin-top:34px;}
.num{padding:0 clamp(16px,3vw,40px);border-left:2px solid rgba(255,255,255,.25);}
.num:first-child{padding-left:0;border-left:0;}
.num .n{font-family:var(--wide);font-weight:800;font-size:clamp(50px,7vw,96px);line-height:.9;}
.num .k{font-size:13px;font-weight:600;letter-spacing:.04em;margin-top:14px;color:rgba(255,255,255,.9);text-transform:uppercase;}
.prov{border-bottom:2px dashed rgba(255,255,255,.5);}
.prov-note{font-size:12px;letter-spacing:.04em;color:rgba(255,255,255,.7);margin-top:30px;display:flex;align-items:center;gap:9px;}
.prov-note::before{content:"";width:20px;height:0;border-bottom:2px dashed rgba(255,255,255,.6);}

/* ===== NEIGHBORHOOD ===== */
.hood{padding:clamp(60px,8vw,118px) 0;}
.hood-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:2px solid var(--ink);background:var(--ink);margin-top:clamp(30px,4vw,50px);}
.hood-fig{position:relative;overflow:hidden;aspect-ratio:1/1;border-right:2px solid var(--ink);background:var(--bone);}
.hood-fig:last-child{border-right:0;}
.hood-fig img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.hood-fig:hover img{transform:scale(1.06);}
.hood-fig figcaption{position:absolute;left:0;bottom:0;right:0;background:linear-gradient(transparent,rgba(20,18,16,.82));color:#fff;padding:30px 16px 14px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;}

/* ===== CTA ===== */
.cta{background:var(--ink);color:#fff;padding:clamp(64px,9vw,130px) 0;}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;}
.cta h2{color:#fff;}
.cta .sub{color:rgba(255,255,255,.7);margin-top:18px;max-width:40ch;}

/* ===== FOOTER ===== */
footer{background:#000;color:#b9b3aa;padding:clamp(46px,6vw,80px) 0 36px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;}
.foot-grid h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#7c766d;margin-bottom:14px;font-weight:700;}
.foot-grid a,.foot-grid p{font-size:14px;color:#b9b3aa;line-height:1.85;}
.foot-grid a:hover{color:var(--orange);}
.foot-brand .word{font-family:var(--wide);font-weight:800;letter-spacing:.1em;font-size:18px;color:#fff;text-transform:uppercase;}
.foot-tag{font-size:14px;color:#8a847b;margin-top:12px;letter-spacing:.02em;}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:50px;padding-top:22px;border-top:1px solid #2a2722;font-size:12px;color:#6f6960;letter-spacing:.03em;}

/* ===== CASE STUDY ===== */
.cs-hero{position:relative;height:min(78vh,700px);overflow:hidden;background:var(--ink);border-bottom:2px solid var(--ink);}
.cs-hero img{width:100%;height:100%;object-fit:cover;}
.cs-hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,16,.2),rgba(20,18,16,.1) 45%,rgba(20,18,16,.78));}
.cs-hero .cs-head{position:absolute;left:0;right:0;bottom:0;color:#fff;padding-bottom:clamp(26px,3.5vw,46px);}
.cs-hero h1{color:#fff;margin-top:14px;}
.cs-statbar{display:grid;grid-template-columns:repeat(4,auto);gap:0;background:var(--ink);border:2px solid var(--ink);}
.cs-statbar .m{background:#fff;padding:16px 26px;border-right:2px solid var(--ink);}
.cs-statbar .m:last-child{border-right:0;}
.cs-statbar .k{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);}
.cs-statbar .v{font-family:var(--wide);font-weight:700;text-transform:uppercase;font-size:16px;margin-top:3px;}

.cs-body{padding:clamp(54px,7vw,104px) 0;}
.cs-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,0.95fr);gap:clamp(34px,6vw,80px);align-items:start;}
.cs-narrative p{margin-bottom:1.15em;font-size:clamp(18px,1.6vw,20px);line-height:1.65;}
.cs-narrative p.intro{font-family:var(--wide);font-weight:600;text-transform:none;font-size:clamp(21px,2.3vw,29px);line-height:1.3;letter-spacing:-.01em;margin-bottom:1.3em;}
.facts{border:2px solid var(--ink);position:sticky;top:100px;}
.facts h4{background:var(--ink);color:#fff;font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:14px 20px;font-weight:700;}
.facts .frow{display:flex;justify-content:space-between;gap:14px;padding:13px 20px;border-bottom:1px solid var(--line);}
.facts .frow:last-child{border-bottom:0;}
.facts dt{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--slate);}
.facts dd{font-weight:600;text-align:right;font-size:15px;}

/* before/after — TABBED toggle */
.ba{padding:clamp(48px,7vw,96px) 0;background:var(--bone);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);}
.ba-toggle{display:inline-flex;border:2px solid var(--ink);margin-top:26px;}
.ba-toggle button{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:13px 30px;background:#fff;color:var(--ink-2);border:0;border-right:2px solid var(--ink);cursor:pointer;transition:background .15s,color .15s;}
.ba-toggle button:last-child{border-right:0;}
.ba-toggle button.on{background:var(--crimson);color:#fff;}
.ba-stage{margin-top:26px;border:2px solid var(--ink);background:var(--ink);position:relative;aspect-ratio:3/2;overflow:hidden;}
.ba-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease;}
.ba-stage img.show{opacity:1;}
.ba-stage .tag{position:absolute;top:0;left:0;z-index:3;background:var(--crimson);color:#fff;font-family:var(--wide);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:9px 18px;}
.ba-stage .tag .yr{opacity:.7;}

/* gallery */
.gallery{padding:clamp(54px,7vw,104px) 0;}
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;background:var(--ink);border:2px solid var(--ink);margin-top:clamp(26px,4vw,46px);}
.gal{overflow:hidden;background:var(--bone);}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.gal:hover img{transform:scale(1.05);}
.gal.wide{grid-column:span 8;aspect-ratio:16/10;}
.gal.tall{grid-column:span 4;aspect-ratio:3/4;}
.gal.half{grid-column:span 6;aspect-ratio:4/3;}
.gal.third{grid-column:span 4;aspect-ratio:1/1;}

/* pull quote */
.pull{background:var(--crimson);color:#fff;padding:clamp(56px,8vw,110px) 0;}
.pull blockquote{font-family:var(--wide);font-weight:700;text-transform:uppercase;font-size:clamp(24px,3.4vw,46px);line-height:1.12;max-width:20ch;}
.pull cite{display:block;font-family:var(--sans);font-style:normal;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-top:26px;}

/* prev/next */
.csnav{display:grid;grid-template-columns:1fr 1fr;border-top:2px solid var(--ink);}
.csnav a{padding:clamp(26px,4vw,50px) var(--gutter);transition:background .18s;}
.csnav a:hover{background:var(--bone);}
.csnav a+a{border-left:2px solid var(--ink);text-align:right;}
.csnav .dir{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--crimson);margin-bottom:8px;}
.csnav .pn{font-family:var(--wide);font-weight:700;text-transform:uppercase;font-size:clamp(20px,2.4vw,32px);}

/* responsive */
@media(max-width:900px){
  .nav-links{display:none;}
  .hero-bar{grid-template-columns:1fr;}
  .hero-bar .hb{border-right:0;border-bottom:2px solid var(--ink);}
  .story-grid{grid-template-columns:1fr;}
  .story-grid .sticky{position:static;}
  .cards{grid-template-columns:1fr;}
  .cards .card{border-right:0;border-bottom:2px solid var(--ink);}
  .cards .card:last-child{border-bottom:0;}
  .num-grid{grid-template-columns:1fr;gap:24px;}
  .num{border-left:0;padding-left:0;}
  .hood-grid{grid-template-columns:1fr 1fr;}
  .hood-fig:nth-child(2){border-right:0;}
  .cta-grid{grid-template-columns:1fr;}
  .cs-layout{grid-template-columns:1fr;}
  .facts{position:static;}
  .cs-statbar{grid-template-columns:1fr 1fr;}
  .cs-statbar .m:nth-child(2){border-right:0;}
  .cs-statbar .m{border-bottom:2px solid var(--ink);}
  .gal.wide,.gal.tall,.gal.half,.gal.third{grid-column:span 12;aspect-ratio:16/10;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px;}
  .switcher .lbl{display:none;}
}
@media(max-width:560px){
  .cs-statbar{grid-template-columns:1fr;}
  .cs-statbar .m{border-right:0;}
  .hood-grid{grid-template-columns:1fr;}
  .hood-fig{border-right:0;border-bottom:2px solid var(--ink);}
  .foot-grid{grid-template-columns:1fr;}
  .csnav{grid-template-columns:1fr;}
  .csnav a+a{border-left:0;border-top:2px solid var(--ink);text-align:left;}
}
