:root{
  --background:#1a1410;
  --foreground:#f5efe6;
  --card:#241c17;
  --muted:#2a221c;
  --muted-foreground:#a89a87;
  --border:#3a2f26;
  --input:#2f2620;
  --primary:#d6a85a;
  --primary-foreground:#1a1410;
  --accent:#c2622f;
  --radius:.5rem;
  --font-display:"Playfair Display",Georgia,serif;
  --font-sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;border-color:var(--border)}
html{scroll-behavior:smooth}
body{background:var(--background);color:var(--foreground);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em;line-height:1.1}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.muted{color:var(--muted-foreground)}
.small{font-size:.85rem}
.center{text-align:center}
.link{color:var(--primary);font-weight:600}
.link:hover{text-decoration:underline}
.strong{font-weight:700;color:var(--foreground)}
.mb{margin-bottom:3rem}
.i{width:1em;height:1em;display:inline-block;vertical-align:-.15em}
.star{fill:var(--primary)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;padding:.6rem 1rem;cursor:pointer;border:1px solid transparent;transition:opacity .15s,background .15s,border-color .15s;text-align:center}
.btn-primary{background:var(--primary);color:var(--primary-foreground)}
.btn-primary:hover{opacity:.9}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--foreground);border-color:var(--border)}
.btn-ghost:hover{background:var(--card)}
.btn-lg{padding:1rem 1.5rem;font-size:1rem}
.btn-block{width:100%;padding:1rem 1.5rem}

/* Topbar */
.topbar{display:none;border-bottom:1px solid var(--border);background:rgba(42,34,28,.5);font-size:.75rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1.5rem}
.topbar-left{display:flex;gap:1rem;color:var(--muted-foreground)}
.topbar-left .ic,.topbar-right{display:inline-flex;align-items:center;gap:.4rem}
.topbar-left .i,.topbar-right .i{color:var(--primary)}
@media(min-width:768px){.topbar{display:block}}

/* Header */
.header{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border);background:rgba(26,20,16,.85);backdrop-filter:blur(8px)}
.header-inner{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-mark{width:2.25rem;height:2.25rem;border-radius:50%;background:var(--primary);color:var(--primary-foreground);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.brand-mark.sm{width:2rem;height:2rem;font-size:1rem}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem}
.brand-tag{font-size:.65rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-foreground)}
.nav{display:none;gap:2rem;font-size:.9rem}
.nav a{color:var(--muted-foreground)}
.nav a:hover{color:var(--foreground)}
.header-call{display:none}
@media(min-width:768px){.nav,.header-call{display:inline-flex}}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,var(--background),rgba(26,20,16,.85) 50%,rgba(26,20,16,.3)),linear-gradient(to top,var(--background),transparent)}
.hero-inner{position:relative;padding:4rem 1.5rem 6rem;display:grid;gap:2rem}
@media(min-width:768px){.hero-inner{grid-template-columns:1fr 1fr;padding:7rem 1.5rem 8rem}}
.badge{display:inline-flex;align-items:center;gap:.4rem;border:1px solid rgba(214,168,90,.3);background:rgba(214,168,90,.1);color:var(--primary);font-size:.75rem;font-weight:500;padding:.3rem .75rem;border-radius:9999px}
h1{font-size:3rem;font-weight:700;margin-top:1.25rem}
@media(min-width:768px){h1{font-size:4.5rem}}
.accent{color:var(--primary)}
.lead{margin-top:1.25rem;max-width:32rem;font-size:1.125rem;color:var(--muted-foreground)}
.cta-row{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem}
@media(min-width:640px){.cta-row{flex-direction:row}}
.hero-checks{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;font-size:.9rem;color:var(--muted-foreground)}

/* Trust */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(42,34,28,.4)}
.trust-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:2rem 1.5rem;text-align:center;max-width:1200px;margin:0 auto}
@media(min-width:768px){.trust-grid{grid-template-columns:repeat(4,1fr)}}
.trust-k{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--primary)}
@media(min-width:768px){.trust-k{font-size:2rem}}
.trust-v{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground)}

/* Sections */
.section{padding:5rem 1.5rem}
.section-alt{padding:5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(42,34,28,.3)}
@media(min-width:768px){.section,.section-alt{padding:7rem 0}.section{padding:7rem 1.5rem}}
.section-head{margin-bottom:3rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start;justify-content:space-between}
@media(min-width:768px){.section-head{flex-direction:row;align-items:flex-end}}
.eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--primary)}
h2{font-size:2.25rem;font-weight:700;margin-top:.5rem}
@media(min-width:768px){h2{font-size:3rem}}

