﻿/* JDLILU - editorial bespoke type system */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f1ece2;
  --bg-2:#e8e1d2;
  --paper:#faf6ee;
  --ink:#14110f;
  --ink-2:#3a3530;
  --muted:#7a7269;
  --line:#221d18;
  --brass:#a87a3d;
  --oxide:#b25232;
  --rule:rgba(20,17,15,.18);
}
html,body{background:var(--bg);color:var(--ink);font-family:"Fraunces",Georgia,serif;-webkit-font-smoothing:antialiased;line-height:1.45}
body{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;letter-spacing:.02em;font-size:.75rem;text-transform:uppercase}
.serif{font-family:"Fraunces",serif}
.wrap{max-width:1320px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 28px}

/* TOP BAR - editorial masthead */
.masthead{border-bottom:1px solid var(--line);background:var(--bg)}
.masthead-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px 28px;gap:24px}
.masthead-meta{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.masthead-meta.right{text-align:right}
.brandmark{display:flex;align-items:center;gap:10px;justify-self:center}
.brandmark .brand-logo{width:140px;height:32px;object-fit:contain}
.brandmark .b-name{font-size:1.05rem;letter-spacing:.32em;font-weight:600}
.nav{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.nav-inner{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;max-width:1320px;margin:0 auto;flex-wrap:wrap;gap:18px}
.nav-list{display:flex;gap:28px;flex-wrap:wrap}
.nav-list a{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);position:relative;padding-bottom:2px}
.nav-list a:hover,.nav-list a.active{color:var(--ink)}
.nav-list a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--oxide)}
.wa-pill{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border:1px solid var(--line);border-radius:999px;font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;background:var(--ink);color:var(--paper);transition:.2s}
.wa-pill:hover{background:var(--oxide);border-color:var(--oxide)}
.wa-pill .dot{width:7px;height:7px;border-radius:50%;background:#7be08a;box-shadow:0 0 0 3px rgba(123,224,138,.25)}

/* HERO - split editorial */
.hero{position:relative;padding:60px 0 80px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:end}
.hero-eyebrow{display:flex;gap:18px;align-items:center;margin-bottom:36px}
.hero-eyebrow .num{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.2em;color:var(--muted)}
.hero-eyebrow .rule{flex:1;height:1px;background:var(--rule);max-width:120px}
.hero h1{font-size:clamp(3rem,7.5vw,7rem);line-height:.92;font-weight:400;letter-spacing:-.02em;font-style:italic}
.hero h1 .alt{font-style:normal;font-weight:600}
.hero h1 .ink-block{background:var(--ink);color:var(--paper);padding:0 .15em;display:inline-block}
.hero-sub{margin-top:32px;font-size:1.18rem;color:var(--ink-2);max-width:42ch;line-height:1.55}
.hero-actions{margin-top:40px;display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line);transition:.2s;cursor:pointer}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--oxide);border-color:var(--oxide)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.hero-art{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.hero-art img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.92) sepia(.1) hue-rotate(-8deg)}
.hero-art .stamp{position:absolute;left:16px;bottom:16px;background:var(--paper);padding:10px 14px;font-family:"JetBrains Mono",monospace;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--line)}


/* WARM IMAGE TUNING */
.intro-stack img,
.o-img img,
.spread figure img,
.t-img img,
.gal figure img,
.mat-img img,
.sol-img img{
  filter:contrast(1.03) saturate(.9) sepia(.12) hue-rotate(-8deg);
}

.ticker{border-bottom:1px solid var(--line);padding:14px 0;overflow:hidden;background:var(--paper)}
.ticker-track{display:flex;gap:60px;animation:ticker 40s linear infinite;white-space:nowrap}
.ticker span{font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-2)}
.ticker span::before{content:"*";margin-right:60px;color:var(--oxide)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION SCAFFOLD */
section{padding:100px 0;border-bottom:1px solid var(--line);position:relative}
.sec-head{display:grid;grid-template-columns:160px 1fr;gap:40px;margin-bottom:64px;align-items:start}
.sec-head .label{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);padding-top:14px;border-top:2px solid var(--ink)}
.sec-head h2{font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1;letter-spacing:-.015em;font-weight:400}
.sec-head h2 em{font-style:italic;color:var(--oxide)}
.sec-head .lede{margin-top:18px;color:var(--ink-2);font-size:1.05rem;max-width:60ch}

