/* Prana — Architectural Editorial · Concept 2 shared stylesheet
   Brand: gold #B8923A · ink #1A1815 · bone #F4F1EA
   Type: Cormorant Garamond display + Inter body */

:root{
  --paper:#F4F1EA;
  --paper-2:#EAE5DB;
  --paper-3:#DDD7C8;
  --ink:#1A1815;
  --ink-soft:#2A2620;
  --mute:#6B655A;
  --mute-2:#8A8475;
  --accent:#B8923A;          /* Prana gold */
  --accent-soft:#D9B96E;
  --line:rgba(26,24,21,.12);
  --line-strong:rgba(26,24,21,.22);
  --maxw:1480px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-weight:300;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;transition:color .2s}
img{display:block;max-width:100%;height:auto}
button{font:inherit;cursor:pointer;border:none;background:none}

.serif{font-family:'Cormorant Garamond',serif;font-weight:300;letter-spacing:-.01em}
.label{font-family:'Inter',sans-serif;font-size:11px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 48px}
@media(max-width:640px){.container{padding:0 22px}}

/* NAV */
.site-nav{
  position:sticky;top:0;left:0;right:0;z-index:100;
  backdrop-filter:blur(20px);background:rgba(244,241,234,.86);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px 48px;max-width:var(--maxw);margin:0 auto;
}
@media(max-width:640px){.nav-inner{padding:14px 22px}}
.brand{
  display:flex;align-items:center;gap:14px;flex-shrink:0;
}
.brand-mark{
  width:30px;height:auto;color:var(--accent);flex-shrink:0;
}
.brand-text{
  display:flex;flex-direction:column;line-height:1;
}
.brand-text .wm{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:28px;letter-spacing:.04em;color:var(--ink);
}
.brand-text .tag{
  font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-top:3px;
}
@media(max-width:520px){.brand-text .tag{display:none}}

.nav-links{display:flex;gap:32px;font-size:13px;letter-spacing:.06em}
.nav-links a{color:var(--mute)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;
  color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px;
  flex-shrink:0;
}
@media(max-width:840px){
  .nav-links{display:none}
  .nav-cta{font-size:15px}
}

/* TYPE */
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;font-weight:300;letter-spacing:-.015em;line-height:1.05;color:var(--ink)}
.h-display{font-size:clamp(54px,9vw,140px);font-weight:300;line-height:.95;letter-spacing:-.025em}
.h-display em{font-style:italic}
.h-section{font-size:clamp(40px,5vw,72px);line-height:1.02;letter-spacing:-.02em}
.h-section em{font-style:italic}
.h-sub{font-size:clamp(28px,3vw,40px);line-height:1.1;letter-spacing:-.01em}

.lead{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:22px;line-height:1.4;color:var(--ink-soft);max-width:680px}
.prose{font-size:16px;line-height:1.75;color:var(--ink-soft);max-width:640px}
.prose + .prose{margin-top:16px}

/* LAYOUT PRIMITIVES */
section{padding:120px 0}
@media(max-width:640px){section{padding:72px 0}}
.twocol{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start}
@media(max-width:840px){.twocol{grid-template-columns:1fr;gap:32px}}
.eyebrow{display:flex;align-items:center;gap:18px;margin-bottom:30px}
.eyebrow span:first-child{height:1px;background:var(--ink);flex:0 0 60px}

/* BUTTONS / LINKS */
.btn-line{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;
  color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:4px;
  transition:gap .2s,color .2s;
}
.btn-line::after{content:"→";font-style:normal}
.btn-line:hover{gap:14px;color:var(--accent);border-color:var(--accent)}

.btn-filled{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--ink);color:var(--paper);
  padding:14px 24px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  border-radius:2px;font-weight:400;transition:background .2s,transform .2s;
}
.btn-filled:hover{background:var(--accent);transform:translateY(-1px)}

/* CARDS */
.card{
  background:var(--paper);border:1px solid var(--line);
  padding:36px;transition:transform .25s,border-color .25s;
}
.card:hover{transform:translateY(-2px);border-color:var(--line-strong)}

/* TAGS / PILLS */
.tag{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);
  border:1px solid var(--line);padding:6px 12px;border-radius:100px;display:inline-block;
}
.tag-accent{color:var(--accent);border-color:var(--accent)}

