:root{
  --bg:#FAFAF7; --fg:#0E1422; --muted:#6B7280; --muted-bg:#F1EFE9;
  --border:#E5E2DA; --primary:#C8A24B; --primary-fg:#1A1408;
  --secondary:#0E1422; --secondary-fg:#FAFAF7;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.font-display{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-0.01em}
.italic{font-style:italic}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 32px}}
.eyebrow{font-size:11px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--primary)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:14px 24px;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:3px;transition:.2s;border:0;cursor:pointer}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{background:#b58d3a}
.btn-secondary{background:var(--secondary);color:var(--secondary-fg)}
.btn-secondary:hover{background:#1c2336}
.btn-ghost{color:inherit}
.btn-ghost:hover{color:var(--primary)}
/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,250,247,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',serif;font-size:24px;font-weight:600;letter-spacing:-.01em}
.brand .mark{width:38px;height:38px;background:var(--secondary);color:var(--primary);display:grid;place-items:center;font-family:'Fraunces',serif;font-size:20px;border-radius:3px}
.brand.brand-xl{font-size:34px}
.brand.brand-xl .mark{width:50px;height:50px;font-size:26px}
@media(min-width:768px){.brand.brand-xl{font-size:44px}.brand.brand-xl .mark{width:62px;height:62px;font-size:32px}}
.nav-links{display:none;gap:32px;font-size:13px;text-transform:uppercase;letter-spacing:.18em;font-weight:600}
.nav-links a:hover{color:var(--primary)}
.nav-links a.active{color:var(--primary)}
@media(min-width:900px){.nav-links{display:flex} .menu-btn{display:none}}
.menu-btn{background:transparent;border:1px solid var(--border);padding:10px 14px;border-radius:3px;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;cursor:pointer}
.mobile-menu{display:none;border-top:1px solid var(--border);background:var(--bg)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:16px 20px;border-bottom:1px solid var(--border);font-size:14px;text-transform:uppercase;letter-spacing:.15em;font-weight:600}
/* HERO */
.hero{position:relative;background:var(--secondary);color:var(--secondary-fg);overflow:hidden;isolation:isolate}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.45;z-index:-2}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--secondary) 0%,rgba(14,20,34,.85) 50%,rgba(14,20,34,.3) 100%);z-index:-1}
.hero-inner{padding:96px 0 120px;display:grid;gap:48px}
@media(min-width:900px){.hero-inner{grid-template-columns:2fr 1fr;padding:128px 0 160px}}
.hero h1{font-family:'Fraunces',serif;font-size:48px;line-height:.95;margin:24px 0 0;font-weight:500}
@media(min-width:768px){.hero h1{font-size:80px}}
.hero p{margin-top:28px;max-width:560px;color:rgba(250,250,247,.75);font-size:17px;line-height:1.6}
.hero .eyebrow{display:flex;align-items:center;gap:12px}
.hero .eyebrow::before{content:"";width:40px;height:1px;background:var(--primary)}
.cta-row{margin-top:36px;display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);border-radius:3px;overflow:hidden;align-self:end}
.stats div{background:var(--secondary);padding:20px}
.stats .k{font-family:'Fraunces',serif;font-size:30px;color:var(--primary);font-weight:600}
.stats .v{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:rgba(250,250,247,.6);margin-top:4px}
/* MARQUEE */
.strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg)}
.strip-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:20px;padding:22px 0;font-size:12px;text-transform:uppercase;letter-spacing:.25em;font-weight:600;color:var(--muted)}
.strip-inner .dot{color:var(--primary);margin-right:10px}
/* SECTIONS */
section.pad{padding:96px 0}
@media(min-width:900px){section.pad{padding:128px 0}}
.section-head{display:flex;flex-direction:column;gap:24px}
@media(min-width:768px){.section-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
h2.h{font-family:'Fraunces',serif;font-size:36px;line-height:1.1;margin:16px 0 0;font-weight:500}
@media(min-width:768px){h2.h{font-size:52px}}
.grid-12{display:grid;gap:48px}
@media(min-width:900px){.grid-12{grid-template-columns:repeat(12,1fr)}}
.col-5{grid-column:span 5}.col-7{grid-column:span 7}.col-4{grid-column:span 4}.col-8{grid-column:span 8}
@media(max-width:899px){.col-5,.col-7,.col-4,.col-8{grid-column:auto}}
.muted{color:var(--muted)}
.bg-muted{background:var(--muted-bg)}
.bg-secondary{background:var(--secondary);color:var(--secondary-fg)}
.text-primary{color:var(--primary)}
/* CAPABILITY GRID */
.cap-grid{margin-top:56px;display:grid;gap:1px;background:var(--border);border-radius:3px;overflow:hidden}
@media(min-width:640px){.cap-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.cap-grid{grid-template-columns:1fr 1fr 1fr}}
.cap{background:var(--bg);padding:32px;display:flex;flex-direction:column;gap:24px;transition:.25s}
.cap:hover{background:var(--secondary);color:var(--secondary-fg)}
.cap:hover .cap-num{color:var(--primary)}
.cap-top{display:flex;justify-content:space-between;align-items:center}
.cap-icon{width:28px;height:28px;color:var(--primary)}
.cap-num{font-family:'Fraunces',serif;font-size:13px;color:var(--muted)}
.cap h3{font-family:'Fraunces',serif;font-size:20px;line-height:1.3;margin:0;font-weight:500}
.cap p{margin:0;font-size:14px;line-height:1.6;color:var(--muted)}
.cap:hover p{color:rgba(250,250,247,.7)}
/* PROCESS */
.proc{margin:0;padding:0;list-style:none}
.proc li{display:grid;grid-template-columns:auto 1fr;gap:40px;padding:24px 0;border-top:1px solid var(--border)}
.proc li:first-child{border-top:0}
.proc .n{font-family:'Fraunces',serif;font-size:28px;color:var(--primary);font-weight:500}
.proc .t{font-family:'Fraunces',serif;font-size:20px;font-weight:500}
.proc .d{color:var(--muted);margin-top:4px}
/* PORTFOLIO */
.portfolio{display:grid;gap:32px;margin-top:56px}
@media(min-width:768px){.portfolio{grid-template-columns:1fr 1fr 1fr}}
.proj{display:block}
.proj .img{aspect-ratio:4/5;overflow:hidden;border-radius:3px;background:var(--muted-bg)}
.proj img{width:100%;height:100%;object-fit:cover;transition:.6s}
.proj:hover img{transform:scale(1.05)}
.proj .meta{display:flex;justify-content:space-between;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin-top:20px}
.proj .meta .tag{color:rgba(250,250,247,.5)}
.proj h3{font-family:'Fraunces',serif;font-size:20px;font-weight:500;margin:8px 0 0}
/* SERVICES PAGE LIST */
.cap-list{margin-top:48px;display:grid;gap:1px;background:var(--border);border-radius:3px;overflow:hidden}
.cap-item{background:var(--bg);padding:32px;display:grid;gap:32px;transition:.2s}
@media(min-width:768px){.cap-item{grid-template-columns:1fr 2fr;gap:64px;padding:48px}}
.cap-item:hover{background:var(--muted-bg)}
.cap-item h2{font-family:'Fraunces',serif;font-size:28px;margin:24px 0 0;font-weight:500}
@media(min-width:768px){.cap-item h2{font-size:36px}}
.cap-item .lead{font-size:17px;line-height:1.65;color:#0E1422cc}
.bullets{margin:24px 0 0;padding:0;list-style:none;display:grid;gap:8px}
@media(min-width:640px){.bullets{grid-template-columns:1fr 1fr}}
.bullets li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:#0E142299}
.bullets li::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--primary);margin-top:8px;flex-shrink:0}
/* FORM */
.field-input{width:100%;padding:14px 16px;border:1px solid var(--border);background:var(--bg);border-radius:3px;font-size:14px;font-family:inherit;color:var(--fg);outline:none;transition:.2s}
.field-input:focus{border-color:var(--primary)}
.field-label{display:block;font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
/* FOOTER */
footer{background:var(--secondary);color:var(--secondary-fg);padding:64px 0 32px;margin-top:0}
.foot-grid{display:grid;gap:40px}
@media(min-width:768px){.foot-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
footer h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin:0 0 16px;font-weight:600}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:8px;font-size:14px;color:rgba(250,250,247,.7)}
footer ul a:hover{color:var(--primary)}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;font-size:12px;color:rgba(250,250,247,.5);flex-wrap:wrap;gap:12px}
/* CARDS */
.mv-grid{display:grid;gap:1px;background:var(--border);border-radius:3px;overflow:hidden;max-width:1100px;margin:0 auto}
@media(min-width:768px){.mv-grid{grid-template-columns:1fr 1fr}}
.mv{background:var(--bg);padding:40px}
@media(min-width:768px){.mv{padding:56px}}
.mv p{font-family:'Fraunces',serif;font-size:22px;line-height:1.35;font-weight:500;margin:24px 0 0}
@media(min-width:768px){.mv p{font-size:28px}}
.contact-list{display:grid;gap:1px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:32px}
.contact-row{background:var(--bg);padding:20px;display:flex;gap:16px;align-items:flex-start}
.contact-ic{width:40px;height:40px;background:var(--secondary);color:var(--primary);display:grid;place-items:center;border-radius:3px;flex-shrink:0}
.contact-row .title{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);font-weight:600}
.contact-row .line{font-size:14px}
/* Utility */
.text-right-md{}
@media(min-width:768px){.text-right-md{text-align:right}}
.notice{margin-top:32px;padding:24px;border:1px solid var(--primary);background:rgba(200,162,75,.1);border-radius:3px;font-size:14px}
.cap-item .cap-media{margin-top:18px;border-radius:3px;overflow:hidden;aspect-ratio:16/10;background:var(--border)}
.cap-item .cap-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.cap-item .cap-media img:hover{transform:scale(1.03)}
