
:root{
  --ivory:#f7f3ec;--ivory-2:#efe9de;--charcoal:#1f1d1b;--charcoal-2:#2c2a27;
  --muted:#6b665e;--gold:#b8975a;--gold-2:#d4b67e;--line:#e3ddcf;--white:#fffdf8;
  --container:1200px;--radius:4px;
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:16px;line-height:1.65;color:var(--charcoal);background:var(--ivory);font-weight:400}
img{max-width:100%;height:auto;display:block}
a{color:var(--charcoal);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.2;color:var(--charcoal);letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.5rem}
h3{font-size:1.35rem}
p{color:var(--charcoal-2);margin-bottom:1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}
.section{padding:5rem 0}
.section-sm{padding:3rem 0}
.eyebrow{display:inline-block;font-family:var(--sans);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-weight:500}
.lede{font-size:1.1rem;color:var(--muted);max-width:640px}
.center{text-align:center}.center .lede{margin:0 auto}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.75rem;border-radius:var(--radius);font-weight:500;font-size:.92rem;letter-spacing:.04em;transition:all .25s ease;border:1px solid transparent;cursor:pointer;font-family:var(--sans)}
.btn-primary{background:var(--charcoal);color:var(--ivory)}
.btn-primary:hover{background:var(--gold);color:var(--white)}
.btn-outline{background:transparent;color:var(--charcoal);border-color:var(--charcoal)}
.btn-outline:hover{background:var(--charcoal);color:var(--ivory)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1ebe57;color:#fff}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,243,236,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.02em;color:var(--charcoal)}
.brand span{color:var(--gold)}
.nav-menu{display:flex;gap:2rem;align-items:center;list-style:none}
.nav-menu a{font-size:.9rem;font-weight:500;letter-spacing:.02em}
.nav-cta{display:inline-flex}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:36px;height:36px;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{display:block;height:2px;background:var(--charcoal);width:24px}

/* Hero */
.hero{padding:5rem 0 6rem;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:center}
.hero h1{margin-bottom:1.25rem}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:1.15rem;color:var(--muted);margin-bottom:2rem;max-width:520px}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-svg{width:100%;height:auto;max-height:520px}

/* Service cards */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;transition:all .3s ease;display:flex;flex-direction:column;height:100%}
.card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 12px 40px -20px rgba(31,29,27,.2)}
.card-icon{width:44px;height:44px;color:var(--gold);margin-bottom:1.25rem}
.card h3{margin-bottom:.6rem}
.card p{font-size:.95rem;color:var(--muted);flex:1}
.card-link{margin-top:1.25rem;font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);display:inline-flex;align-items:center;gap:.4rem}
.card-link:hover{color:var(--gold)}

/* Process */
.process{background:var(--ivory-2);padding:5rem 0}
.process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.25rem;margin-top:2.5rem;counter-reset:step}
.step{padding:1.5rem;border-top:2px solid var(--gold);background:transparent}
.step-num{font-family:var(--serif);font-size:2.2rem;color:var(--gold);font-style:italic}
.step h3{font-size:1.1rem;margin:.4rem 0 .5rem}
.step p{font-size:.9rem;color:var(--muted)}

/* Projects */
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.project{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/5}
.project img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.project:hover img{transform:scale(1.05)}
.project-meta{position:absolute;left:0;right:0;bottom:0;padding:1.5rem;background:linear-gradient(to top,rgba(31,29,27,.85),transparent);color:var(--ivory)}
.project-meta h3{color:var(--ivory);font-size:1.2rem;margin-bottom:.2rem}
.project-meta span{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-2)}

/* Why */
.why{background:var(--charcoal);color:var(--ivory);padding:5rem 0}
.why h2{color:var(--ivory)}
.why .eyebrow{color:var(--gold-2)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:2.5rem}
.why-item{padding:1.5rem 0;border-top:1px solid rgba(255,253,248,.15)}
.why-item h3{color:var(--ivory);font-size:1.15rem;margin-bottom:.5rem}
.why-item p{color:rgba(247,243,236,.7);font-size:.92rem}
.why-num{font-family:var(--serif);font-style:italic;color:var(--gold-2);font-size:1rem;margin-bottom:.5rem;display:block}