/* Grids */
.grid-2{display:grid;gap:3rem}
.grid-3{display:grid;gap:1.5rem}
@media(min-width:768px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}}

/* Card */
.card{border:1px solid var(--border);background:var(--card);border-radius:.75rem;overflow:hidden;transition:border-color .15s}
.card:hover{border-color:rgba(214,168,90,.5)}
.card.pad{padding:1.75rem;display:flex;flex-direction:column}
.card-img{aspect-ratio:4/3;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:1.5rem}
.card-row{display:flex;justify-content:space-between;align-items:center}
.card h3{font-size:1.5rem}
.card-body p,.card.pad blockquote{margin-top:.75rem;color:var(--muted-foreground)}
.pill{background:rgba(214,168,90,.15);color:var(--primary);font-size:.85rem;font-weight:600;padding:.25rem .75rem;border-radius:9999px}
.card.pad blockquote{font-family:var(--font-display);font-size:1.1rem;flex:1}
.card.pad figcaption{margin-top:1.25rem;font-size:.9rem}
.stars{color:var(--primary);letter-spacing:.1em}

/* About */
.checks{margin-top:1.5rem;list-style:none;display:flex;flex-direction:column;gap:.75rem}
.about-img{position:relative}
.about-img img{border-radius:.75rem;border:1px solid var(--border)}
.rating-card{display:none;position:absolute;left:-1.5rem;bottom:-1.5rem;background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.rating-card .rating-num{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-top:.25rem}
@media(min-width:768px){.rating-card{display:block}}

/* Quote */
.contact-stack{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.contact-card{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid var(--border);background:var(--card);border-radius:.5rem;transition:border-color .15s}
.contact-card:hover{border-color:rgba(214,168,90,.5)}
.contact-card.primary{border-color:rgba(214,168,90,.4);background:rgba(214,168,90,.1)}
.contact-ic{width:2.75rem;height:2.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--primary);color:var(--primary-foreground);font-size:1.1rem}
.contact-card:not(.primary) .contact-ic{background:var(--muted);color:var(--primary)}
.contact-big{font-family:var(--font-display);font-size:1.25rem;font-weight:700}

.quote-form{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:2rem;box-shadow:0 20px 50px rgba(0,0,0,.3)}
.quote-form h3{font-size:1.5rem}
.field{display:block;margin-top:1rem}
.field span{display:block;margin-bottom:.4rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground);font-weight:500}
.field input,.field select,.field textarea{width:100%;background:var(--input);border:1px solid var(--border);color:var(--foreground);border-radius:.5rem;padding:.75rem 1rem;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(214,168,90,.25)}
.field textarea{resize:none}
#quoteFields button{margin-top:1.5rem}
.success{text-align:center;padding:3rem 0}
.success-ic{width:3.5rem;height:3.5rem;border-radius:50%;background:rgba(214,168,90,.2);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 1rem}
.success h3{font-size:1.5rem}

/* Visit */
.info-stack{margin-top:2rem;display:flex;flex-direction:column;gap:1.5rem}
.info{display:flex;gap:1rem}
.info-ic{flex-shrink:0;width:2.75rem;height:2.75rem;border-radius:50%;background:rgba(214,168,90,.15);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.hours{list-style:none;margin-top:.25rem;display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}
.hours li{display:flex;justify-content:space-between;gap:1rem}
.map{border:1px solid var(--border);border-radius:1rem;overflow:hidden;min-height:420px}
.map iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* Footer */
.footer{border-top:1px solid var(--border);background:rgba(42,34,28,.3)}
.footer-inner{display:flex;flex-direction:column;gap:1.5rem;padding:2.5rem 1.5rem 6rem;align-items:flex-start;justify-content:space-between}
@media(min-width:768px){.footer-inner{flex-direction:row;align-items:center;padding-bottom:2.5rem}}

/* Mobile bar */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;border-top:1px solid var(--border);background:rgba(26,20,16,.95);backdrop-filter:blur(8px);padding:.75rem;display:flex;gap:.5rem}
.mobile-bar .btn{flex:1;padding:.85rem 1rem;font-size:.9rem}
@media(min-width:768px){.mobile-bar{display:none}}
