/* Detail By Design — shared styles (dark luxury automotive) */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root{
  --bg:#0a0a0c; --bg-2:#101015; --panel:#15151b; --panel-2:#1b1b22;
  --white:#f4f3f1; --soft:#cbcace; --muted:#8b8b93; --faint:#6a6a72;
  --hair:rgba(255,255,255,0.12); --hair-soft:rgba(255,255,255,0.07);
  --silver:#dadce1; --silver-2:#a9adb5;
  --serif:"Cormorant Garamond","EB Garamond",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --max:1240px; --pad:clamp(20px,5vw,64px);
}
html{ scroll-behavior:smooth; }
body{ font-family:var(--sans); font-weight:400; font-size:17px; line-height:1.65; color:var(--soft); background:var(--bg); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
.container,.wrap{ max-width:var(--max); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }

.eyebrow,.kicker{ font-family:var(--sans); font-size:12px; font-weight:500; letter-spacing:0.28em; text-transform:uppercase; }
.chrome,.accent{ background:linear-gradient(180deg,#ffffff 0%,#cdd0d6 52%,#83878f 100%); -webkit-background-clip:text; background-clip:text; color:transparent; }
h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.06; letter-spacing:0.005em; color:var(--white); }
h1{ font-size:clamp(44px,7vw,92px); }
h2{ font-size:clamp(32px,4.4vw,58px); }
h3{ font-size:clamp(21px,2.2vw,27px); font-weight:600; }
p.lede{ font-size:clamp(17px,1.4vw,19.5px); color:var(--soft); line-height:1.62; }

/* skip + a11y */
.skip-link{ position:absolute; left:-9999px; top:0; background:#fff; color:#000; padding:10px 16px; z-index:200; }
.skip-link:focus{ left:12px; top:12px; }
:focus-visible{ outline:2px solid var(--silver); outline-offset:3px; border-radius:2px; }
@media (prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; } html{ scroll-behavior:auto; } }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--sans); font-size:12.5px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; border-radius:999px; transition:all .2s ease; white-space:nowrap; cursor:pointer; }
.btn svg{ width:14px; height:14px; }
.btn-primary,.btn-book{ padding:15px 28px; background:var(--white); color:#0a0a0c; border:1px solid var(--white); }
.btn-primary:hover,.btn-book:hover{ background:transparent; color:#fff; }
.btn-ghost{ padding:15px 28px; background:transparent; color:var(--white); border:1px solid var(--hair); }
.btn-ghost:hover{ border-color:var(--silver); background:rgba(255,255,255,0.04); }
.btn-outline{ padding:13px 24px; background:transparent; color:var(--white); border:1px solid var(--silver-2); }
.btn-outline:hover{ background:rgba(255,255,255,0.05); }

/* topbar */
.topbar{ font-family:var(--sans); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); background:#070708; border-bottom:1px solid var(--hair-soft); }
.topbar-inner{ display:flex; justify-content:space-between; align-items:center; padding:10px 0; }
.topbar-text{ display:flex; align-items:center; gap:0; flex-wrap:wrap; }
.topbar-divider{ display:inline-block; width:1px; height:11px; background:var(--hair); margin:0 14px; }
.topbar-phone{ color:var(--soft); font-weight:500; }
.topbar-phone:hover{ color:#fff; }
@media (max-width:680px){ .topbar .topbar-hide{ display:none; } .topbar-inner{ justify-content:center; } .topbar-phone{ display:none; } }

/* nav */
.nav{ position:sticky; top:0; z-index:60; border-bottom:1px solid var(--hair-soft); background:rgba(10,10,12,0.82); backdrop-filter:saturate(150%) blur(14px); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:22px; padding:15px 0; }
.brand{ display:flex; align-items:center; gap:13px; }
.brand img.mark{ height:34px; width:auto; }
.brand img.word{ height:17px; width:auto; opacity:0.96; }
.nav-links{ display:flex; align-items:center; gap:30px; font-size:13px; font-weight:500; letter-spacing:0.04em; color:var(--soft); text-transform:uppercase; }
.nav-links a:not(.btn){ position:relative; padding:4px 0; }
.nav-links a:not(.btn)::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--silver); transition:width .25s ease; }
.nav-links a:not(.btn):hover{ color:#fff; }
.nav-links a:not(.btn):hover::after,.nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:#fff; }
.nav-phone{ display:inline-flex; flex-direction:column; line-height:1.1; font-size:13px; }
.nav-phone span{ font-size:9.5px; letter-spacing:0.18em; color:var(--muted); }
.menu-toggle{ display:none; background:none; border:0; color:var(--white); cursor:pointer; padding:6px; }
.menu-toggle svg{ width:26px; height:26px; }
@media (max-width:980px){ .nav-links{ display:none; } .menu-toggle{ display:inline-flex; } }
@media (max-width:520px){ .brand img.word{ display:none; } }
.mobile-menu{ display:none; border-bottom:1px solid var(--hair-soft); background:#0c0c0f; }
.mobile-menu.open{ display:block; }
.mobile-menu .container{ display:flex; flex-direction:column; padding:8px 0 22px; }
.mobile-menu a{ padding:14px 0; font-size:14px; letter-spacing:0.06em; text-transform:uppercase; color:var(--soft); border-bottom:1px solid var(--hair-soft); }
.mobile-menu a:last-child{ border-bottom:0; }

/* breadcrumbs */
.breadcrumbs{ border-bottom:1px solid var(--hair-soft); background:var(--bg); }
.breadcrumbs-inner{ display:flex; align-items:center; gap:10px; padding:14px 0; font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); }
.breadcrumbs a:hover{ color:#fff; }
.breadcrumbs [aria-current]{ color:var(--silver-2); }

/* hero (home) */
.hero{ padding-top:clamp(54px,8vw,104px); padding-bottom:clamp(54px,8vw,104px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(40px,6vw,84px); align-items:center; }
.hero .eyebrow{ display:block; margin-bottom:24px; }
.hero h1{ margin-bottom:26px; }
.hero h1 em{ font-style:italic; font-weight:400; }
.hero p.lede{ max-width:480px; margin-bottom:34px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-meta{ margin-top:38px; display:flex; gap:26px; flex-wrap:wrap; font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
.hero-meta span{ display:inline-flex; align-items:center; gap:9px; }
.hero-meta .dot{ width:4px; height:4px; background:var(--silver); border-radius:50%; }
.hero-img{ position:relative; border-radius:3px; overflow:hidden; box-shadow:0 40px 80px -36px rgba(0,0,0,0.9); }
.hero-img img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.hero-img::before{ content:""; position:absolute; top:-13px; left:-13px; width:62px; height:62px; border-top:1px solid var(--silver-2); border-left:1px solid var(--silver-2); z-index:2; }
.hero-img::after{ content:""; position:absolute; bottom:-13px; right:-13px; width:62px; height:62px; border-bottom:1px solid var(--silver-2); border-right:1px solid var(--silver-2); z-index:2; }
@media (max-width:880px){ .hero-grid{ grid-template-columns:1fr; gap:46px; } .hero-img{ order:-1; max-width:520px; } }

/* page hero (subpages) */
.page-hero{ padding-top:clamp(56px,7vw,96px); padding-bottom:clamp(40px,5vw,64px); border-bottom:1px solid var(--hair-soft); }
.page-hero .eyebrow{ display:block; margin-bottom:20px; }
.page-hero h1{ font-size:clamp(40px,5.6vw,74px); margin-bottom:22px; max-width:14ch; }
.page-hero-sub{ font-size:clamp(17px,1.5vw,20px); color:var(--soft); max-width:620px; margin-bottom:30px; }

/* trust */
.trust{ border-top:1px solid var(--hair-soft); border-bottom:1px solid var(--hair-soft); background:var(--bg-2); padding:34px 0; }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.trust-item{ display:flex; align-items:center; gap:14px; justify-content:center; }
.trust-item svg{ width:30px; height:30px; color:var(--silver); flex:0 0 auto; stroke-width:1.3; }
.trust-item .t-label{ font-size:12.5px; letter-spacing:0.04em; line-height:1.35; color:var(--soft); }
.trust-item .t-label strong{ display:block; color:#fff; font-weight:600; }
@media (max-width:820px){ .trust-grid{ grid-template-columns:repeat(2,1fr); gap:26px 18px; } }

/* sections */
.section{ padding-top:clamp(66px,8vw,118px); padding-bottom:clamp(66px,8vw,118px); }
.section.alt{ background:var(--bg-2); }
.section-head{ max-width:760px; margin-bottom:clamp(42px,5vw,68px); }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head .kicker,.section-head .eyebrow{ display:block; margin-bottom:18px; color:var(--silver-2); }
.section-head h2{ margin-bottom:18px; }
.section-head p,.section-sub{ color:var(--soft); font-size:18px; line-height:1.6; max-width:600px; }
.section-head.center p{ margin-left:auto; margin-right:auto; }
.section-foot{ margin-top:42px; text-align:center; }

/* services grid */
.services-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--hair-soft); border:1px solid var(--hair-soft); }
.svc{ background:var(--panel); padding:42px 36px; display:flex; flex-direction:column; gap:16px; min-height:268px; transition:background .25s ease; }
.svc:hover{ background:var(--panel-2); }
.svc-icon{ width:38px; height:38px; color:var(--silver); stroke-width:1.2; }
.svc h3{ color:#fff; }
.svc p{ color:var(--muted); font-size:15.5px; line-height:1.6; flex:1; }
.svc .svc-cta{ font-size:11.5px; letter-spacing:0.18em; text-transform:uppercase; font-weight:600; color:var(--white); display:inline-flex; align-items:center; gap:8px; align-self:flex-start; border-bottom:1px solid var(--silver-2); padding-bottom:4px; transition:gap .2s ease,color .2s ease; }
.svc .svc-cta:hover{ gap:13px; color:var(--silver); }
@media (max-width:900px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .services-grid{ grid-template-columns:1fr; } .svc{ min-height:0; padding:34px 28px; } }

/* feature (ceramic) */
.feature-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,72px); align-items:center; }
.feature-img{ position:relative; border-radius:3px; overflow:hidden; box-shadow:0 36px 70px -34px rgba(0,0,0,0.85); }
.feature-img img{ width:100%; aspect-ratio:3/2; object-fit:cover; }
.feature-text .eyebrow{ display:block; margin-bottom:18px; color:var(--silver-2); }
.feature-text h2{ margin-bottom:18px; }
.feature-text p{ color:var(--soft); margin-bottom:24px; max-width:520px; }
.inc-list{ display:grid; grid-template-columns:1fr 1fr; gap:11px 22px; margin-bottom:26px; }
.inc-list li{ list-style:none; display:flex; align-items:flex-start; gap:10px; font-size:14.5px; color:var(--soft); }
.inc-list svg{ width:16px; height:16px; color:var(--silver); flex:0 0 auto; margin-top:3px; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:30px; }
.chip{ font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--silver-2); border:1px solid var(--hair); border-radius:999px; padding:7px 13px; }
.feature-note{ font-size:13px; color:var(--faint); margin-top:18px; }
@media (max-width:880px){ .feature-grid{ grid-template-columns:1fr; gap:42px; } .inc-list{ grid-template-columns:1fr; } }

/* gallery */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.tile{ position:relative; border-radius:3px; overflow:hidden; background:var(--panel); }
.tile img{ width:100%; aspect-ratio:4/5; object-fit:cover; transition:transform .6s ease; }
.tile:hover img{ transform:scale(1.04); }
.tile::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,0.6)); }
.tile .cap{ position:absolute; left:16px; bottom:14px; z-index:2; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:#fff; font-weight:500; }
@media (max-width:760px){ .gallery-grid{ grid-template-columns:repeat(2,1fr); gap:12px; } }

/* steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; list-style:none; counter-reset:step; }
.step{ background:var(--panel); border:1px solid var(--hair-soft); border-radius:4px; padding:36px 32px; }
.step-num{ font-family:var(--serif); font-size:30px; color:var(--silver-2); display:block; margin-bottom:14px; }
.step h3{ margin-bottom:10px; }
.step p{ color:var(--muted); font-size:15px; }
@media (max-width:820px){ .steps{ grid-template-columns:1fr; gap:16px; } }

/* about */
.about-grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(40px,6vw,80px); align-items:center; }
.about-img{ border-radius:3px; overflow:hidden; box-shadow:0 36px 70px -34px rgba(0,0,0,0.85); }
.about-img img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.about-text .eyebrow{ display:block; margin-bottom:18px; color:var(--silver-2); }
.about-text h2{ margin-bottom:26px; }
.about-text p{ color:var(--soft); margin-bottom:18px; line-height:1.72; font-size:16.5px; }
.about-text p:last-of-type{ margin-bottom:0; }
.signature{ margin-top:30px; font-family:var(--serif); font-style:italic; font-size:19px; color:#fff; display:flex; align-items:center; gap:13px; }
.signature .rule{ width:34px; height:1px; background:var(--silver); flex:0 0 34px; }
.about-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.about-stat{ background:var(--panel); border:1px solid var(--hair-soft); border-radius:4px; padding:26px 20px; text-align:center; }
.about-stat .why-stat{ font-family:var(--serif); font-size:40px; color:#fff; line-height:1; }
.about-stat .why-stat sup{ font-size:18px; color:var(--silver-2); }
.about-stat-label{ font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); margin-top:10px; }
@media (max-width:880px){ .about-grid{ grid-template-columns:1fr; gap:42px; } .about-img{ max-width:460px; } }

/* quote / single testimonial */
.quote{ background:var(--bg-2); border-top:1px solid var(--hair-soft); border-bottom:1px solid var(--hair-soft); }
.quote .container{ padding-top:clamp(60px,8vw,100px); padding-bottom:clamp(60px,8vw,100px); text-align:center; max-width:920px; }
.quote .stars{ display:inline-flex; gap:4px; color:var(--silver); margin-bottom:26px; }
.quote .stars svg{ width:18px; height:18px; }
.quote blockquote{ font-family:var(--serif); font-size:clamp(25px,3.2vw,38px); line-height:1.32; color:#fff; font-weight:500; }
.quote .attr{ margin-top:28px; font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }

/* review grid (reviews page) */
.review-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.review-card{ background:var(--panel); border:1px solid var(--hair-soft); border-radius:6px; padding:30px 28px; display:flex; flex-direction:column; gap:16px; }
.review-card .review-stars{ color:var(--silver); letter-spacing:3px; font-size:15px; }
.review-card p{ font-family:var(--serif); font-style:italic; font-size:18px; line-height:1.5; color:var(--white); flex:1; }
.review-meta{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); border-top:1px solid var(--hair-soft); padding-top:14px; }
.review-meta strong{ color:#fff; font-weight:600; }
@media (max-width:900px){ .review-grid{ grid-template-columns:1fr; } }

/* service areas */
.area-map{ border-radius:3px; overflow:hidden; border:1px solid var(--hair); filter:grayscale(0.3) brightness(0.85); }
.area-map iframe{ display:block; }
.map-credit{ display:inline-block; margin-top:14px; font-size:12px; letter-spacing:0.06em; color:var(--silver-2); }
.map-credit:hover{ color:#fff; }
.area-columns{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.area-col-title{ font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--silver-2); margin-bottom:16px; }
.area-list{ list-style:none; display:flex; flex-direction:column; gap:9px; }
.area-list li{ color:var(--soft); font-size:15.5px; padding-left:18px; position:relative; }
.area-list li::before{ content:""; position:absolute; left:0; top:9px; width:5px; height:5px; background:var(--silver-2); border-radius:50%; }
.area-note{ margin-top:18px; color:var(--muted); font-size:14px; }
.area-note a{ color:var(--silver); }
@media (max-width:820px){ .area-columns{ grid-template-columns:1fr 1fr; gap:26px; } }
@media (max-width:520px){ .area-columns{ grid-template-columns:1fr; } }

/* club */
.club-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,72px); align-items:center; }
.club-img{ border-radius:3px; overflow:hidden; box-shadow:0 36px 70px -34px rgba(0,0,0,0.85); }
.club-img img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.club-text .eyebrow{ display:block; margin-bottom:18px; color:var(--silver-2); }
.club-text h2{ margin-bottom:20px; }
.club-text p{ color:var(--soft); margin-bottom:22px; max-width:520px; }
.club-points{ display:flex; flex-direction:column; gap:13px; margin-bottom:30px; list-style:none; }
.club-points li{ display:flex; align-items:flex-start; gap:11px; font-size:15px; color:var(--soft); }
.club-points svg{ width:17px; height:17px; color:var(--silver); flex:0 0 auto; margin-top:3px; }
@media (max-width:880px){ .club-grid{ grid-template-columns:1fr; gap:40px; } .club-img{ order:-1; max-width:520px; } }

/* booking / contact */
.book-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,70px); align-items:stretch; }
.book-info{ display:flex; flex-direction:column; gap:30px; }
.info-row{ display:flex; flex-direction:column; gap:8px; }
.info-row .label{ font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--silver-2); font-weight:500; }
.info-row .body{ font-family:var(--serif); font-size:22px; line-height:1.4; color:#fff; font-weight:500; }
.info-row a.body:hover{ color:var(--silver); }
.book-info .btn-book{ align-self:flex-start; margin-top:6px; }
.map-frame{ border-radius:3px; overflow:hidden; border:1px solid var(--hair); min-height:420px; position:relative; filter:grayscale(0.3) brightness(0.85); }
.map-frame iframe{ width:100%; height:100%; min-height:420px; border:0; display:block; }
.map-link{ position:absolute; bottom:12px; right:12px; background:rgba(255,255,255,0.92); color:#0a0a0c; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; padding:9px 16px; border-radius:999px; font-weight:600; }
@media (max-width:880px){ .book-grid{ grid-template-columns:1fr; gap:40px; } }

/* contact cards */
.contact-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.contact-card{ background:var(--panel); border:1px solid var(--hair-soft); border-radius:6px; padding:36px 30px; display:flex; flex-direction:column; gap:14px; }
.contact-card-icon{ width:44px; height:44px; border-radius:50%; border:1px solid var(--hair); display:grid; place-items:center; color:var(--silver); }
.contact-card-icon svg{ width:20px; height:20px; }
.contact-card h3{ color:#fff; }
.contact-card p{ color:var(--muted); font-size:15px; }
.contact-phone-num{ font-family:var(--serif); font-size:26px; color:#fff; }
.contact-phone-num:hover{ color:var(--silver); }
.contact-hours{ list-style:none; display:flex; flex-direction:column; gap:8px; margin-top:4px; }
.contact-hours li{ display:flex; justify-content:space-between; font-size:14px; color:var(--soft); border-bottom:1px solid var(--hair-soft); padding-bottom:8px; }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }

/* cta band */
.cta{ position:relative; padding:clamp(80px,11vw,150px) 0; text-align:center; overflow:hidden; }
.cta .cta-bg{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0.34; }
.cta .cta-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,10,12,0.78),rgba(10,10,12,0.92)); }
.cta .container{ position:relative; z-index:2; }
.cta img.tagline{ width:min(540px,86%); margin:0 auto 14px; opacity:0.96; }
.cta p{ color:var(--soft); font-size:18px; margin-bottom:32px; }
.cta .hero-cta{ justify-content:center; }