/* Articles */
.article-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:all .3s ease}
.article-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.article-thumb{aspect-ratio:16/10;background:var(--ivory-2);overflow:hidden}
.article-thumb img{width:100%;height:100%;object-fit:cover}
.article-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.article-body .eyebrow{margin-bottom:.5rem}
.article-body h3{font-size:1.2rem;margin-bottom:.5rem;line-height:1.3}
.article-body p{font-size:.92rem;color:var(--muted);flex:1}
.article-body .card-link{margin-top:1rem}

/* CTA */
.cta-section{background:var(--ivory-2);padding:5rem 0;text-align:center}
.cta-section h2{margin-bottom:1rem}
.cta-section p{max-width:560px;margin:0 auto 2rem;color:var(--muted);font-size:1.05rem}

/* Footer */
.site-footer{background:var(--charcoal);color:rgba(247,243,236,.8);padding:4rem 0 1.5rem;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.footer-brand{font-family:var(--serif);font-size:1.5rem;color:var(--ivory);margin-bottom:.75rem;font-weight:600}
.footer-brand span{color:var(--gold)}
.site-footer h4{color:var(--ivory);font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;font-family:var(--sans);font-weight:600}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:.5rem}
.site-footer a{color:rgba(247,243,236,.7)}
.site-footer a:hover{color:var(--gold-2)}
.footer-bottom{border-top:1px solid rgba(255,253,248,.1);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:rgba(247,243,236,.5)}

/* Page hero (inner pages) */
.page-hero{padding:4rem 0 3rem;background:var(--ivory-2);border-bottom:1px solid var(--line)}
.page-hero h1{margin-bottom:.75rem}
.page-hero p{font-size:1.1rem;color:var(--muted);max-width:680px}
.breadcrumbs{font-size:.82rem;letter-spacing:.05em;color:var(--muted);margin-bottom:1.25rem}
.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--gold)}
.breadcrumbs span{color:var(--charcoal)}

/* Content */
.content{max-width:780px;margin:0 auto}
.content h2{margin:2.5rem 0 1rem;font-size:1.9rem}
.content h3{margin:1.75rem 0 .75rem;font-size:1.35rem}
.content p,.content ul,.content ol{margin-bottom:1.1rem;color:var(--charcoal-2)}
.content ul,.content ol{padding-left:1.4rem}
.content li{margin-bottom:.4rem}
.content blockquote{border-left:3px solid var(--gold);padding:.5rem 0 .5rem 1.25rem;font-family:var(--serif);font-size:1.25rem;font-style:italic;color:var(--charcoal);margin:1.5rem 0}

/* Benefits / FAQ */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.benefit{padding:1.75rem;background:var(--white);border:1px solid var(--line);border-radius:var(--radius)}
.benefit-icon{width:36px;height:36px;color:var(--gold);margin-bottom:.75rem}
.benefit h3{font-size:1.1rem;margin-bottom:.4rem}
.benefit p{font-size:.92rem;color:var(--muted);margin:0}

.faq{max-width:780px;margin:2rem auto 0}
.faq details{border-bottom:1px solid var(--line);padding:1.25rem 0}
.faq summary{font-family:var(--serif);font-size:1.2rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--charcoal)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.5rem;color:var(--gold);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:.75rem;color:var(--muted)}

/* Mobile bottom nav */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--line);padding:.5rem 0 calc(.5rem + env(safe-area-inset-bottom));z-index:99}
.mobile-nav-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem;font-size:.7rem;color:var(--muted);font-weight:500}
.mobile-nav a.wa{color:#25D366}
.mobile-nav svg{width:22px;height:22px}

/* Forms / contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info p{color:var(--muted)}
.contact-info .info-item{padding:1rem 0;border-bottom:1px solid var(--line)}
.contact-info .info-item h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem;font-weight:600}
.contact-info .info-item p{margin:0;color:var(--charcoal)}
.locations{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.loc-chip{padding:.35rem .75rem;background:var(--ivory-2);border-radius:999px;font-size:.8rem;color:var(--charcoal-2)}

/* Article list */
.article-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}