/* BRAND INTRO TWO COL */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-grid .text p{font-size:1.1rem;color:var(--ink-2);margin-bottom:18px;line-height:1.6}
.intro-stack{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.intro-stack img{aspect-ratio:3/4;object-fit:cover;width:100%}
.intro-stack img:nth-child(2){margin-top:40px}

/* CORE OFFER - numbered editorial list */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.offer{padding:36px 28px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper);transition:.3s}
.offer:nth-child(3n){border-right:none}
.offer:hover{background:var(--ink);color:var(--paper)}
.offer:hover .o-num{color:var(--oxide)}
.offer .o-num{font-family:"JetBrains Mono",monospace;font-size:.85rem;letter-spacing:.18em;color:var(--muted);margin-bottom:32px}
.offer h3{font-size:1.7rem;line-height:1.05;margin-bottom:14px;font-weight:400;letter-spacing:-.01em}
.offer p{color:var(--ink-2);font-size:.98rem;line-height:1.55}
.offer:hover p{color:rgba(250,246,238,.78)}
.offer .o-img{margin-top:28px;aspect-ratio:5/3;overflow:hidden}
.offer .o-img img{width:100%;height:100%;object-fit:cover}

/* FEATURED PROJECTS - magazine spread */
.spread{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;grid-auto-rows:90px}
.spread figure{position:relative;overflow:hidden}
.spread figure img{width:100%;height:100%;object-fit:cover;transition:1.2s}
.spread figure:hover img{transform:scale(1.04)}
.spread figcaption{position:absolute;left:14px;bottom:14px;background:var(--paper);padding:8px 12px;font-family:"JetBrains Mono",monospace;font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--line)}
.s-a{grid-column:1/span 7;grid-row:span 6}
.s-b{grid-column:8/span 5;grid-row:span 3}
.s-c{grid-column:8/span 5;grid-row:span 3}
.s-d{grid-column:1/span 4;grid-row:span 4}
.s-e{grid-column:5/span 4;grid-row:span 4}
.s-f{grid-column:9/span 4;grid-row:span 4}

/* WHY LIST */
.why{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.why-cell{padding:38px 24px;border-right:1px solid var(--line)}
.why-cell:last-child{border-right:none}
.why-cell .glyph{font-family:"Fraunces",serif;font-size:3rem;font-style:italic;color:var(--oxide);margin-bottom:18px;line-height:1}
.why-cell h4{font-size:1.2rem;margin-bottom:10px;font-weight:500}
.why-cell p{color:var(--ink-2);font-size:.95rem;line-height:1.55}

/* PROCESS TIMELINE - vertical with rule */
.timeline{display:grid;grid-template-columns:60px 1fr;gap:0}
.timeline-rule{position:relative}
.timeline-rule::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line)}
.t-step{display:grid;grid-template-columns:200px 1fr 1fr;gap:40px;padding:48px 0;border-bottom:1px solid var(--rule);align-items:start}
.t-step:last-child{border-bottom:none}
.t-num{font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.2em;color:var(--muted)}
.t-num strong{display:block;font-family:"Fraunces",serif;font-size:3.4rem;font-style:italic;font-weight:400;color:var(--ink);line-height:1;margin-top:6px}
.t-body h3{font-size:1.6rem;font-weight:400;margin-bottom:12px;letter-spacing:-.01em}
.t-body p{color:var(--ink-2);line-height:1.6}
.t-img{aspect-ratio:4/3;overflow:hidden}
.t-img img{width:100%;height:100%;object-fit:cover}

/* GALLERY GRID */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gal figure{position:relative;overflow:hidden;background:var(--bg-2);aspect-ratio:4/3}
.gal figure.tall{aspect-ratio:3/4}
.gal figure img{width:100%;height:100%;object-fit:cover;transition:1s}
.gal figure:hover img{transform:scale(1.05)}
.gal figcaption{position:absolute;inset:auto 0 0 0;padding:14px;background:linear-gradient(transparent,rgba(20,17,15,.85));color:var(--paper);font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase}
.gal-cat{margin:60px 0 24px;display:flex;align-items:baseline;gap:18px}
.gal-cat h3{font-size:2rem;font-weight:400;font-style:italic}
.gal-cat .rule{flex:1;height:1px;background:var(--rule)}
.gal-cat .count{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.18em;color:var(--muted)}

/* MATERIALS - comparative cards */
.mat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.mat{background:var(--paper);border:1px solid var(--line);overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.mat-img{aspect-ratio:1;overflow:hidden}
.mat-img img{width:100%;height:100%;object-fit:cover}
.mat-body{padding:30px}
.mat-body .tag{font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--oxide);margin-bottom:14px}
.mat-body h3{font-size:1.5rem;font-weight:500;margin-bottom:12px}
.mat-body p{color:var(--ink-2);line-height:1.6;font-size:.95rem;margin-bottom:14px}
.mat-body ul{list-style:none}
.mat-body li{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);padding:6px 0;border-bottom:1px dotted var(--rule)}

/* SOLUTIONS - alternate rows */
.sol-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:80px 0;border-bottom:1px dashed var(--rule)}
.sol-row:last-child{border-bottom:none}
.sol-row.flip .sol-img{order:2}
.sol-img{aspect-ratio:5/4;overflow:hidden}
.sol-img img{width:100%;height:100%;object-fit:cover}
.sol-body .tag{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--oxide);margin-bottom:18px}
.sol-body h3{font-size:2.4rem;font-weight:400;line-height:1;letter-spacing:-.015em;margin-bottom:18px;font-style:italic}
.sol-body p{color:var(--ink-2);line-height:1.65;margin-bottom:18px}
.sol-body .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.sol-body .chip{font-family:"JetBrains Mono",monospace;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 12px;border:1px solid var(--line);border-radius:999px}

