/* =========================================================================
   Bathhouse Flatiron — main.css
   Brutalist-luxe · moody · editorial. Mobile-first.
   ========================================================================= */

/* ---- Design tokens ---- */
:root{
	--bg:#0b0c0e;
	--bg-2:#121419;
	--bg-3:#1a1d24;
	--bg-4:#23272f;
	--line:rgba(237,232,223,.10);
	--line-2:rgba(237,232,223,.16);
	--bone:#ece7de;
	--bone-dim:#b7b2a8;
	--muted:#84817b;
	--ember:#c2603f;
	--ember-2:#d97a55;
	--cool:#6fa8bc;
	--maxw:1280px;
	--pad:clamp(20px,5vw,40px);
	--sec:clamp(60px,9vw,116px);
	--r:14px;
	--serif:"Fraunces",Georgia,"Times New Roman",serif;
	--sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
	--ease:cubic-bezier(.22,.61,.36,1);
	--bar-h:64px;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:84px}
body{
	font-family:var(--sans);
	background:var(--bg);
	color:var(--bone);
	line-height:1.65;
	font-size:16px;
	font-weight:400;
	-webkit-font-smoothing:antialiased;
	overflow-x:hidden;
}
body.has-bottom-bar{padding-bottom:var(--bar-h)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none;padding:0}
iframe{display:block}
::selection{background:var(--ember);color:#fff}

/* ---- Typography ---- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:-.01em}
.display{font-size:clamp(1.9rem,4.6vw,3.6rem);font-weight:480;line-height:1.04;letter-spacing:-.015em}
.display em{font-style:italic;color:var(--ember-2)}
.eyebrow{
	font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.22em;
	text-transform:uppercase;color:var(--ember);margin-bottom:1rem;
}
.eyebrow--light{color:var(--bone)}
p{color:var(--bone-dim)}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);width:100%}
.section{padding-block:var(--sec)}
.section--alt{background:var(--bg-2)}
.section--dark{background:#070809}
.section-head{max-width:680px;margin:0 auto clamp(2.4rem,5vw,4rem);text-align:center}
.section-head__sub{font-size:1.05rem;margin-top:.75rem}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.skip-link{position:fixed;top:-60px;left:8px;z-index:1000;background:var(--ember);color:#fff;padding:.6rem 1rem;border-radius:6px;transition:top .2s}
.skip-link:focus{top:8px}

/* ---- Buttons ---- */
.btn{
	display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
	font-family:var(--sans);font-weight:600;font-size:.86rem;letter-spacing:.04em;
	padding:.95rem 1.7rem;border-radius:100px;min-height:48px;
	transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
	white-space:nowrap;text-align:center;
}
.btn--accent{background:var(--ember);color:#fff}
.btn--accent:hover{background:var(--ember-2);transform:translateY(-2px)}
.btn--outline{border:1px solid var(--line-2);color:var(--bone)}
.btn--outline:hover{border-color:var(--bone);background:rgba(237,232,223,.06)}
.btn--ghost{color:var(--bone-dim)}
.btn--ghost:hover{color:var(--bone)}
.btn--lg{padding:1.1rem 2.1rem;font-size:.95rem}
.btn--block{display:flex;width:100%}
.link-arrow{display:inline-flex;align-items:center;gap:.4rem;color:var(--ember-2);font-weight:600;font-size:.92rem;transition:gap .3s var(--ease)}
.link-arrow:hover{gap:.8rem}

/* =========================================================================
   Header
   ========================================================================= */
.site-header{
	position:fixed;inset:0 0 auto 0;z-index:90;
	transition:background .4s var(--ease),backdrop-filter .4s var(--ease),box-shadow .4s var(--ease);
}
.site-header__inner{
	max-width:var(--maxw);margin-inline:auto;padding:1.1rem var(--pad);
	display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.site-header.is-scrolled{
	background:rgba(11,12,14,.82);backdrop-filter:blur(14px) saturate(140%);
	border-bottom:1px solid var(--line);box-shadow:0 10px 40px rgba(0,0,0,.4);
}
.brand__link{display:flex;flex-direction:column;line-height:1}
.brand__mark{font-family:var(--serif);font-weight:600;font-size:1.32rem;letter-spacing:.04em}
.brand__mark--lg{font-size:2rem}
.brand__sub{font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ember-2);margin-top:.32rem}
.custom-logo{max-height:52px;width:auto}

.nav__list{display:flex;gap:2rem;align-items:center}
.nav__link{font-size:.84rem;font-weight:500;letter-spacing:.04em;color:var(--bone-dim);position:relative;padding:.3rem 0;transition:color .3s}
.nav__link::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--ember);transition:width .3s var(--ease)}
.nav__link:hover{color:var(--bone)}
.nav__link:hover::after{width:100%}

