/* ============ JUST2 — editorial image-led ============ */
:root{
  --paper:#E8E2D3;
  --paper-2:#DED7C4;
  --ink:#1C1B17;
  --ink-soft:#3B3A34;
  --mute:#6E6B5E;
  --line:rgba(28,27,23,.14);
  --accent:#C7471A;       /* terracotta */
  --butter:#F2E9B8;       /* soft butter pill */
  --white:#F7F3E7;
  --display:"Fraunces",serif;
  --sans:"Instrument Sans",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

::selection{background:var(--accent);color:var(--white)}

/* ---------- Top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  max-width:1600px;margin:0 auto;
  display:flex;align-items:center;gap:40px;
  padding:22px 48px;
}
.wordmark{
  font-family:var(--display);
  font-weight:400;font-size:26px;letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:3px;
  font-variation-settings:"opsz" 48,"SOFT" 100;
}
.wordmark .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);display:inline-block;margin:0 1px 3px 2px;
}
.wordmark em{font-style:italic;color:var(--accent);font-weight:400}

.nav{display:flex;gap:28px;font-size:14.5px;color:var(--ink-soft)}
.nav a{position:relative;padding:4px 0}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{content:"";position:absolute;inset:auto 0 -2px;height:1px;background:var(--ink)}

.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;border:1px solid var(--line);border-radius:999px;
  font-size:13.5px;color:var(--ink);
  transition:background .15s,border-color .15s;
}
.pill:hover{background:rgba(0,0,0,.04)}
.pill.ghost{border-color:var(--ink)}
.pill.cta{background:var(--butter);border-color:var(--butter);padding:11px 22px;font-weight:500}
.pill.cta:hover{background:#EADFA0}
.pill .arrow{font-family:var(--mono);font-size:12px}

/* ---------- Hero ---------- */
.hero{
  padding:72px 48px 0;
  max-width:1600px;margin:0 auto;
}
.hero-head{
  display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:80px;align-items:end;
  padding-bottom:72px;
}
.hero h1{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(56px,8vw,132px);
  line-height:.98;letter-spacing:-.03em;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.hero h1 em{font-style:italic;font-weight:300;color:var(--accent)}
.hero h1 .amp{font-style:italic;font-weight:300;font-size:.82em;display:inline-block;transform:translateY(.06em)}

.hero-lede{
  font-size:17px;line-height:1.45;color:var(--ink-soft);
  max-width:380px;justify-self:end;
  padding-bottom:14px;
}
.hero-lede strong{color:var(--ink);font-weight:500}

.hero-image{
  position:relative;
  aspect-ratio:16/9;
  border-radius:2px;
  overflow:hidden;
  background:#222;
}
.hero-image img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95) contrast(1.02);
}
.hero-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.35) 100%);
}

.hero-tag{
  position:absolute;left:28px;bottom:24px;color:var(--white);
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  display:flex;gap:18px;align-items:center;
}
.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}

.hero-scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  width:42px;height:42px;border-radius:50%;
  background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-size:16px;
  border:1px solid rgba(255,255,255,.2);
}

/* ---------- Meta strip ---------- */
.meta-strip{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
  padding:28px 0;
  border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);
}
.meta-strip .cell strong{display:block;font-family:var(--sans);font-weight:500;font-size:15.5px;color:var(--ink);text-transform:none;letter-spacing:0;margin-top:6px}
.meta-strip .cell.c1{grid-column:span 3}
.meta-strip .cell.c2{grid-column:span 3}
.meta-strip .cell.c3{grid-column:span 3}
.meta-strip .cell.c4{grid-column:span 3;text-align:right}

/* ---------- Section framing ---------- */
section{padding:120px 48px;max-width:1600px;margin:0 auto}
.section-head{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);
  gap:60px;align-items:start;margin-bottom:72px;
}
.section-label{
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);
  display:flex;align-items:center;gap:12px;
}
.section-label::before{content:"";width:28px;height:1px;background:var(--ink)}
.section-title{
  font-family:var(--display);font-weight:300;
  font-size:clamp(40px,5.2vw,76px);line-height:1;letter-spacing:-.025em;
  font-variation-settings:"opsz" 144;
}
.section-title em{font-style:italic;color:var(--accent);font-weight:300}