/* footer */
footer{ background:#070708; color:var(--muted); padding-top:64px; padding-bottom:30px; font-family:var(--sans); font-size:14px; border-top:1px solid var(--hair-soft); }
.foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:44px; padding-bottom:48px; border-bottom:1px solid var(--hair-soft); }
.foot-brand img.mark{ height:40px; margin-bottom:18px; }
.foot-brand p{ color:var(--faint); font-size:14px; line-height:1.6; max-width:320px; }
.foot-col h4{ font-size:11px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--silver-2); margin-bottom:18px; }
.foot-col ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ padding-top:26px; display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--faint); }
.foot-bottom .credit a{ color:var(--silver-2); }
.foot-bottom .credit a:hover{ color:#fff; }
@media (max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:34px; } }
@media (max-width:520px){ .foot-grid{ grid-template-columns:1fr; } .foot-bottom{ flex-direction:column; gap:14px; text-align:center; } }

/* sticky mobile call */
.sticky-call{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:80; background:var(--white); color:#0a0a0c; text-align:center; padding:15px; font-size:13px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; }
@media (max-width:760px){ .sticky-call{ display:block; } body{ padding-bottom:52px; } }

/* ---- motion (progressive: only hides when html.js present) ---- */
html.js [data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); transition-delay:var(--rd,0ms); }
html.js [data-reveal].is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ html.js [data-reveal]{ opacity:1!important; transform:none!important; transition:none!important; } html{ scroll-behavior:auto; } }
.hero-img{ will-change:transform; }