.site-header__actions{display:flex;align-items:center;gap:1rem}
.site-header__phone{font-weight:600;font-size:.84rem}

.nav-toggle{display:none;width:46px;height:46px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--bone);transition:transform .3s var(--ease),opacity .3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav overlay */
.mobile-nav{position:fixed;inset:0;z-index:80;background:rgba(8,9,11,.97);backdrop-filter:blur(8px);opacity:0;transition:opacity .35s var(--ease);display:flex;align-items:center;justify-content:center}
.mobile-nav.is-open{opacity:1}
.mobile-nav[hidden]{display:none}
.mobile-nav__inner{text-align:center;padding:2rem;width:100%;max-width:420px}
.mobile-nav .nav__list{flex-direction:column;gap:1.4rem;margin-bottom:2.4rem}
.mobile-nav .nav__link{font-family:var(--serif);font-size:1.7rem;color:var(--bone)}
.mobile-nav__cta{display:flex;flex-direction:column;gap:.8rem}
.mobile-nav__hours{margin-top:1.6rem;font-size:.8rem;letter-spacing:.05em;color:var(--muted)}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;background:
	linear-gradient(180deg,rgba(8,9,11,.55) 0%,rgba(8,9,11,.25) 35%,rgba(8,9,11,.75) 100%),
	radial-gradient(120% 90% at 20% 90%,rgba(11,12,14,.85),transparent 60%);
}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto;padding:7rem var(--pad) 5rem;width:100%}
.hero__title{font-size:clamp(2.4rem,8.2vw,5.6rem);font-weight:480;line-height:.98;letter-spacing:-.02em;max-width:14ch}
.hero__title em{font-style:italic;color:var(--bone)}
.hero__lede{font-size:clamp(1rem,1.6vw,1.22rem);max-width:46ch;margin-top:1.6rem;color:var(--bone-dim)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;margin-top:2.8rem;border-top:1px solid var(--line);padding-top:1.6rem;max-width:560px}
.hero__meta li{font-size:.82rem;letter-spacing:.04em;color:var(--muted)}
.hero__meta strong{color:var(--bone);font-weight:600}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:1px solid var(--line-2);border-radius:14px;display:grid;place-items:start center;padding-top:7px}
.hero__scroll span{width:3px;height:8px;background:var(--bone);border-radius:2px;animation:scroll 1.7s var(--ease) infinite}
@keyframes scroll{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(12px)}}

/* =========================================================================
   Social proof strip
   ========================================================================= */
.proof{background:var(--bg-2);border-block:1px solid var(--line)}
.proof--page{border-top:0}
.proof__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding-block:1.4rem;flex-wrap:wrap}
.proof__rating{display:flex;align-items:center;gap:.7rem}
.proof__stars{color:var(--ember-2);letter-spacing:2px;font-size:1rem}
.proof__num{font-family:var(--serif);font-size:1.5rem;font-weight:600}
.proof__lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}
.proof__logos{display:flex;flex-wrap:wrap;gap:1.2rem 2.4rem;align-items:center}
.proof__logos li{font-family:var(--serif);font-size:1rem;letter-spacing:.02em;color:var(--bone-dim);opacity:.85}

/* =========================================================================
   Intro
   ========================================================================= */
.intro__grid{display:grid;grid-template-columns:1fr;gap:1.5rem 4rem}
.intro__lead .display{max-width:18ch}
.intro__body p+p{margin-top:1rem}
.intro__body p{font-size:1.06rem}

/* =========================================================================
   Cards (amenities)
   ========================================================================= */