/* ---------- Services ---------- */
.services{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.service{
  display:flex;flex-direction:column;gap:20px;
}
.service .frame{
  aspect-ratio:4/5;overflow:hidden;background:#333;
  border-radius:2px;position:relative;
}
.service .frame img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.service:hover .frame img{transform:scale(1.04)}
.service .num{
  font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.1em;
}
.service h3{
  font-family:var(--display);font-weight:400;
  font-size:30px;line-height:1.1;letter-spacing:-.01em;
}
.service p{color:var(--ink-soft);line-height:1.5;font-size:15px;max-width:36ch}
.service .more{
  margin-top:4px;font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;
  display:inline-flex;align-items:center;gap:10px;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:4px;align-self:flex-start;
}
.service .more:hover{color:var(--accent);border-color:var(--accent)}

.service .tag{
  position:absolute;top:16px;left:16px;color:var(--white);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(0,0,0,.28);backdrop-filter:blur(6px);
  padding:6px 10px;border-radius:999px;
}

/* ---------- Featured project (big split) ---------- */
.featured{
  background:var(--ink);color:var(--paper);
  padding:120px 48px;margin:0;max-width:none;
}
.featured-inner{max-width:1600px;margin:0 auto}
.featured .section-label{color:rgba(255,255,255,.6)}
.featured .section-label::before{background:rgba(255,255,255,.6)}
.featured .section-title{color:var(--paper)}
.featured .section-title em{color:var(--butter)}

.featured-body{
  display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);
  gap:56px;align-items:start;
}
.featured-image{
  aspect-ratio:4/3;overflow:hidden;border-radius:2px;background:#000;
}
.featured-image img{width:100%;height:100%;object-fit:cover}
.featured-meta{
  display:flex;flex-direction:column;gap:28px;padding-top:10px;
}
.featured-meta .row{display:grid;grid-template-columns:110px 1fr;gap:16px;padding:16px 0;border-top:1px solid rgba(255,255,255,.16)}
.featured-meta .row:last-of-type{border-bottom:1px solid rgba(255,255,255,.16)}
.featured-meta .row .k{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.6)}
.featured-meta .row .v{font-size:15.5px;line-height:1.4}
.featured-meta .row .v em{font-style:italic;color:var(--butter);font-family:var(--display);font-weight:400}

.featured-q{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(22px,2vw,30px);line-height:1.3;margin-top:8px;
  color:rgba(255,255,255,.9);
}

/* ---------- Gallery band ---------- */
.band{
  padding:0;max-width:none;margin:0;
  background:var(--paper);
  overflow:hidden;
}
.band-inner{
  display:grid;grid-template-columns:repeat(4,1fr);gap:2px;
}
.band-inner .cell{
  aspect-ratio:1/1;overflow:hidden;position:relative;background:#222;
}
.band-inner .cell img{width:100%;height:100%;object-fit:cover}
.band-inner .cell .cap{
  position:absolute;left:14px;bottom:12px;color:var(--white);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  text-shadow:0 1px 3px rgba(0,0,0,.5);
}

/* ---------- Process ---------- */
.process{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:80px;
  align-items:start;
}
.process-steps{display:flex;flex-direction:column}
.process-steps .step{
  display:grid;grid-template-columns:60px 1fr auto;gap:28px;
  padding:28px 0;border-top:1px solid var(--line);
  align-items:baseline;
}
.process-steps .step:last-child{border-bottom:1px solid var(--line)}
.process-steps .step .n{font-family:var(--mono);font-size:13px;color:var(--mute);letter-spacing:.1em}
.process-steps .step h4{font-family:var(--display);font-weight:400;font-size:30px;letter-spacing:-.01em}
.process-steps .step p{color:var(--ink-soft);font-size:15px;line-height:1.5;margin-top:8px;max-width:44ch}
.process-steps .step .dur{font-family:var(--mono);font-size:12px;color:var(--mute);text-transform:uppercase;letter-spacing:.08em;align-self:start;padding-top:4px}