/* Single article */
.article-hero{padding:3rem 0 2rem}
.article-hero h1{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem;max-width:820px}
.article-meta{font-size:.85rem;color:var(--muted);letter-spacing:.05em}
.article-cover{aspect-ratio:16/8;overflow:hidden;border-radius:var(--radius);margin-bottom:2.5rem;background:var(--ivory-2)}
.article-cover img{width:100%;height:100%;object-fit:cover}

/* Responsive */
@media (max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-svg{max-height:380px}
}
@media (max-width:768px){
  .section{padding:3.5rem 0}
  .nav-menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--ivory);flex-direction:column;align-items:stretch;padding:1rem 1.25rem;border-bottom:1px solid var(--line);gap:0}
  .nav-menu.open{display:flex}
  .nav-menu li{padding:.75rem 0;border-bottom:1px solid var(--line)}
  .nav-menu li:last-child{border:0}
  .nav-cta{display:none}
  .nav-toggle{display:flex}
  .grid-3,.projects-grid,.article-list,.benefits{grid-template-columns:1fr}
  .grid-2,.contact-grid{grid-template-columns:1fr}
  .mobile-nav{display:block}
  body{padding-bottom:64px}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .hero{padding:3rem 0 4rem}
}
@media (max-width:480px){
  .grid-4,.process-grid,.why-grid{grid-template-columns:1fr}
}

/* ============================================
   HOMEPAGE EDITORIAL REDESIGN
============================================ */
.container{max-width:1320px}

/* Hero — editorial display */
.hero{padding:3.5rem 0 0;overflow:hidden}
.hero h1{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:-.025em;font-size:clamp(3rem,8.5vw,7.5rem);margin:0 0 0 -.05em}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:500}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:2.25rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.hero-meta b{font-weight:500;color:var(--charcoal)}

.hero-plates{display:grid;grid-template-columns:1.55fr 1fr;gap:1.25rem;margin-top:3.25rem}
.plate{position:relative;overflow:hidden;border-radius:2px;background:var(--ivory-2)}
.plate img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s ease}
.plate:hover img{transform:scale(1.03)}
.plate-main{aspect-ratio:5/6}
.plate-main figcaption{position:absolute;left:1.5rem;bottom:1.25rem;right:1.5rem;display:flex;justify-content:space-between;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ivory);text-shadow:0 1px 8px rgba(0,0,0,.4)}
.plate-side{display:grid;grid-template-rows:1fr auto;gap:1.25rem}
.plate-side .plate{aspect-ratio:1/1}
.hero-statement{display:flex;flex-direction:column;justify-content:flex-end}
.hero-statement .hero-sub{font-family:var(--serif);font-style:italic;font-size:1.35rem;line-height:1.4;color:var(--charcoal-2);margin-bottom:1.5rem;font-weight:400}
.hero-cta{display:flex;gap:.6rem;flex-wrap:wrap}

.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin:4.5rem 0 0;padding:2.25rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero-stats div{display:flex;flex-direction:column;gap:.35rem}
.hero-stats b{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,4vw,3rem);color:var(--charcoal);line-height:1;letter-spacing:-.02em}
.hero-stats span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* Marquee */
.marquee{margin-top:2.25rem;padding:1.1rem 0;background:var(--charcoal);color:var(--ivory);overflow:hidden;border-top:1px solid var(--charcoal-2)}
.marquee-track{display:inline-flex;gap:2rem;white-space:nowrap;animation:marquee 38s linear infinite;font-family:var(--serif);font-style:italic;font-size:1.4rem;letter-spacing:.01em}
.marquee-track span:nth-child(even){color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Section heads */
.section-head{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:end;margin-bottom:3rem}
.section-head .eyebrow{display:block;margin-bottom:1rem}
.section-head h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;letter-spacing:-.02em;font-weight:400;max-width:14ch}
.section-head .lede{justify-self:end;max-width:380px;text-align:left}
@media (max-width:768px){.section-head{grid-template-columns:1fr;gap:1rem}.section-head .lede{justify-self:start}}