.cards{display:grid;grid-template-columns:1fr;gap:1.4rem}
.card{
	background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
	transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 24px 60px rgba(0,0,0,.45)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card__media .card__img,.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__img{transform:scale(1.06)}
.card__temp{position:absolute;top:12px;left:12px;background:rgba(8,9,11,.66);backdrop-filter:blur(6px);border:1px solid var(--line-2);color:var(--bone);font-size:.7rem;font-weight:600;letter-spacing:.08em;padding:.35rem .7rem;border-radius:100px}
.card__body{padding:1.5rem 1.5rem 1.7rem}
.card__title{font-size:1.35rem;margin-bottom:.5rem}
.card__desc{font-size:.95rem}
.card__title a:hover{color:var(--ember-2)}

/* =========================================================================
   Stat band
   ========================================================================= */
.stats{background:var(--bg);border-block:1px solid var(--line);padding-block:clamp(2.4rem,5vw,3.6rem)}
.stats__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem 1rem;text-align:center}
.stat{display:flex;flex-direction:column;gap:.3rem}
.stat__num{font-family:var(--serif);font-size:clamp(2.2rem,6vw,3.4rem);font-weight:500;color:var(--bone);line-height:1}
.stat__lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}

/* =========================================================================
   Story
   ========================================================================= */
.story__grid{display:grid;grid-template-columns:1fr;gap:2.4rem;align-items:center}
.story__media{position:relative;border-radius:var(--r);overflow:hidden}
.story__media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.story__badge{position:absolute;left:14px;bottom:14px;background:rgba(8,9,11,.7);backdrop-filter:blur(6px);border:1px solid var(--line-2);font-size:.72rem;letter-spacing:.06em;padding:.45rem .8rem;border-radius:100px;color:var(--bone-dim)}
.story__body .display{margin-bottom:1.2rem;max-width:16ch}
.story__body p+p{margin-top:1rem}
.story__body .link-arrow{margin-top:1.4rem}

/* =========================================================================
   Circuit / steps
   ========================================================================= */
.steps{display:grid;grid-template-columns:1fr;gap:1.4rem;counter-reset:step}
.step{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.8rem;position:relative;transition:border-color .3s,transform .3s var(--ease)}
.step:hover{border-color:var(--ember);transform:translateY(-4px)}
.step__no{font-family:var(--serif);font-size:1rem;color:var(--ember-2);letter-spacing:.1em}
.step__title{font-size:1.6rem;margin:.6rem 0 .7rem}
.step p{font-size:.96rem}

/* =========================================================================
   Treatments menu
   ========================================================================= */
.treatments__grid{display:grid;grid-template-columns:1fr;gap:2.6rem}
.treatments__head .display{margin:.2rem 0 1rem}
.treatments__head p{margin-bottom:1.6rem;max-width:42ch}
.menu-list{display:flex;flex-direction:column}
.menu-item{padding:1.3rem 0;border-bottom:1px solid var(--line)}
.menu-item:first-child{padding-top:0}
.menu-item__main{display:flex;align-items:baseline;gap:.6rem}
.menu-item__name{font-family:var(--serif);font-size:1.24rem;color:var(--bone);white-space:nowrap}
.menu-item__dots{flex:1;border-bottom:1px dotted var(--line-2);transform:translateY(-4px)}
.menu-item__price{font-weight:600;color:var(--ember-2);white-space:nowrap}
.menu-item__desc{font-size:.92rem;margin-top:.45rem;max-width:52ch}

/* =========================================================================
   Quotes / testimonials
   ========================================================================= */
.quotes__grid{display:grid;grid-template-columns:1fr;gap:1.4rem}
.quote{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.9rem;display:flex;flex-direction:column;gap:1.4rem;transition:border-color .3s,transform .3s var(--ease)}
.quote:hover{border-color:var(--line-2);transform:translateY(-4px)}
.quote blockquote{font-family:var(--serif);font-size:1.18rem;line-height:1.45;color:var(--bone);font-weight:430}
.quote figcaption{display:flex;flex-direction:column;gap:.15rem;margin-top:auto}
.quote__name{font-weight:600;font-size:.92rem;color:var(--bone)}
.quote__role{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ember-2)}

/* =========================================================================
   Gallery masonry
   ========================================================================= */
.masonry{columns:2;column-gap:1rem}
.masonry__item{display:block;margin-bottom:1rem;border-radius:10px;overflow:hidden;break-inside:avoid;position:relative}
.masonry__img{width:100%;height:auto;transition:transform .6s var(--ease),filter .4s}
.masonry__item:hover .masonry__img{transform:scale(1.05);filter:brightness(1.06)}

/* =========================================================================
   FAQ accordion
   ========================================================================= */