.process-image{
  aspect-ratio:3/4;overflow:hidden;border-radius:2px;position:sticky;top:100px;background:#333;
}
.process-image img{width:100%;height:100%;object-fit:cover}

/* ---------- Quote block ---------- */
.quote{
  padding:140px 48px;max-width:1600px;margin:0 auto;
}
.quote-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:60px;align-items:start}
.quote-grid .who{display:flex;flex-direction:column;gap:16px}
.quote-grid .who .avatar{
  width:72px;height:72px;border-radius:50%;overflow:hidden;background:#333;
}
.quote-grid .who .avatar img{width:100%;height:100%;object-fit:cover}
.quote-grid .who .name{font-weight:500}
.quote-grid .who .meta{font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.08em;text-transform:uppercase}

.quote-body{
  font-family:var(--display);font-weight:300;
  font-size:clamp(32px,3.5vw,52px);line-height:1.12;letter-spacing:-.02em;
  font-variation-settings:"opsz" 144;
}
.quote-body .mark{font-style:italic;color:var(--accent);font-family:var(--display);font-weight:300;margin-right:.1em}
.quote-body em{font-style:italic;color:var(--accent);font-weight:300}

/* ---------- Estimate block (calculator feeling) ---------- */
.estimate{
  background:var(--paper-2);
  border-radius:4px;
  padding:64px;
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:64px;
  align-items:center;
}
.estimate h3{font-family:var(--display);font-weight:300;font-size:clamp(34px,3.5vw,56px);line-height:1;letter-spacing:-.02em}
.estimate h3 em{font-style:italic;color:var(--accent);font-weight:300}
.estimate .sub{color:var(--ink-soft);margin-top:18px;max-width:40ch;line-height:1.5}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field.wide{grid-column:span 2}
.form-field label{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute)}
.form-field .control{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--line);background:var(--paper);
  border-radius:999px;padding:12px 18px;
  font-size:15px;
}
.form-field .control input{
  flex:1;border:0;outline:0;background:transparent;font:inherit;color:var(--ink);
}
.form-field .control input::placeholder{color:var(--mute)}
.form-field .control .unit{font-family:var(--mono);font-size:12px;color:var(--mute)}

.chip-row{display:flex;flex-wrap:wrap;gap:8px;grid-column:span 2}
.chip{
  padding:9px 16px;border-radius:999px;border:1px solid var(--line);
  font-size:13.5px;cursor:pointer;background:transparent;transition:all .15s;
}
.chip:hover{border-color:var(--ink)}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.estimate-cta{
  grid-column:span 2;display:flex;align-items:center;justify-content:space-between;gap:20px;
  margin-top:8px;
}
.estimate-cta .range{font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.estimate-cta .range strong{font-family:var(--display);font-size:28px;font-weight:400;color:var(--ink);display:block;margin-top:4px;letter-spacing:-.01em}
.estimate-cta button{
  background:var(--butter);padding:14px 28px;border-radius:999px;font-weight:500;
  display:inline-flex;align-items:center;gap:12px;
}
.estimate-cta button:hover{background:#EADFA0}

/* ---------- Facts strip ---------- */
.facts{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.fact{
  padding:56px 40px;border-right:1px solid var(--line);
}
.fact:last-child{border-right:0}
.fact .n{
  font-family:var(--display);font-weight:300;font-size:72px;line-height:.95;letter-spacing:-.03em;
  font-variation-settings:"opsz" 144;
}
.fact .n em{font-style:italic;color:var(--accent);font-weight:300}
.fact .t{margin-top:16px;color:var(--ink-soft);font-size:14.5px;line-height:1.45;max-width:28ch}

/* ---------- CTA band ---------- */
.cta-band{
  padding:140px 48px;max-width:1600px;margin:0 auto;text-align:center;
}
.cta-band h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(60px,9vw,160px);line-height:.9;letter-spacing:-.03em;
  font-variation-settings:"opsz" 144;
}
.cta-band h2 em{font-style:italic;color:var(--accent);font-weight:300}
.cta-band .line{
  margin:28px auto 0;max-width:46ch;color:var(--ink-soft);font-size:17px;line-height:1.5;
}
.cta-band .buttons{margin-top:48px;display:inline-flex;gap:14px}

/* ---------- Footer ---------- */
footer{
  background:var(--ink);color:var(--paper);padding:80px 48px 36px;
}
.foot-inner{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr 1fr 1.2fr;gap:60px}
.foot-inner h5{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:18px}
.foot-inner ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14.5px;color:rgba(255,255,255,.85)}
.foot-inner ul a:hover{color:var(--butter)}
.foot-wordmark{font-family:var(--display);font-weight:300;font-size:36px;letter-spacing:-.02em;margin-bottom:20px;display:flex;align-items:baseline;gap:3px}
.foot-wordmark em{font-style:italic;color:var(--butter);font-weight:300}
.foot-wordmark .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin:0 2px 5px 2px}
.foot-sub{color:rgba(255,255,255,.7);font-size:14px;line-height:1.5;max-width:32ch}

