:root{
  --bg:#fafaf7; --fg:#1a1a1a; --muted:#6b6b6b; --border:#e7e3da;
  --charcoal:#1a1a1a; --gold:#C8A45D; --gold-fg:#1a1a1a;
  --secondary:#f3efe7;
  --shadow-luxe: 0 30px 60px -20px rgba(26,26,26,.18);
  --shadow-soft: 0 6px 24px -8px rgba(26,26,26,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--fg);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s}
h1,h2,h3,h4,h5,.font-display{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;color:var(--charcoal);line-height:1.1;letter-spacing:-.01em}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";display:inline-block;width:36px;height:1px;background:var(--gold)}
.gold{color:var(--gold)} em{color:var(--gold);font-style:normal}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;font-size:11px;text-transform:uppercase;letter-spacing:.22em;border:1px solid transparent;cursor:pointer;transition:.25s}
.btn-primary{background:var(--charcoal);color:#fff}
.btn-primary:hover{background:var(--gold);color:var(--gold-fg)}
.btn-gold{background:var(--gold);color:var(--gold-fg)}
.btn-gold:hover{background:var(--charcoal);color:#fff}
.btn-outline{border-color:rgba(26,26,26,.25);color:var(--charcoal)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border)}
.topbar{font-size:12px;color:var(--muted);border-bottom:1px solid #efeae0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding-top:8px;padding-bottom:8px}
.topbar a{display:inline-flex;align-items:center;gap:6px;margin-left:20px}
.topbar a:hover{color:var(--gold)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 24px}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:42px;height:42px;background:var(--charcoal);color:var(--gold);display:grid;place-items:center;font-family:'Cormorant Garamond',serif;font-size:22px}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--charcoal);line-height:1}
.brand-tag{display:block;font-size:9px;letter-spacing:.3em;color:var(--gold);margin-top:4px;font-family:'Inter',sans-serif}
.nav-primary{display:none;gap:28px;font-size:14px}
.nav-primary a{position:relative}
.nav-primary a:hover, .nav-primary .current-menu-item a{color:var(--gold)}
.badge-new{font-size:9px;letter-spacing:.18em;background:var(--gold);color:var(--gold-fg);padding:2px 6px;margin-left:6px;text-transform:uppercase}
.header-cta{display:none;gap:10px}
.menu-toggle{background:none;border:0;cursor:pointer;padding:8px}
.menu-toggle svg{width:24px;height:24px}
@media(min-width:1024px){.nav-primary{display:flex}.header-cta{display:flex}.menu-toggle{display:none}}