.faq__grid{display:grid;grid-template-columns:1fr;gap:2.2rem}
.faq__head .display{margin:.2rem 0 1rem}
.accordion__item{border-bottom:1px solid var(--line)}
.accordion__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 0;text-align:left;font-family:var(--serif);font-size:1.12rem;color:var(--bone)}
.accordion__icon{position:relative;flex:0 0 18px;height:18px}
.accordion__icon::before,.accordion__icon::after{content:"";position:absolute;background:var(--ember-2);transition:transform .3s var(--ease)}
.accordion__icon::before{top:8px;left:0;width:18px;height:2px}
.accordion__icon::after{left:8px;top:0;width:2px;height:18px}
.accordion__q[aria-expanded="true"] .accordion__icon::after{transform:scaleY(0)}
.accordion__a{overflow:hidden;max-height:0;transition:max-height .4s var(--ease)}
.accordion__a p{padding:0 0 1.3rem;max-width:60ch;font-size:.96rem}

/* =========================================================================
   Visit / location + map
   ========================================================================= */
.visit__grid{display:grid;grid-template-columns:1fr;gap:2.4rem;align-items:stretch}
.visit__address{font-family:var(--serif);font-style:normal;font-size:1.5rem;line-height:1.3;color:var(--bone);margin:.4rem 0 1.6rem}
.visit__details{display:grid;gap:1rem;margin-bottom:1.8rem}
.visit__details>div{display:grid;grid-template-columns:90px 1fr;gap:1rem;border-top:1px solid var(--line);padding-top:1rem}
.visit__details dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.visit__details dd{color:var(--bone-dim);font-size:.95rem}
.visit__details a:hover{color:var(--ember-2)}
.visit__actions{display:flex;flex-wrap:wrap;gap:.8rem}
.visit__map{min-height:340px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.visit__map iframe{width:100%;height:100%;min-height:340px;filter:grayscale(.3) contrast(1.05) brightness(.92)}
.visit__map--wide{margin-top:2rem;height:420px}

/* Contact form */
.contact-form{display:flex;flex-direction:column;gap:1rem;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem}
.contact-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.contact-form input,.contact-form textarea{background:var(--bg);border:1px solid var(--line-2);border-radius:8px;padding:.8rem;color:var(--bone);font-family:inherit;font-size:1rem;min-height:48px}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--ember)}
.contact-form__note{font-size:.78rem;color:var(--muted);text-transform:none;letter-spacing:0}
.contact-form__note a{color:var(--ember-2)}

/* =========================================================================
   Final CTA
   ========================================================================= */
.cta-final{position:relative;overflow:hidden;text-align:center;padding-block:clamp(4rem,10vw,7rem)}
.cta-final__media{position:absolute;inset:0;z-index:0}
.cta-final__media img{width:100%;height:100%;object-fit:cover}
.cta-final__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,11,.78),rgba(8,9,11,.86))}
.cta-final__inner{position:relative;z-index:2}
.cta-final__title{font-size:clamp(2rem,6vw,3.6rem);font-weight:480}
.cta-final__sub{max-width:46ch;margin:1rem auto 2rem;font-size:1.05rem}

/* =========================================================================
   Page hero (inner pages)
   ========================================================================= */
.page-hero{padding:9rem var(--pad) 3rem;position:relative;background:var(--bg-2);border-bottom:1px solid var(--line)}
.page-hero .wrap{padding-inline:0}
.page-hero--img{padding-block:11rem 3rem;background:#000;overflow:hidden}
.page-hero__media{position:absolute;inset:0;z-index:0}
.page-hero__media img{width:100%;height:100%;object-fit:cover}
.page-hero--img .wrap{position:relative;z-index:2}
.page-hero__title{margin-top:.6rem}
.page-hero__sub{margin-top:1rem;font-size:1.1rem;max-width:52ch}
.crumbs{display:flex;gap:.6rem;align-items:center;font-size:.8rem;color:var(--muted);letter-spacing:.04em}
.crumbs a:hover{color:var(--ember-2)}
.crumbs--light{color:var(--bone-dim)}

/* Prose (Privacy/Terms/content) */
.prose{max-width:760px;margin-inline:auto}
.prose h2{font-size:1.7rem;margin:2.2rem 0 .9rem}
.prose h3{font-size:1.3rem;margin:1.8rem 0 .7rem}
.prose p,.prose li{color:var(--bone-dim);font-size:1.02rem}
.prose p,.prose ul,.prose ol{margin-bottom:1.1rem}
.prose ul,.prose ol{padding-left:1.3rem}
.prose ul{list-style:disc}.prose ol{list-style:decimal}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--ember-2);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--bone)}
.contact-form-wrap .prose{margin:0 0 1.5rem}

