/* Forever Still Home — shared styles (masculine FSB: bronze on espresso, no sparkle) */
:root{
  --ink:#1a1410;
  --ink-2:#241b13;
  --ink-3:#2e231a;
  --brass:#c8a96a;
  --brass-deep:#a07d44;
  --bronze:#8a6233;
  --cream:#ece0c8;
  --cream-dim:#b3a282;
  --wood:#6b4f34;
  --line:rgba(200,169,106,.22);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',system-ui,sans-serif;color:var(--cream);background:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Cormorant',Georgia,serif;font-weight:700;line-height:1.08;letter-spacing:.01em}
h2{font-size:clamp(2rem,4.5vw,3.2rem);color:var(--cream)}
h3{font-size:1.5rem}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
[id]{scroll-margin-top:96px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass);font-weight:600}
.btn{display:inline-flex;align-items:center;gap:.5em;justify-content:center;font-weight:600;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;padding:15px 28px;border-radius:2px;cursor:pointer;border:1px solid transparent;transition:.18s ease;font-family:inherit}
.btn-gold{background:var(--brass);color:var(--ink);border-color:var(--brass)}
.btn-gold:hover{background:#d8bd84;border-color:#d8bd84}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}

/* Announcement bar */
.topbar{background:var(--ink-2);border-bottom:1px solid var(--line);font-size:.78rem;letter-spacing:.08em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:8px 22px;flex-wrap:wrap;gap:6px}
.topbar .tags{color:var(--cream-dim);text-transform:uppercase}
.topbar .tags b{color:var(--brass)}
.topbar a.phone{color:var(--cream);font-weight:600;letter-spacing:.05em}

/* Header */
header.nav{position:sticky;top:0;z-index:40;background:rgba(20,16,12,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:46px;height:46px;border-radius:50%}
.brand .bn{font-family:'Cormorant',serif;font-weight:700;font-size:1.35rem;color:var(--cream);line-height:1}
.brand .bs{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);white-space:nowrap}
nav.links{display:flex;gap:26px;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500}
nav.links a:hover,nav.links a.active{color:var(--brass)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .ph{font-weight:600;font-size:.9rem;color:var(--cream);white-space:nowrap}
.nav-cta .ph:hover{color:var(--brass)}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--cream);padding:8px 10px;border-radius:2px;cursor:pointer;font-size:1rem}

/* Home hero */
.hero{position:relative;min-height:86vh;display:flex;align-items:center;background:linear-gradient(180deg,rgba(20,16,12,.62),rgba(20,16,12,.72)),url('hero.jpg') center/cover no-repeat}
.hero .wrap{padding-top:60px;padding-bottom:60px}
.hero-inner{max-width:720px}
.hero h1{font-size:clamp(2.6rem,7vw,5rem);color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero p.sub{font-size:clamp(1rem,2vw,1.25rem);color:var(--cream);margin:22px 0 0;max-width:560px}
.hero .actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

/* Inner page hero */
.page-hero{position:relative;background:linear-gradient(180deg,rgba(20,16,12,.74),rgba(20,16,12,.86)),url('hero.jpg') center/cover no-repeat;padding:80px 0;text-align:center;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,3.8rem);color:#fff}
.page-hero p{color:var(--cream);max-width:600px;margin:16px auto 0}

/* Trust bar */
.trust{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 36px;padding:18px 22px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cream-dim);font-weight:600}
.trust span{display:flex;align-items:center;gap:8px}
.trust span::before{content:"✦";color:var(--brass)}

/* Sections */
section{padding:84px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 50px}
.sec-head p{color:var(--cream-dim);margin-top:14px}
.alt{background:var(--ink-2)}

/* Cards */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--ink-2);border:1px solid var(--line);border-radius:3px;padding:34px 28px;transition:.2s}
.card:hover{border-color:var(--brass);transform:translateY(-3px)}
.card .ico{font-size:1.7rem;margin-bottom:14px}
.card h3{color:var(--brass);margin-bottom:10px}
.card p{color:var(--cream-dim);font-size:.94rem}

