:root{
  --bg:#0E0E0E;
  --bg-2:#141414;
  --ink:#0B0B0B;
  --paper:#F6F1E7;
  --paper-2:#EDE6D6;
  --muted:#8A867E;
  --line:rgba(20,20,20,.10);
  --line-dark:rgba(255,255,255,.08);
  --accent:#B5482A;
  --accent-2:#C9A86A;
  --sage:#5C6B52;
  --radius:2px;
  --max:1320px;
  --gutter:clamp(20px, 4vw, 64px);
  --display: "Instrument Serif", "Times New Roman", serif;
  --body: "Geist", "Inter Tight", -apple-system, "SF Pro Text", system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.55;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .25s ease, color .25s ease}
a:hover{opacity:.7}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(80px, 12vw, 160px) 0}
.section-sm{padding:clamp(56px, 8vw, 100px) 0}

/* Typography */
h1,h2,h3,h4{font-family:var(--display);font-weight:400;letter-spacing:-.01em;line-height:1.02}
h1{font-size:clamp(48px, 8.5vw, 132px)}
h2{font-size:clamp(36px, 5.5vw, 84px)}
h3{font-size:clamp(28px, 3.4vw, 48px)}
h4{font-size:clamp(22px, 2vw, 30px)}
p{max-width:68ch}
.lede{font-size:clamp(20px, 1.8vw, 26px);line-height:1.45;color:#2A2A2A;font-weight:400}
.eyebrow{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);display:inline-flex;gap:.6em;align-items:center}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;opacity:.6}
.serif{font-family:var(--display)}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;background:rgba(246,241,231,.72);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--line);transition:transform .4s ease, background .3s ease}
.site-header.dark{background:rgba(14,14,14,.55);border-bottom-color:var(--line-dark);color:var(--paper)}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:22px}
.brand img{width:28px;height:28px;object-fit:contain}
.brand span{letter-spacing:-.01em}
.nav{display:flex;gap:28px;align-items:center}
.nav a{font-size:14px;letter-spacing:.01em}
.nav a.cta{padding:10px 18px;border:1px solid currentColor;border-radius:999px}
.menu-btn{display:none;width:42px;height:42px;border:1px solid currentColor;border-radius:999px;align-items:center;justify-content:center}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{content:"";display:block;width:16px;height:1px;background:currentColor;position:relative}
.menu-btn span::before{position:absolute;top:-5px;left:0}
.menu-btn span::after{position:absolute;top:5px;left:0}
@media (max-width: 900px){
  .nav{position:fixed;inset:0;background:var(--paper);flex-direction:column;justify-content:center;align-items:center;gap:24px;transform:translateY(-100%);transition:transform .5s cubic-bezier(.7,0,.2,1);z-index:60}
  .nav.open{transform:translateY(0)}
  .nav a{font-family:var(--display);font-size:32px}
  .menu-btn{display:inline-flex;z-index:70}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 28px;border-radius:999px;font-size:14px;letter-spacing:.02em;transition:transform .3s ease, background .3s ease, color .3s ease;border:1px solid transparent;will-change:transform}
.btn:hover{opacity:1;transform:translateY(-2px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent)}
.btn-outline{border-color:currentColor}
.btn-outline:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn .arrow{display:inline-block;transition:transform .3s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:140px 0 80px;overflow:hidden;background:var(--paper)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 40%, rgba(181,72,42,.06), transparent 70%);pointer-events:none}
.hero-canvas{position:absolute;inset:0;z-index:0;opacity:.85}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{max-width:14ch}
.hero-meta{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:end;margin-top:48px}
.hero-meta p{max-width:48ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:80px;border-top:1px solid var(--line);padding-top:24px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.hero-foot div{display:flex;gap:8px;align-items:center}

/* Marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;background:var(--paper-2)}
.marquee-track{display:flex;gap:64px;white-space:nowrap;animation:scroll 40s linear infinite;font-family:var(--display);font-size:clamp(20px, 2.2vw, 36px)}
.marquee-track span{display:inline-flex;align-items:center;gap:64px}
.marquee-track span::after{content:"✦";color:var(--accent);font-size:.7em}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Page hero */
.page-hero{padding:200px 0 80px;border-bottom:1px solid var(--line);background:var(--paper)}
.page-hero h1{max-width:18ch;margin-top:18px}
.page-hero .lede{margin-top:36px;max-width:62ch}

/* Split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:48px}}
.split img{width:100%;border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover}

/* Cards */
.grid{display:grid;gap:32px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{padding:40px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);transition:transform .4s ease, background .4s ease}
.card:hover{transform:translateY(-4px);background:var(--paper-2)}
.card .num{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}
.card h3{margin:24px 0 16px}
.card p{color:#3a3a3a}

/* Service tile */
.svc-tile{position:relative;display:block;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/5;color:var(--paper)}
.svc-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease}
.svc-tile:hover img{transform:scale(1.05)}
.svc-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.75))}
.svc-tile .meta{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:2}
.svc-tile h3{font-size:32px;margin:8px 0}
.svc-tile .num{color:rgba(255,255,255,.6)}
.svc-tile .arrow-link{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em}