/* standalone eyebrow color */
.eyebrow{ color:var(--silver-2); }

/* service cards as links */
a.svc{ text-decoration:none; cursor:pointer; }
a.svc .svc-cta{ pointer-events:none; }

/* gloss reveal — stylized ceramic demo (hover), not a fabricated before/after */
.feature-img.gloss{ position:relative; }
.feature-img.gloss img{ filter:saturate(.55) brightness(.8) contrast(.96); transition:filter .8s cubic-bezier(.16,1,.3,1); }
.feature-img.gloss:hover img, .feature-img.gloss:focus-within img{ filter:saturate(1.15) brightness(1.06) contrast(1.06); }
.gloss-tag{ position:absolute; left:14px; bottom:14px; z-index:2; font-size:10.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--white); background:rgba(10,10,14,0.6); border:1px solid var(--hair); padding:7px 12px; border-radius:999px; backdrop-filter:blur(6px); }

/* single-column include list (service pages) */
.inc-list.inc-1col{ grid-template-columns:1fr; gap:13px; }

/* FAQ accordion */
.faq-wrap{ max-width:880px; }
.faq-list{ border-top:1px solid var(--hair-soft); }
.faq{ border-bottom:1px solid var(--hair-soft); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 2px; font-family:var(--serif); font-size:clamp(19px,2vw,23px); color:var(--white); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--sans); font-size:22px; font-weight:300; color:var(--silver-2); transition:transform .3s ease; flex:0 0 auto; }
.faq[open] summary::after{ transform:rotate(45deg); }
.faq-a{ padding:0 2px 24px; }
.faq-a p{ color:var(--muted); font-size:16px; line-height:1.65; max-width:72ch; }