/* Services grid */
.grid-serv{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.serv{background:var(--ink);border:1px solid var(--line);border-radius:3px;padding:30px 26px;display:flex;flex-direction:column}
.serv h3{color:var(--cream);margin-bottom:8px}
.serv p{color:var(--cream-dim);font-size:.9rem;flex:1}
.serv .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);margin-bottom:14px}

/* Service detail blocks */
.serv-detail{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center;padding:46px 0;border-bottom:1px solid var(--line)}
.serv-detail:last-child{border-bottom:none}
.serv-detail .body h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--cream)}
.serv-detail .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass)}
.serv-detail p{color:var(--cream-dim);margin-top:12px}
.serv-detail ul{list-style:none;margin:16px 0 22px;color:var(--cream-dim);font-size:.92rem}
.serv-detail ul li{padding:5px 0}
.serv-detail ul li::before{content:"▸ ";color:var(--brass)}
.serv-detail .panel{background:var(--ink-2);border:1px solid var(--line);border-radius:4px;min-height:230px;display:flex;align-items:center;justify-content:center;color:var(--wood);text-align:center;padding:24px;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem}

/* Care plan */
.care{background:linear-gradient(120deg,var(--ink-3),var(--ink));border:1px solid var(--brass);border-radius:4px;padding:54px 44px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center}
.care ul{list-style:none;margin:18px 0;columns:2;font-size:.9rem;color:var(--cream-dim)}
.care ul li{padding:4px 0}
.care ul li::before{content:"▸ ";color:var(--brass)}
.price-box{text-align:center;background:var(--ink-2);border:1px solid var(--line);border-radius:3px;padding:30px}
.price-box .big{font-family:'Cormorant',serif;font-size:3.4rem;color:var(--brass);font-weight:700;line-height:1}
.price-box small{color:var(--cream-dim);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem}

/* Gallery */
.gal-filter{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.gal-filter button{background:transparent;border:1px solid var(--line);color:var(--cream-dim);padding:9px 18px;border-radius:2px;cursor:pointer;font-family:inherit;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;transition:.18s}
.gal-filter button:hover,.gal-filter button.active{border-color:var(--brass);color:var(--brass)}
.grid-gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gal{aspect-ratio:4/3;background:var(--ink-2);border:1px solid var(--line);border-radius:3px;display:flex;align-items:center;justify-content:center;color:var(--wood);text-align:center;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:20px}
.case{background:var(--ink-2);border:1px solid var(--line);border-radius:4px;padding:34px;margin-top:30px}
.case h3{color:var(--brass);margin-bottom:6px}
.case .row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:18px}
.case .row h4{color:var(--cream);font-family:'Montserrat';font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.case .row p{color:var(--cream-dim);font-size:.9rem}

/* Testimonials */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
blockquote{background:var(--ink);border-left:3px solid var(--brass);padding:28px 30px;border-radius:0 3px 3px 0}
blockquote p{font-family:'Cormorant',serif;font-size:1.5rem;color:var(--cream);line-height:1.3}
blockquote cite{display:block;margin-top:14px;font-style:normal;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass)}

/* About */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:46px;align-items:start}
.about-grid .prose p{color:var(--cream-dim);margin-bottom:16px}
.about-grid .portrait{background:var(--ink-2);border:1px solid var(--line);border-radius:4px;min-height:360px;display:flex;align-items:center;justify-content:center;color:var(--wood);text-align:center;padding:24px;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem}
.cred-list{list-style:none;margin:0}
.cred-list li{padding:10px 0;border-bottom:1px solid var(--line);color:var(--cream-dim);font-size:.92rem;display:flex;gap:10px}
.cred-list li::before{content:"✔";color:var(--brass);font-weight:700}

