
:root {
  --bg: #fbf7f0;
  --panel: #ffffff;
  --ink: #1f2a24;
  --muted: #68736b;
  --brand: #b86b45;
  --brand-dark: #7e432a;
  --sage: #dfe8dc;
  --cream: #f4eadb;
  --stone: #d8d1c5;
  --shadow: 0 24px 70px rgba(42, 35, 28, 0.12);
  --radius: 28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}
a{color:inherit;text-decoration:none}
.site-header{position:sticky;top:0;z-index:20;backdrop-filter:blur(18px);background:rgba(251,247,240,.84);border-bottom:1px solid rgba(31,42,36,.08)}
.nav{max-width:1180px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:inline-flex;align-items:center;gap:12px;font-weight:850;letter-spacing:-.02em}
.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:15px;background:var(--ink);color:#fff;font-size:13px}
.nav-links{display:flex;align-items:center;gap:20px;color:var(--muted);font-weight:700}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{padding:10px 16px;border-radius:999px;background:var(--ink);color:#fff!important}
.nav-toggle{display:none;border:0;background:transparent;font-size:28px}
main{min-height:70vh}
.hero{max-width:1180px;margin:0 auto;padding:86px 24px 54px;display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.eyebrow{color:var(--brand);text-transform:uppercase;letter-spacing:.14em;font-size:13px;font-weight:850;margin:0 0 14px}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(44px,7vw,76px);line-height:.94;letter-spacing:-.065em;margin-bottom:24px}
h2{font-size:clamp(32px,5vw,52px);line-height:1;letter-spacing:-.045em;margin-bottom:18px}
h3{font-size:21px;line-height:1.2;letter-spacing:-.02em}
.hero-text{max-width:650px;color:var(--muted);font-size:20px;margin-bottom:30px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 22px;border-radius:999px;font-weight:850;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--brand);color:white;box-shadow:0 16px 32px rgba(184,107,69,.28)}
.btn-primary:hover{background:var(--brand-dark)}
.btn-secondary{background:white;border-color:rgba(31,42,36,.12)}
.full{width:100%}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:640px}
.hero-stats div{padding:18px;background:rgba(255,255,255,.72);border:1px solid rgba(31,42,36,.08);border-radius:22px}
.hero-stats strong{display:block;font-size:26px;letter-spacing:-.04em}
.hero-stats span{display:block;color:var(--muted);font-size:13px;line-height:1.3}
.hero-card{position:relative;min-height:560px;border-radius:42px;background:linear-gradient(145deg,#eee1cf,#cbb89d);box-shadow:var(--shadow);overflow:hidden;padding:38px}
.image-placeholder{min-height:240px;border-radius:28px;background:linear-gradient(135deg,#ead8c6,#fff7ea);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;color:rgba(31,42,36,.74);border:1px solid rgba(31,42,36,.08)}
.image-placeholder span{font-weight:850;font-size:20px}
.image-placeholder small{color:var(--muted);margin-top:6px}
.image-hero{position:absolute;inset:42px;width:calc(100% - 84px);height:calc(100% - 84px);border-radius:34px;object-fit:cover;display:block}
.warm{background:linear-gradient(135deg,#d8a678,#fff1dd)}
.dark{background:linear-gradient(135deg,#25302a,#b9aa96);color:#fff}
.dark small{color:rgba(255,255,255,.72)}
.light{background:linear-gradient(135deg,#ffffff,#d9e4d7)}
.contact-image{margin-top:24px;min-height:230px;width:100%;object-fit:cover;border-radius:28px;display:block}
.floating-note{position:absolute;right:26px;bottom:28px;max-width:250px;padding:18px 20px;background:rgba(255,255,255,.9);border-radius:24px;box-shadow:0 18px 40px rgba(31,42,36,.14)}
.floating-note span{display:block;color:var(--muted);font-size:13px}
.floating-note strong{display:block;margin-top:4px;font-size:18px}
.logos{max-width:1180px;margin:0 auto;padding:22px 24px 64px;display:flex;gap:24px;flex-wrap:wrap;color:var(--muted);align-items:center}
.logos strong{color:var(--ink)}
.section{max-width:1180px;margin:0 auto;padding:78px 24px}
.section-muted{max-width:none;background:var(--sage)}
.section-inner{max-width:1180px;margin:0 auto}
.section-heading{max-width:760px;margin-bottom:36px}
.section-heading p:not(.eyebrow),.page-hero p{color:var(--muted);font-size:18px}
.service-grid,.project-grid,.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-grid{grid-template-columns:repeat(4,1fr)}
.card{padding:28px;border-radius:var(--radius);background:var(--panel);border:1px solid rgba(31,42,36,.08);box-shadow:0 18px 60px rgba(31,42,36,.06)}
.card p,.project-card p,.step p,.feature-panel p,.service-detail p,.case-study p,.process-step p{color:var(--muted)}
.card a,.project-card a{font-weight:850;color:var(--brand-dark)}
.icon{display:grid;place-items:center;width:44px;height:44px;margin-bottom:18px;border-radius:16px;background:var(--cream);color:var(--brand-dark);font-weight:900}
.project-card{overflow:hidden;border-radius:32px;background:white;box-shadow:0 18px 60px rgba(31,42,36,.08)}
.project-card img{border-radius:0;height:240px;width:100%;object-fit:cover;display:block}
.project-card div:last-child{padding:24px}
.page-hero{max-width:980px;margin:0 auto;padding:86px 24px 44px}
.page-hero h1{font-size:clamp(42px,6vw,68px)}
.two-col{display:grid;grid-template-columns:1fr .8fr;gap:46px;align-items:start}
.feature-panel{background:white;border-radius:32px;padding:30px;box-shadow:var(--shadow)}
.check-list,.service-detail ul,.case-study ul{padding-left:0;list-style:none}
.check-list li,.service-detail li,.case-study li{padding:8px 0 8px 28px;position:relative;color:var(--muted)}
.check-list li:before,.service-detail li:before,.case-study li:before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:900}
.service-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.service-detail{background:white;border-radius:34px;overflow:hidden;border:1px solid rgba(31,42,36,.08)}
.service-detail img{width:100%;height:200px;object-fit:cover;display:block}
.service-detail>span,.service-detail>h2,.service-detail>p,.service-detail>ul{padding-left:34px;padding-right:34px}
.service-detail>span{padding-top:28px}
.service-detail>ul{padding-bottom:34px}
.process-hero-img{width:100%;max-height:460px;object-fit:cover;border-radius:32px;display:block}
.project-list{display:grid;gap:30px}
.case-study{display:grid;grid-template-columns:.95fr 1.05fr;gap:34px;align-items:center;background:white;padding:28px;border-radius:38px;box-shadow:0 18px 60px rgba(31,42,36,.07)}
.case-study img{min-height:360px;width:100%;object-fit:cover;display:block;border-radius:28px}
.case-study.reverse img{order:2}
.timeline-large{display:grid;gap:0;max-width:820px;margin:0 auto;position:relative;padding-left:10px}
.timeline-large::before{content:'';position:absolute;left:35px;top:28px;bottom:28px;width:2px;background:linear-gradient(to bottom,var(--brand),rgba(31,42,36,.1))}
.process-step{display:grid;grid-template-columns:52px 1fr;gap:36px;padding:0 0 44px;align-items:start;position:relative}
.process-step:last-child{padding-bottom:0}
.process-step>span{width:52px;height:52px;display:grid;place-items:center;border-radius:50%;background:var(--brand);color:white;font-size:15px;font-weight:900;position:relative;z-index:1;flex-shrink:0}
.process-step h2{font-size:clamp(20px,2.4vw,26px);margin:10px 0 8px}
.process-step p{margin:0;grid-column:2}
.faq-list{max-width:900px}
details{background:white;border-radius:24px;margin-bottom:14px;padding:22px 24px;border:1px solid rgba(31,42,36,.08)}
summary{cursor:pointer;font-weight:850;font-size:19px}
details p{color:var(--muted);margin:14px 0 0}
.contact-section{display:grid;grid-template-columns:.9fr 1.1fr;gap:42px;align-items:start}
.contact-copy p{color:var(--muted)}
.contact-details{margin-top:26px;padding:22px;border-radius:24px;background:white;border:1px solid rgba(31,42,36,.08)}
.contact-details p{margin:0 0 8px}
.contact-form{padding:28px;border-radius:34px;background:white;box-shadow:var(--shadow)}
label{display:block;margin-bottom:16px;font-weight:750}
input,select,textarea{width:100%;margin-top:8px;padding:14px 15px;border:1px solid rgba(31,42,36,.14);border-radius:16px;font:inherit;color:var(--ink);background:#fffdf8}
textarea{resize:vertical}
.form-note{margin:14px 0 0;color:var(--muted);font-size:13px;text-align:center}
.cta-band{max-width:1180px;margin:40px auto 80px;padding:42px;border-radius:38px;background:var(--ink);color:white;display:flex;align-items:center;justify-content:space-between;gap:28px}
.cta-band p{color:rgba(255,255,255,.72);max-width:720px}
.cta-band .eyebrow{color:#f1c6a8}
.legal-page{max-width:900px}
.legal-page p{color:var(--muted)}
.footer{max-width:1180px;margin:0 auto;padding:38px 24px 46px;border-top:1px solid rgba(31,42,36,.1);display:grid;grid-template-columns:1.1fr .7fr 1fr;gap:28px;color:var(--muted)}
.footer-brand{color:var(--ink);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-weight:750;color:var(--ink)}
.footer-contact p{margin:0 0 8px}
@media(max-width:980px){
  .hero,.two-col,.contact-section,.case-study{grid-template-columns:1fr}
  .case-study.reverse img{order:0}
  .hero-card{min-height:460px}
  .service-grid,.project-grid,.values-grid,.service-detail-grid{grid-template-columns:repeat(2,1fr)}
  .footer{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .nav-links{display:none;position:absolute;left:24px;right:24px;top:76px;padding:20px;border-radius:22px;background:white;box-shadow:var(--shadow);flex-direction:column;align-items:flex-start}
  .nav-links.open{display:flex}
}
@media(max-width:640px){
  .hero{padding-top:54px}
  .hero-stats,.service-grid,.project-grid,.values-grid,.service-detail-grid{grid-template-columns:1fr}
  .process-step{grid-template-columns:44px 1fr;gap:24px}
  .process-step>span{width:44px;height:44px;font-size:13px}
  .timeline-large::before{left:31px}
  .hero-card{min-height:380px;border-radius:30px;padding:22px}
  .image-hero{inset:24px;width:calc(100% - 48px);height:calc(100% - 48px)}
  .floating-note{left:22px;right:22px;bottom:22px;max-width:none}
  .cta-band{flex-direction:column;align-items:flex-start;margin-left:24px;margin-right:24px}
}