/* FOOTER */
.site-foot{padding:80px 0 30px;border-top:1px solid var(--line);margin-top:80px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px}
@media(max-width:840px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
.foot-col h4{font-family:'Inter',sans-serif;font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:18px}
.foot-col a{display:block;padding:5px 0;font-size:14px;color:var(--ink)}
.foot-col a:hover{color:var(--accent)}
.foot-brand p{color:var(--mute);font-size:14px;line-height:1.6;max-width:340px;margin-top:22px}
.foot-brand .brand{gap:18px;align-items:center}
.foot-brand .brand-mark{width:42px !important;flex-shrink:0}
.foot-brand .brand-text .wm{font-size:34px;line-height:1}
.foot-brand .brand-text .tag{font-size:10px;margin-top:6px;display:block !important}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;color:var(--mute);font-size:12px;flex-wrap:wrap;gap:16px}

/* PROJECT GRID — Editorial */
.pj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
@media(max-width:840px){.pj-grid{grid-template-columns:repeat(2,1fr);gap:18px}}
.pj{cursor:pointer;display:block;color:inherit}
.pj:hover .pj-img{transform:translateY(-4px)}
.pj:hover h3{color:var(--accent)}
.pj-img{
  aspect-ratio:4/3;background:var(--paper-2);position:relative;overflow:hidden;
  border:1px solid var(--line);transition:transform .35s ease;
}
.pj-img-inner{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:saturate(.9);
}
.pj-meta{margin-top:18px;display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.pj-meta h3{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;line-height:1.1;transition:color .2s}
.pj-meta .pj-y{font-size:13px;color:var(--mute);font-variant-numeric:tabular-nums;flex-shrink:0}
.pj-cat{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-top:6px}

/* QUOTE BAND */
.band-dark{background:var(--ink);color:var(--paper);padding:140px 0}
.band-dark h2{color:var(--paper)}
.band-dark blockquote{
  font-family:'Cormorant Garamond',serif;font-weight:300;font-style:italic;
  font-size:clamp(28px,3.6vw,52px);line-height:1.18;
}
.band-dark blockquote::before{content:"";display:block;width:60px;height:1px;background:var(--accent);margin-bottom:40px}
.band-dark cite{display:block;margin-top:36px;font-style:normal;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#B0A99B}

.band-paper{background:var(--paper-2)}

/* UTILS */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .9s ease,transform .9s ease}
.fade-in.visible{opacity:1;transform:none}
.sr-only{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}

/* =============================================================
   MOBILE RESPONSIVE OVERHAUL — added 2026-05-27
   Three-tier breakpoints: 840px tablet, 640px phone, 480px small phone
   ============================================================= */

/* --- NAV: keep links visible on all sizes (horizontal scroll on small) --- */
@media(max-width:840px){
  .nav-inner{gap:12px;padding:14px 22px}
  .nav-links{
    display:flex !important;
    gap:18px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    font-size:13px;
    flex:1 1 auto;
    min-width:0;
    justify-content:flex-end;
  }
  .nav-links::-webkit-scrollbar{display:none}
  .nav-cta{font-size:13px;padding:7px 14px;flex-shrink:0}
  .brand-text .wm{font-size:22px}
  .brand-mark{width:24px}
}
@media(max-width:520px){
  .nav-inner{padding:12px 18px;gap:8px}
  .nav-links{gap:14px;font-size:12px}
  .nav-cta{font-size:11px;padding:6px 10px}
  .brand-text .wm{font-size:20px}
  .brand-text .tag{display:none}
}

/* --- TYPOGRAPHY: smaller floors on mobile --- */
@media(max-width:640px){
  .h-display{font-size:clamp(36px,9.5vw,54px) !important;line-height:1.02 !important}
  .h-section{font-size:clamp(30px,7vw,42px) !important}
  .h-sub{font-size:clamp(22px,5.5vw,30px) !important}
  .lead{font-size:18px;line-height:1.45}
  .prose{font-size:15px}
}
@media(max-width:480px){
  .h-display{font-size:clamp(32px,9vw,44px) !important}
  .h-section{font-size:clamp(26px,7vw,36px) !important}
  .lead{font-size:17px}
  .prose{font-size:14px}
}

/* --- SECTIONS: tighter padding on small screens --- */
@media(max-width:640px){
  section{padding:64px 0 !important}
  .sec-head{margin-bottom:40px}
}
@media(max-width:480px){
  section{padding:48px 0 !important}
  .container{padding:0 18px}
}

/* --- PROJECT GRID: 1 column on phones (was still 2 cols) --- */
@media(max-width:640px){
  .pj-grid{
    grid-template-columns:1fr !important;
    gap:36px !important;
  }
  .pj{grid-column:1 / -1 !important;margin-top:0 !important}
  .pj-meta h3{font-size:22px}
  .pj-meta{flex-direction:column;align-items:flex-start;gap:8px}
}

/* --- HOMEPAGE HERO: shorter, smaller h1 on mobile --- */
@media(max-width:640px){
  .hero{padding:80px 0 40px !important;min-height:auto !important}
  .hero h1{font-size:clamp(38px,11vw,58px) !important;line-height:1 !important;letter-spacing:-.02em !important}
  .hero p{font-size:16px;line-height:1.55}
  .hero-grid{gap:32px !important}
  .hero-meta-row{flex-direction:column;align-items:flex-start;gap:4px}
}

/* --- PROJECT PAGE HEROES: shorter on mobile --- */
@media(max-width:640px){
  .project-hero{
    height:auto !important;
    min-height:520px !important;
    padding:100px 0 50px !important;
  }
  .project-hero h1{font-size:clamp(34px,10vw,52px) !important;line-height:1 !important}
  .project-hero .container{padding-bottom:30px !important}
  .project-hero .lead{font-size:16px !important;margin-top:14px !important}
  .project-hero .meta-row{margin-bottom:20px !important}
}
@media(max-width:480px){
  .project-hero{min-height:480px !important;padding:90px 0 40px !important}
  .project-hero h1{font-size:clamp(28px,9.5vw,42px) !important}
}

/* --- INFO TABLE: 1 column on phones (sooner than 640px) --- */
@media(max-width:760px){
  .info-table{grid-template-columns:1fr !important}
  .info-cell{padding:14px 18px !important}
  .info-cell .v{font-size:17px !important}
}

/* --- FEATURE IMAGE BAND: shorter on mobile --- */
@media(max-width:640px){
  .feature-image{height:auto !important;min-height:380px !important;padding:60px 0 30px}
  .feature-cap{padding:28px 22px !important}
  .feature-cap h3{font-size:24px !important;line-height:1.15 !important}
}

/* --- TWO-COL CONTENT: tighter gap, label-stacked --- */
@media(max-width:640px){
  .twocol{gap:28px !important}
  .eyebrow{gap:10px}
}
@media(max-width:480px){
  .eyebrow span:first-child{display:none}
}

/* --- SERVICES + SECTORS GRID: 1 col on smallest, 2 col on phones --- */
@media(max-width:760px){
  .services,
  section [style*="grid-template-columns:repeat(3,1fr)"],
  section [style*="grid-template-columns:repeat(2,1fr)"]{
    grid-template-columns:1fr !important;
  }
}

/* --- FOOTER: 2 columns on phones, 1 col on smallest --- */
@media(max-width:640px){
  .foot-grid{grid-template-columns:1fr 1fr !important;gap:28px !important}
  .foot-brand{grid-column:1 / -1}
  .foot-brand p{max-width:none}
}
@media(max-width:420px){
  .foot-grid{grid-template-columns:1fr !important}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:8px;font-size:11px}
}

/* --- BAND-DARK QUOTE: tighter on mobile --- */
@media(max-width:640px){
  .band-dark{padding:80px 0 !important}
  .band-dark blockquote{font-size:clamp(22px,5.5vw,32px) !important;line-height:1.25 !important}
  .band-dark blockquote::before{margin-bottom:24px}
  .band-dark cite{font-size:11px;margin-top:24px}
}

/* --- TAGS: smaller on mobile --- */
@media(max-width:640px){
  .tag{font-size:10px;padding:5px 10px;letter-spacing:.12em}
}

/* --- CONTAINER HORIZONTAL OVERFLOW SAFEGUARD --- */
body, html{overflow-x:hidden}
img, svg, video{max-width:100%}