/* CTA band */
.ctaband{background:linear-gradient(rgba(20,16,12,.8),rgba(20,16,12,.8)),url('hero.jpg') center/cover;text-align:center}
.ctaband h2{color:#fff}
.ctaband p{color:var(--cream);margin:14px 0 28px}
.ctaband .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Forms */
.formbox{max-width:640px;margin:0 auto;background:var(--ink-2);border:1px solid var(--line);border-radius:4px;padding:40px}
.formbox label{display:block;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-dim);margin:16px 0 6px}
.formbox input,.formbox select{width:100%;padding:13px 14px;background:var(--ink);border:1px solid var(--line);border-radius:2px;color:var(--cream);font-family:inherit;font-size:.95rem}
.formbox input:focus,.formbox select:focus{outline:none;border-color:var(--brass)}
.formbox .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.contact-info li{list-style:none;padding:12px 0;border-bottom:1px solid var(--line);color:var(--cream-dim)}
.contact-info li strong{display:block;color:var(--brass);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px}
.contact-info a:hover{color:var(--brass)}
.booking-inline{background:#fff;border:1px solid var(--brass);border-radius:4px;width:100%;height:560px;border:none}
.map-embed{margin-top:30px;background:var(--ink-2);border:1px solid var(--line);border-radius:4px;height:300px;display:flex;align-items:center;justify-content:center;color:var(--wood);letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;text-align:center;padding:20px}

/* Footer */
footer{background:#120e0a;border-top:1px solid var(--line);padding:56px 0 28px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
footer h4{font-family:'Cormorant',serif;color:var(--brass);font-size:1.3rem;margin-bottom:14px}
footer p,footer a{color:var(--cream-dim);font-size:.88rem;line-height:1.9}
footer a:hover{color:var(--brass)}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.foot-brand img{width:54px;height:54px;border-radius:50%}
.copy{text-align:center;border-top:1px solid var(--line);margin-top:40px;padding-top:22px;color:var(--wood);font-size:.78rem;letter-spacing:.06em}

/* Sticky mobile bar */
.mobilebar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--ink-2);border-top:1px solid var(--brass)}
.mobilebar a,.mobilebar button{flex:1;padding:16px;text-align:center;font-weight:700;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;border:none;cursor:pointer;font-family:inherit}
.mobilebar .call{background:var(--ink);color:var(--cream)}
.mobilebar .book{background:var(--brass);color:var(--ink)}

/* Booking modal */
.modal{position:fixed;inset:0;z-index:100;background:rgba(10,8,6,.86);display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-box{background:var(--ink);border:1px solid var(--brass);border-radius:5px;width:100%;max-width:880px;height:86vh;display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line)}
.modal-head .t{font-family:'Cormorant',serif;font-size:1.4rem;color:var(--brass)}
.modal-head button{background:none;border:none;color:var(--cream);font-size:1.6rem;cursor:pointer;line-height:1}
.modal iframe{flex:1;width:100%;border:none;background:#fff}

/* Responsive */
@media(max-width:860px){
  nav.links,.nav-cta .ph,.nav-cta .btn-gold{display:none}
  .menu-toggle{display:block}
  .grid3,.grid-serv,.grid-gal,.quotes,.fgrid,.about-grid,.contact-grid,.case .row{grid-template-columns:1fr}
  .serv-detail{grid-template-columns:1fr;gap:24px;padding:34px 0}
  .care{grid-template-columns:1fr;padding:36px 26px}
  .care ul{columns:1}
  .hero{min-height:78vh}
  body{padding-bottom:56px}
  .mobilebar{display:flex}
  .formbox .row{grid-template-columns:1fr}
  nav.links.show{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:16px;background:var(--ink-2);padding:20px 22px;border-bottom:1px solid var(--line);font-size:.95rem}
}

/* Serve WebP hero where supported; JPG fallback above stays for older browsers */
@supports (background: image-set(url('i.webp') type('image/webp'))){
  .hero{background:linear-gradient(180deg,rgba(20,16,12,.62),rgba(20,16,12,.72)),image-set(url('hero.webp') type('image/webp'),url('hero.jpg') type('image/jpeg')) center/cover no-repeat}
  .page-hero{background:linear-gradient(180deg,rgba(20,16,12,.74),rgba(20,16,12,.86)),image-set(url('hero.webp') type('image/webp'),url('hero.jpg') type('image/jpeg')) center/cover no-repeat}
  .ctaband{background:linear-gradient(rgba(20,16,12,.8),rgba(20,16,12,.8)),image-set(url('hero.webp') type('image/webp'),url('hero.jpg') type('image/jpeg')) center/cover}
}