.foot-bottom{max-width:1600px;margin:60px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5)}

/* ---------- Ticker ---------- */
.ticker{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;overflow:hidden;
}
.ticker-track{
  display:flex;gap:48px;animation:slide 60s linear infinite;
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(36px,5vw,64px);letter-spacing:-.02em;color:var(--ink);
  white-space:nowrap;
}
.ticker-track .sep{color:var(--accent);font-style:normal;font-family:var(--mono);font-size:.4em;align-self:center}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- Tweaks panel ---------- */
.tweaks{
  position:fixed;right:20px;bottom:20px;z-index:100;
  background:var(--ink);color:var(--paper);
  border-radius:14px;padding:20px;width:280px;
  box-shadow:0 20px 60px rgba(0,0,0,.25);
  font-size:13px;
  display:none;
}
.tweaks.open{display:block}
.tweaks h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:rgba(255,255,255,.5);margin-bottom:14px}
.tweak-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.tweak-row label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.swatches{display:flex;gap:8px;flex-wrap:wrap}
.swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent}
.swatch.on{border-color:var(--butter)}
.font-picks{display:flex;gap:6px;flex-wrap:wrap}
.font-picks button{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.2);font-size:11.5px}
.font-picks button.on{background:var(--butter);color:var(--ink);border-color:var(--butter)}

/* ---------- Grid overlay ---------- */
.grid-over{
  position:fixed;inset:0;pointer-events:none;z-index:90;
  max-width:1600px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;
}
.grid-over span{background:rgba(199,71,26,.08);height:100%}

/* ---------- Responsive ---------- */
@media (max-width:1100px){
  .hero-head{grid-template-columns:1fr;gap:32px}
  .hero-lede{justify-self:start;padding-bottom:0}
  .services{grid-template-columns:1fr 1fr}
  .featured-body{grid-template-columns:1fr;gap:32px}
  .process{grid-template-columns:1fr;gap:32px}
  .process-image{position:static;aspect-ratio:4/3}
  .estimate{grid-template-columns:1fr;padding:40px;gap:32px}
  .facts{grid-template-columns:1fr 1fr}
  .fact{border-bottom:1px solid var(--line)}
  .fact:nth-child(2){border-right:0}
  .band-inner{grid-template-columns:1fr 1fr}
  .foot-inner{grid-template-columns:1fr 1fr;gap:40px}
  .meta-strip .cell{grid-column:span 6 !important}
  .meta-strip .cell.c4{text-align:left}
}
@media (max-width:680px){
  .topbar-inner{padding:16px 20px;gap:16px}
  .nav,.topbar-right .pill.ghost{display:none}
  .hero{padding:32px 20px 0}
  section{padding:80px 20px}
  .services{grid-template-columns:1fr}
  .quote{padding:80px 20px}
  .featured{padding:80px 20px}
  .cta-band{padding:80px 20px}
  footer{padding:60px 20px 24px}
  .foot-inner{grid-template-columns:1fr}
}