/* Mobile menu */
.mobile-menu{display:none;background:#fff;border-top:1px solid var(--border)}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:16px 24px;border-bottom:1px solid var(--border);font-size:13px;letter-spacing:.15em;text-transform:uppercase}

/* HERO */
.hero{padding:60px 0 100px}
.hero-grid{display:grid;gap:50px;align-items:center}
@media(min-width:1024px){.hero-grid{grid-template-columns:1fr 1fr;gap:80px}}
.hero h1{font-size:56px;margin:24px 0 28px}
@media(min-width:768px){.hero h1{font-size:78px}}
.hero p{font-size:18px;color:var(--muted);max-width:520px;margin-bottom:36px}
.hero-img{position:relative;aspect-ratio:4/5;background:#222;overflow:hidden;box-shadow:var(--shadow-luxe)}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;background:#fff;padding:18px 22px;box-shadow:var(--shadow-luxe);display:flex;gap:14px;align-items:center;max-width:240px}
.hero-badge-1{left:-20px;bottom:60px}
.hero-badge-2{right:-20px;top:60px;background:var(--charcoal);color:#fff}
.hero-badge strong{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--charcoal);display:block}
.hero-badge-2 strong{color:#fff}
.hero-badge small{font-size:11px;color:var(--muted);display:block}
.hero-badge-2 small{color:rgba(255,255,255,.7)}
.cta-row{display:flex;flex-wrap:wrap;gap:12px}

/* Stats strip */
.stats{background:var(--charcoal);color:#fff}
.stats .container{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:50px 24px}
@media(min-width:768px){.stats .container{grid-template-columns:repeat(4,1fr)}}
.stat-value{font-family:'Cormorant Garamond',serif;font-size:48px;color:var(--gold);line-height:1}
.stat-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:8px}

/* Section base */
.section{padding:100px 0}
.section-secondary{background:var(--secondary)}
.section-dark{background:var(--charcoal);color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-head{max-width:780px;margin-bottom:60px}
.section-head h2{font-size:42px;margin:20px 0 16px}
@media(min-width:768px){.section-head h2{font-size:56px}}

/* Services grid */
.services-grid{display:grid;gap:1px;background:var(--border)}
@media(min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services-grid{grid-template-columns:repeat(4,1fr)}}
.service-card{background:#fff;padding:32px;transition:.4s}
.service-card:hover{background:var(--charcoal);color:#fff}
.service-card:hover h3{color:#fff}
.service-card:hover p{color:rgba(255,255,255,.7)}
.service-card svg{color:var(--gold);width:36px;height:36px;stroke-width:1.2}
.service-card h3{font-size:22px;margin:20px 0 10px}
.service-card p{color:var(--muted);font-size:14px}
.service-card .learn{margin-top:20px;display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}

/* Why us */
.why-grid{display:grid;gap:60px;align-items:center}
@media(min-width:1024px){.why-grid{grid-template-columns:1fr 1fr}}
.why-list{display:grid;gap:14px;grid-template-columns:1fr;list-style:none;padding:0;margin:0}
@media(min-width:640px){.why-list{grid-template-columns:1fr 1fr}}
.why-list li{display:flex;gap:12px;background:#fff;padding:18px;box-shadow:var(--shadow-soft);font-size:14px}
.why-list li::before{content:"✓";color:var(--gold);font-weight:700}

/* Portfolio */
.portfolio-grid{display:grid;gap:20px}
@media(min-width:768px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}
.p-card{position:relative;overflow:hidden;aspect-ratio:4/5;background:#222}
.p-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.p-card:hover img{transform:scale(1.05)}
.p-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(26,26,26,.85), transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff}
.p-cat{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.p-title{font-family:'Cormorant Garamond',serif;font-size:24px;margin:8px 0 4px}
.p-loc{font-size:12px;color:rgba(255,255,255,.7)}

/* Process */
.process-grid{display:grid;gap:1px;background:rgba(255,255,255,.1)}
@media(min-width:768px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.process-grid{grid-template-columns:repeat(3,1fr)}}
.process-card{background:var(--charcoal);padding:32px}
.process-num{font-family:'Cormorant Garamond',serif;font-size:54px;color:var(--gold);line-height:1}
.process-card h3{font-size:24px;margin:18px 0 10px}
.process-card p{color:rgba(255,255,255,.7);font-size:14px}

/* Testimonials */
.t-grid{display:grid;gap:24px;margin-top:60px}
@media(min-width:768px){.t-grid{grid-template-columns:repeat(3,1fr)}}
.t-card{background:#fff;padding:32px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.t-stars{color:var(--gold);letter-spacing:2px}
.t-quote{font-family:'Cormorant Garamond',serif;font-size:20px;margin:20px 0;flex:1}
.t-author{padding-top:18px;border-top:1px solid var(--border);font-size:14px;font-weight:500}
.t-author small{display:block;color:var(--muted);font-size:12px;margin-top:4px;font-weight:400}

/* CTA */
.cta-banner{position:relative;overflow:hidden;text-align:center;color:#fff}
.cta-banner::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#1a1a1a 0%, #2a2a2a 100%);z-index:0}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{font-size:42px;margin:20px auto;max-width:640px;color:#fff}
@media(min-width:768px){.cta-banner h2{font-size:64px}}
.cta-banner p{color:rgba(255,255,255,.8);max-width:520px;margin:0 auto 36px}

/* FOOTER */
.site-footer{background:#0e0e0e;color:rgba(255,255,255,.7);padding:80px 0 30px}
.footer-grid{display:grid;gap:40px;margin-bottom:60px}
@media(min-width:768px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.site-footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:11px;letter-spacing:.22em;text-transform:uppercase;margin:0 0 20px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:10px 0;font-size:14px}
.site-footer a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:30px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12px}

/* Contact */
.contact-grid{display:grid;gap:50px}
@media(min-width:1024px){.contact-grid{grid-template-columns:1.2fr 1fr}}
.contact-form{display:grid;gap:16px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:14px;background:#fff;border:1px solid var(--border);font:inherit;font-size:14px}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--gold)}
.contact-info{background:var(--charcoal);color:#fff;padding:40px}
.contact-info h3{color:#fff}
.contact-info a:hover{color:var(--gold)}
.map-embed{margin-top:40px;height:380px;border:0;width:100%}

/* Designer iframe page */
.designer-frame{width:100%;height:calc(100vh - 200px);min-height:720px;border:0;display:block;background:#f3efe7}
.designer-note{background:var(--charcoal);color:#fff;padding:14px;text-align:center;font-size:12px;letter-spacing:.15em;text-transform:uppercase}

/* Page hero */
.page-hero{padding:80px 0 40px;background:#fff;border-bottom:1px solid var(--border)}
.page-hero h1{font-size:48px;margin-top:18px}
@media(min-width:768px){.page-hero h1{font-size:72px}}

/* Sticky mobile CTA */
.mobile-cta{position:fixed;bottom:0;left:0;right:0;display:flex;z-index:40;background:#fff;border-top:1px solid var(--border)}
.mobile-cta a{flex:1;text-align:center;padding:14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.mobile-cta a:first-child{background:var(--charcoal);color:#fff}
.mobile-cta a:last-child{background:#25D366;color:#fff}
@media(min-width:1024px){.mobile-cta{display:none}}
@media(max-width:1023px){body{padding-bottom:50px}}

/* Utility */
.text-center{text-align:center}
.mt-md{margin-top:24px} .mt-lg{margin-top:40px}