/* Dark section */
.dark-sec{background:var(--bg);color:var(--paper)}
.dark-sec .card{background:var(--bg-2);border-color:var(--line-dark);color:var(--paper)}
.dark-sec .card:hover{background:#1c1c1c}
.dark-sec .card p{color:#b6b3ac}
.dark-sec .eyebrow{color:#9a958a}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.stats > div{padding:40px 24px;border-right:1px solid var(--line-dark)}
.stats > div:last-child{border-right:0}
.stats .big{font-family:var(--display);font-size:clamp(48px, 6vw, 88px)}
.stats .lbl{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:#9a958a;margin-top:10px}
@media (max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}.stats > div{border-bottom:1px solid var(--line-dark)}.stats > div:nth-child(odd){border-right:1px solid var(--line-dark)}.stats > div:nth-child(even){border-right:0}}

/* Process steps */
.steps{display:grid;gap:0}
.step{display:grid;grid-template-columns:120px 1fr 1fr;gap:48px;padding:48px 0;border-top:1px solid var(--line);align-items:start}
.step:last-child{border-bottom:1px solid var(--line)}
.step .num{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.18em}
.step h3{font-size:clamp(28px, 3vw, 44px)}
.step p{color:#3a3a3a}
@media (max-width:900px){.step{grid-template-columns:1fr;gap:16px}}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.gal img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius)}
.gal .a{grid-column:span 7;aspect-ratio:16/10}
.gal .b{grid-column:span 5;aspect-ratio:4/5}
.gal .c{grid-column:span 4;aspect-ratio:1}
.gal .d{grid-column:span 4;aspect-ratio:1}
.gal .e{grid-column:span 4;aspect-ratio:1}
.gal .f{grid-column:span 6;aspect-ratio:3/2}
.gal .g{grid-column:span 6;aspect-ratio:3/2}
@media (max-width:900px){.gal > *{grid-column:span 12 !important;aspect-ratio:4/3 !important}}

/* Testimonials */
.quote{padding:48px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper)}
.quote .q{font-family:var(--display);font-size:clamp(22px,2vw,32px);line-height:1.35}
.quote .by{margin-top:24px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}

/* FAQ */
.faq details{border-bottom:1px solid var(--line);padding:28px 0;cursor:pointer}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{font-family:var(--display);font-size:clamp(22px,2.2vw,32px);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:28px;transition:transform .3s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding-top:18px;color:#3a3a3a;max-width:80ch}

/* Contact form */
.form{display:grid;gap:20px;max-width:680px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.field{display:grid;gap:8px}
.field label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.field input,.field textarea,.field select{padding:16px 18px;border:1px solid var(--line);border-radius:var(--radius);background:transparent;font:inherit;color:var(--ink);transition:border-color .3s ease}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ink)}
.field textarea{min-height:160px;resize:vertical;font-family:var(--body)}

/* Footer */
.site-footer{background:var(--ink);color:var(--paper);padding:80px 0 32px}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid var(--line-dark)}
@media (max-width:900px){.foot-top{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.foot-top{grid-template-columns:1fr}}
.foot-top h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:#9a958a;margin-bottom:20px;font-weight:400}
.foot-top a, .foot-top p{display:block;font-size:14px;margin-bottom:10px;color:#cec9bf}
.foot-brand .mark{font-family:var(--display);font-size:40px;line-height:1}
.foot-brand p{margin-top:16px;max-width:38ch}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:24px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:#7a766d}
.foot-bottom a{color:#7a766d}

/* Cookie banner */
.cookie{position:fixed;bottom:24px;left:24px;right:24px;max-width:520px;background:var(--ink);color:var(--paper);padding:24px;border-radius:var(--radius);z-index:100;box-shadow:0 30px 60px rgba(0,0,0,.3);display:none}
.cookie.show{display:block;animation:slideUp .5s ease}
.cookie p{font-size:13px;line-height:1.55;color:#cec9bf;margin-bottom:16px}
.cookie .row{display:flex;gap:10px}
.cookie .btn{padding:12px 18px;font-size:12px}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Reveal animation */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}

/* Legal pages */
.legal{max-width:820px;margin:0 auto}
.legal h2{margin-top:56px;font-size:clamp(28px,3vw,40px)}
.legal h3{margin-top:32px;font-size:clamp(22px,2vw,28px)}
.legal p, .legal li{color:#2a2a2a;margin-bottom:16px;max-width:none}
.legal ul,.legal ol{padding-left:24px;margin-bottom:16px}
.legal a{color:var(--accent);text-decoration:underline}

/* Misc */
hr.thin{border:0;border-top:1px solid var(--line);margin:0}
.center{text-align:center}
.muted{color:var(--muted)}
.spacer{height:80px}