.pagination{margin-top:3rem;display:flex;justify-content:center}
.pagination .page-numbers{padding:.5rem .9rem;border:1px solid var(--line);border-radius:8px;margin:0 .2rem}
.pagination .current{background:var(--ember);color:#fff;border-color:var(--ember)}

/* =========================================================================
   Footer
   ========================================================================= */
.site-footer{background:#070809;border-top:1px solid var(--line);padding:clamp(3rem,6vw,5rem) 0 2rem}
.footer__top{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);display:grid;grid-template-columns:1fr;gap:2.6rem}
.footer__tag{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--bone-dim);margin:.8rem 0 1.2rem;max-width:24ch}
.footer__social{display:flex;flex-wrap:wrap;gap:1rem}
.footer__social-link{font-size:.82rem;color:var(--muted);transition:color .3s}
.footer__social-link:hover{color:var(--ember-2)}
.footer__h{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--bone);margin-bottom:1rem;font-family:var(--sans);font-weight:600}
.footer__col ul li{margin-bottom:.6rem}
.footer__col a,.footer__col p{color:var(--bone-dim);font-size:.92rem;transition:color .3s}
.footer__col a:hover{color:var(--ember-2)}
.footer__address{font-style:normal;line-height:1.8;font-size:.92rem;color:var(--bone-dim)}
.footer__hours{margin-top:.8rem;font-size:.82rem;color:var(--muted)}
.footer__col--cta p{margin-bottom:1rem;max-width:30ch}
.footer__col--cta .btn{margin-bottom:.7rem}
.footer__bottom{max-width:var(--maxw);margin:2.6rem auto 0;padding:1.6rem var(--pad) 0;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}
.footer__bottom p{font-size:.78rem;color:var(--muted)}
.footer__legal{display:flex;gap:1.4rem}
.footer__legal a{font-size:.78rem;color:var(--muted);transition:color .3s}
.footer__legal a:hover{color:var(--bone)}

/* =========================================================================
   Mobile fixed bottom action bar
   ========================================================================= */
.bottom-bar{position:fixed;left:0;right:0;bottom:0;z-index:95;height:var(--bar-h);display:none;background:var(--bg-2);border-top:1px solid var(--line-2)}
.bottom-bar__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--bone-dim);font-size:10px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;border-right:1px solid var(--line)}
.bottom-bar__item:last-child{border-right:0}
.bottom-bar__ico{font-size:20px;line-height:1}
.bottom-bar__item--cta{background:var(--ember);color:#fff}
.bottom-bar__item:active{background:rgba(255,255,255,.06)}
.bottom-bar__item--cta:active{background:var(--ember-2)}

/* =========================================================================
   Responsive
   ========================================================================= */
@media(min-width:681px){
	.cards{grid-template-columns:repeat(2,1fr)}
	.quotes__grid{grid-template-columns:repeat(2,1fr)}
	.steps{grid-template-columns:repeat(3,1fr)}
	.stats__grid{grid-template-columns:repeat(5,1fr)}
	.masonry{columns:3}
	.footer__top{grid-template-columns:1.6fr 1fr 1fr 1.4fr}
}
@media(min-width:901px){
	.intro__grid{grid-template-columns:1fr 1fr;align-items:end}
	.story__grid{grid-template-columns:1fr 1fr;gap:4rem}
	.treatments__grid{grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:start}
	.treatments__head{position:sticky;top:100px}
	.faq__grid{grid-template-columns:.8fr 1.2fr;gap:4rem}
	.faq__head{position:sticky;top:100px;align-self:start}
	.visit__grid{grid-template-columns:1fr 1.1fr}
	.cards{grid-template-columns:repeat(3,1fr)}
	.quotes__grid{grid-template-columns:repeat(3,1fr)}
	.masonry{columns:4}
}
@media(max-width:900px){
	.nav,.site-header__phone,.site-header .btn--accent{display:none}
	.nav-toggle{display:flex}
	.bottom-bar{display:flex}
}
@media(max-width:680px){
	:root{--sec:clamp(48px,11vw,60px)}
	.hero__title{font-size:clamp(2.3rem,11vw,3rem)}
	.hero__inner{padding-top:6rem}
	.hero__actions .btn{flex:1}
	.proof__inner{justify-content:center;text-align:center}
	.footer__bottom{flex-direction:column;text-align:center}
}

@media(prefers-reduced-motion:reduce){
	*{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