/* big quote (reviews page) */
.big-quote{ text-align:center; max-width:880px; margin:0 auto; }
.big-quote .stars{ display:inline-flex; gap:4px; color:var(--silver); margin-bottom:24px; }
.big-quote .stars svg{ width:18px; height:18px; }
.big-quote blockquote{ font-family:var(--serif); font-size:clamp(25px,3.4vw,40px); line-height:1.32; color:#fff; }
.big-quote .attr{ margin-top:24px; font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }

/* town pages */
.town-links{ display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.town-link{ font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:var(--silver-2); border:1px solid var(--hair); border-radius:999px; padding:11px 20px; transition:all .2s ease; }
.town-link:hover{ color:#fff; border-color:var(--silver); background:rgba(255,255,255,0.04); }
.town-grid{ display:grid; grid-template-columns:1.5fr 1fr; gap:clamp(36px,5vw,64px); align-items:start; }
.town-copy p{ color:var(--soft); font-size:17px; line-height:1.72; margin-bottom:18px; max-width:62ch; }
.town-side{ background:var(--panel); border:1px solid var(--hair-soft); border-radius:6px; padding:32px 28px; }
.chip.chip-link{ transition:all .2s ease; }
a.chip.chip-link:hover{ color:#fff; border-color:var(--silver); }
@media (max-width:820px){ .town-grid{ grid-template-columns:1fr; gap:32px; } }