/* Service rows (editorial list) */
.section-services{padding:7rem 0}
.service-rows{border-top:1px solid var(--line)}
.service-row{display:grid;grid-template-columns:80px 1fr auto;gap:2.5rem;align-items:center;padding:2.5rem 0;border-bottom:1px solid var(--line);transition:padding .3s ease,background .3s ease;color:var(--charcoal)}
.service-row:hover{padding-left:1.5rem;background:linear-gradient(90deg,var(--ivory-2),transparent 60%)}
.service-row .srv-num{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold);letter-spacing:.05em}
.service-row h3{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:400;letter-spacing:-.01em;margin-bottom:.4rem;line-height:1.1}
.service-row p{font-size:.98rem;color:var(--muted);max-width:60ch;margin:0}
.service-row .srv-go{font-family:var(--serif);font-size:2rem;color:var(--charcoal);transition:transform .3s ease,color .3s ease}
.service-row:hover .srv-go{transform:translateX(8px);color:var(--gold)}
@media (max-width:768px){.service-row{grid-template-columns:50px 1fr;gap:1rem;padding:1.75rem 0}.service-row .srv-go{display:none}.service-row:hover{padding-left:.5rem}}

/* Manifesto */
.manifesto{padding:7rem 0;background:var(--ivory-2)}
.manifesto-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center}
.manifesto-img{aspect-ratio:4/5;overflow:hidden;border-radius:2px}
.manifesto-img img{width:100%;height:100%;object-fit:cover}
.manifesto-quote{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.3;color:var(--charcoal);margin:1.5rem 0 1.75rem;font-weight:400}
.manifesto-quote em{font-style:italic;color:var(--charcoal)}
.manifesto-sign{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
@media (max-width:768px){.manifesto-grid{grid-template-columns:1fr;gap:2rem}.manifesto{padding:4rem 0}}

/* Editorial projects grid */
.projects-grid.editorial{grid-template-columns:1.3fr 1fr 1fr;gap:1.25rem}
.projects-grid.editorial .project{aspect-ratio:3/4}
.projects-grid.editorial .project.tall{aspect-ratio:3/4.6;grid-row:span 1}
.project-meta{padding:1.75rem;background:linear-gradient(to top,rgba(31,29,27,.92),rgba(31,29,27,.1) 70%,transparent)}
.project-meta span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin-bottom:.35rem;display:block}
.project-meta h3{font-family:var(--serif);font-weight:500;font-size:1.5rem;color:var(--ivory)}
@media (max-width:900px){.projects-grid.editorial{grid-template-columns:1fr 1fr}.projects-grid.editorial .project,.projects-grid.editorial .project.tall{aspect-ratio:3/4}}
@media (max-width:560px){.projects-grid.editorial{grid-template-columns:1fr}}

/* Process tweaks */
.process{padding:7rem 0}
.process-grid{margin-top:1rem}
.step{padding:2rem 1.25rem 1.5rem 0;border-top:1px solid var(--charcoal);background:transparent}
.step-num{font-family:var(--serif);font-style:italic;font-size:2.4rem;color:var(--gold);line-height:1;margin-bottom:.75rem}

/* Why dark */
.why{padding:7rem 0}
.why h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:400;letter-spacing:-.02em;line-height:1.05;margin-top:1rem}

/* Final CTA */
.cta-final{background:var(--charcoal);color:var(--ivory);padding:8rem 0;position:relative;overflow:hidden}
.cta-final::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(184,151,90,.18),transparent 60%)}
.cta-final-inner{position:relative;text-align:center;max-width:780px;margin:0 auto}
.cta-final .eyebrow{color:var(--gold-2)}
.cta-final h2{color:var(--ivory);font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:400;line-height:1.05;letter-spacing:-.02em;margin:1rem 0 1.5rem}
.cta-final h2 em{font-style:italic;color:var(--gold-2);font-weight:500}
.cta-final p{color:rgba(247,243,236,.75);font-size:1.05rem;max-width:540px;margin:0 auto 2.25rem}
.btn-lg{padding:1.15rem 2.25rem;font-size:1rem}

/* Hero responsive */
@media (max-width:900px){
  .hero-plates{grid-template-columns:1fr;gap:1rem}
  .plate-side{grid-template-columns:1fr;grid-template-rows:auto auto}
  .plate-main{aspect-ratio:4/5}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
  .hero{padding:2rem 0 0}
  .marquee-track{font-size:1.1rem}
}