/* FAQ */
.faq{max-width:880px;margin:0 auto}
.faq-item{border-top:1px solid var(--line);padding:28px 0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;gap:24px;cursor:pointer;align-items:baseline}
.faq-q h3{font-size:1.45rem;font-weight:400;letter-spacing:-.01em;line-height:1.2}
.faq-q .n{font-family:"JetBrains Mono",monospace;font-size:.72rem;letter-spacing:.18em;color:var(--muted)}
.faq-a{margin-top:14px;color:var(--ink-2);line-height:1.65;max-width:62ch}

/* WA BLOCK - large editorial CTA */
.wa-block{background:var(--ink);color:var(--paper);padding:90px 0;border-bottom:1px solid var(--line)}
.wa-block .grid{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.wa-block h2{font-size:clamp(2rem,4.4vw,3.6rem);font-weight:400;line-height:1;letter-spacing:-.015em;font-style:italic}
.wa-block .alt{color:var(--brass)}
.wa-block .sub{margin-top:18px;color:rgba(250,246,238,.7);font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}
.wa-large{display:inline-flex;align-items:center;gap:14px;background:var(--paper);color:var(--ink);padding:22px 32px;font-family:"JetBrains Mono",monospace;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;border-radius:999px;transition:.2s;border:1px solid var(--paper)}
.wa-large:hover{background:var(--oxide);color:var(--paper);border-color:var(--oxide)}

/* PAGE HERO (sub pages) */
.page-hero{padding:80px 0 60px;border-bottom:1px solid var(--line);background:var(--paper)}
.page-hero .crumb{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.page-hero h1{font-size:clamp(2.6rem,6vw,5rem);line-height:.95;font-weight:400;letter-spacing:-.02em;max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--oxide)}
.page-hero .lede{margin-top:30px;font-size:1.15rem;color:var(--ink-2);max-width:60ch;line-height:1.55}

/* PROSE for legal */
.prose h2{font-size:1.6rem;margin:40px 0 14px;font-weight:500;letter-spacing:-.01em}
.prose h3{font-size:1.15rem;margin:24px 0 10px;font-weight:600;font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.1em}
.prose p,.prose li{color:var(--ink-2);line-height:1.7;margin-bottom:12px;font-size:1rem}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose .updated{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:30px;display:block}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:30px}
.contact-card{border:1px solid var(--line);background:var(--paper);padding:28px}
.contact-card h2{font-size:1.35rem;margin:0 0 12px;font-weight:500}
.contact-card p,.contact-card a{display:block;color:var(--ink-2);line-height:1.65;margin-bottom:8px}
.identity-note{margin-top:18px;color:rgba(250,246,238,.62);font-size:.9rem;line-height:1.65;max-width:46ch}
.identity-note strong{display:block;color:rgba(250,246,238,.9);font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:8px}

/* FOOTER */
footer.foot{background:var(--ink);color:var(--paper);padding:80px 0 30px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.foot-grid h5{font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:18px}
.foot-grid p,.foot-grid a{color:rgba(250,246,238,.72);font-size:.95rem;line-height:1.6;display:block;margin-bottom:8px}
.foot-grid a:hover{color:var(--paper)}
.foot-brand{font-size:1.4rem;letter-spacing:.3em;margin-bottom:16px;font-weight:600}
.foot-bottom{border-top:1px solid rgba(250,246,238,.15);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(250,246,238,.5)}
.foot-bottom a{color:rgba(250,246,238,.7);margin-left:18px}

/* RESPONSIVE */
@media (max-width:960px){
  .hero-grid,.intro-grid,.sol-row,.sol-row.flip,.wa-block .grid{grid-template-columns:1fr;gap:36px}
  .sol-row.flip .sol-img{order:0}
  .offers,.why,.mat-grid,.gal{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .sec-head{grid-template-columns:1fr;gap:14px}
  .t-step{grid-template-columns:1fr;gap:18px}
  .spread{grid-auto-rows:60px}
  .s-a{grid-column:1/-1;grid-row:span 5}
  .s-b,.s-c{grid-column:1/span 6;grid-row:span 3}
  .s-c{grid-column:7/-1}
  .s-d,.s-e,.s-f{grid-column:span 6;grid-row:span 3}
  .s-f{grid-column:1/-1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .masthead-row{grid-template-columns:1fr;text-align:center;gap:8px}
  .masthead-meta,.masthead-meta.right{text-align:center}
  .nav-list{gap:14px;justify-content:center;width:100%}
  .nav-inner{justify-content:center}
}
@media (max-width:560px){
  .offers,.why,.mat-grid,.gal{grid-template-columns:1fr}
  .mat{grid-template-columns:1fr}
}

