:root{
  --ink:#15202e;--navy:#2e3e57;--navy-700:#243149;
  --water:#0e8ea3;--water-deep:#0a6a7a;--water-soft:#dff0f2;
  --sand:#f5eee2;--cream:#fcf8f1;--sun:#dd8f43;--sun-soft:#f0c89a;
  --line:#e7ddcc;--muted:#5d6675;--white:#fff;
  --shadow:0 24px 60px -28px rgba(21,32,46,.45);
  --shadow-sm:0 12px 30px -18px rgba(21,32,46,.4);
  --display:'Bricolage Grotesque',Georgia,serif;
  --ui:'Manrope',system-ui,sans-serif;
  --body:'Open Sans',system-ui,sans-serif;
  --wrap:1220px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.7;overflow-x:hidden;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
h1{font-family:var(--display);font-weight:800;line-height:.98;letter-spacing:-.03em}
h2{font-family:var(--display);font-weight:700;line-height:1.03;letter-spacing:-.022em;font-size:clamp(2rem,4.6vw,3.4rem);color:var(--ink)}
h3{font-family:var(--display);font-weight:600;letter-spacing:-.01em}
.eyebrow{font-family:var(--ui);font-weight:700;text-transform:uppercase;letter-spacing:.26em;font-size:.72rem;color:var(--water-deep);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--sun);display:inline-block}
.eyebrow.on-dark{color:var(--sun-soft)}
.lead{font-size:1.18rem;color:var(--muted);max-width:60ch}
.ico{width:1em;height:1em;fill:currentColor;flex:none}
.btn{font-family:var(--ui);font-weight:700;font-size:.96rem;letter-spacing:.01em;display:inline-flex;align-items:center;gap:.6rem;padding:15px 26px;border-radius:2px;cursor:pointer;border:1.5px solid transparent;transition:transform .25s cubic-bezier(.2,.7,.2,1),background .25s,color .25s,box-shadow .25s}
.btn .ico{width:18px;height:18px}
.btn-sun{background:var(--sun);color:#231405;box-shadow:0 14px 26px -14px rgba(221,143,67,.9)}
.btn-sun:hover{transform:translateY(-3px);background:#e89c54}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{transform:translateY(-3px);background:var(--navy-700)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-line{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-line:hover{background:var(--navy);color:#fff}
/* HEADER */
header{position:fixed;inset:0 0 auto 0;z-index:60;background:var(--navy);transition:box-shadow .35s,padding .35s;padding:14px 0}
header.scrolled{box-shadow:0 10px 30px -16px rgba(0,0,0,.55);padding:9px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand img{height:34px;width:auto;transition:height .35s}
header.scrolled .brand img{height:28px}
.menu{display:flex;align-items:center;gap:4px;list-style:none}
.menu a{font-family:var(--ui);font-weight:600;font-size:.92rem;color:rgba(255,255,255,.9);padding:9px 14px;border-radius:2px;transition:color .3s}
.menu a:hover,.menu a.active{color:var(--sun)}
.nav-right{display:flex;align-items:center;gap:16px}
.callbox{display:flex;align-items:center;gap:.55rem;font-family:var(--ui);font-weight:800;color:#fff;font-size:1.02rem}
.callbox .ic{width:34px;height:34px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6);display:grid;place-items:center;flex:none}
.callbox .ic .ico{width:15px;height:15px}
.callbox small{display:block;font-weight:600;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sun-soft)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:61}
.burger span{width:26px;height:2px;background:#fff;transition:.35s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* HERO (home) */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-stage{position:absolute;inset:0;z-index:0}
.hero-stage .frame{position:absolute;inset:0;opacity:0;background-size:cover;background-position:center;animation:kb 32s infinite;will-change:transform,opacity}
.hero-stage .frame:nth-child(1){animation-delay:0s}
.hero-stage .frame:nth-child(2){animation-delay:8s}
.hero-stage .frame:nth-child(3){animation-delay:16s}
.hero-stage .frame:nth-child(4){animation-delay:24s}
@keyframes kb{0%{opacity:0;transform:scale(1.12)}5%{opacity:1}22%{opacity:1}28%{opacity:0;transform:scale(1.03)}100%{opacity:0}}
.hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(187deg,rgba(21,32,46,.42) 0%,rgba(21,32,46,.14) 36%,rgba(21,32,46,.66) 78%,rgba(21,32,46,.9) 100%)}
.hero-veil::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 12% 92%,rgba(14,142,163,.4),transparent 60%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:9vh;padding-top:150px}
.hero-badge{display:inline-flex;align-items:center;gap:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(6px);padding:8px 16px;border-radius:50px;margin-bottom:22px;font-family:var(--ui);font-weight:700;font-size:.84rem}
.hero-badge .stars{display:inline-flex;gap:2px;color:var(--sun)}
.hero-badge .stars .ico{width:15px;height:15px}
.hero-badge b{color:#fff}.hero-badge span{color:rgba(255,255,255,.8);font-weight:600}
.hero h1{font-size:clamp(2.9rem,8vw,6.4rem);max-width:15ch;color:#fff;text-shadow:0 2px 40px rgba(0,0,0,.25)}
.hero h1 em{font-style:italic;font-weight:600;color:var(--sun-soft)}
.hero .sub{margin-top:24px;max-width:54ch;font-size:1.24rem;color:rgba(255,255,255,.92);font-weight:400}
.hero-cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-foot{margin-top:46px;display:flex;flex-wrap:wrap;gap:34px;border-top:1px solid rgba(255,255,255,.22);padding-top:22px;align-items:center}
.hero-foot div{font-family:var(--ui)}
.hero-foot b{display:block;font-family:var(--display);font-weight:700;font-size:1.5rem;color:#fff;line-height:1}
.hero-foot span{font-size:.82rem;color:rgba(255,255,255,.78)}
.hero-wm{position:absolute;right:30px;bottom:30px;z-index:3;height:40px;opacity:.75;filter:drop-shadow(0 2px 10px rgba(0,0,0,.5))}
.brand-logo{display:block;width:auto;color:#fff}
.brand .brand-logo{height:34px;transition:height .35s}
header.scrolled .brand .brand-logo{height:29px}
.f-brand .brand-logo{height:44px;margin-bottom:16px}
.hero-wm.brand-logo{height:46px;color:#fff}
.scrollcue{position:absolute;left:30px;bottom:26px;z-index:3;font-family:var(--ui);font-weight:600;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:12px}
.scrollcue::after{content:"";width:54px;height:1.5px;background:linear-gradient(90deg,rgba(255,255,255,.7),transparent);animation:cue 2.2s infinite}
@keyframes cue{0%{transform:scaleX(0);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}51%{transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}
/* PAGE HERO (inner pages) */
.page-hero{position:relative;min-height:54vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.page-hero .ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.06);animation:phzoom 14s ease-out forwards}
@keyframes phzoom{to{transform:scale(1)}}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(21,32,46,.5),rgba(21,32,46,.5) 40%,rgba(21,32,46,.86))}
.page-hero .inner{position:relative;z-index:2;width:100%;padding:150px 0 52px}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);color:#fff;max-width:18ch}
.crumb{font-family:var(--ui);font-weight:600;font-size:.86rem;color:rgba(255,255,255,.78);margin-bottom:14px;display:flex;gap:8px;align-items:center}
.crumb a{color:var(--sun-soft)}.crumb span{opacity:.5}
.page-hero .ph-sub{margin-top:16px;max-width:56ch;font-size:1.16rem;color:rgba(255,255,255,.9)}
/* TICKER */
.ticker{background:var(--navy);color:#fff;overflow:hidden;border-top:3px solid var(--sun)}
.ticker-row{display:flex;white-space:nowrap;animation:slide 34s linear infinite;font-family:var(--display);font-weight:600;font-size:1.05rem;padding:16px 0}
.ticker-row span{padding:0 28px;display:inline-flex;align-items:center;gap:28px;color:rgba(255,255,255,.92)}
.ticker-row span::after{content:"\2022";color:var(--sun)}
@keyframes slide{to{transform:translateX(-50%)}}
/* SECTIONS */
.section{padding:104px 0;position:relative}
.section.cream{background:var(--cream)}.section.sand{background:var(--sand)}
.section.navy{background:var(--navy);color:#fff}.section.navy h2,.section.navy h3{color:#fff}
.shead{max-width:64ch}.shead h2{margin-top:14px}.shead p{margin-top:16px}
.r{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.r.in{opacity:1;transform:none}
.r.d1{transition-delay:.08s}.r.d2{transition-delay:.16s}.r.d3{transition-delay:.24s}
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.feature.flip .ftext{order:2}
.fmedia{position:relative}
.fmedia .main{border-radius:3px;box-shadow:var(--shadow);aspect-ratio:4/3.3;object-fit:cover;width:100%}
.fmedia .badge{position:absolute;left:-26px;bottom:-26px;background:var(--white);border-radius:3px;padding:20px 24px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px;max-width:250px}
.fmedia .badge .n{font-family:var(--display);font-weight:800;font-size:2.1rem;color:var(--water-deep);line-height:1}
.fmedia .badge .t{font-family:var(--ui);font-weight:600;font-size:.82rem;color:var(--muted);line-height:1.3}
.fmedia .tag{position:absolute;top:18px;right:-18px;background:var(--sun);color:#241404;font-family:var(--ui);font-weight:800;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:9px 16px;border-radius:2px;box-shadow:var(--shadow-sm)}
.ftext h2{margin:14px 0 18px}.ftext .body p+p{margin-top:14px}
.tick{list-style:none;margin-top:24px;display:grid;gap:13px}
.tick li{display:flex;gap:13px;align-items:flex-start;font-family:var(--ui);font-weight:600;color:var(--ink)}
.tick li .ico{width:22px;height:22px;color:var(--water);margin-top:3px}
.ftext .cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.card{background:var(--white);border:1px solid var(--line);border-radius:3px;padding:34px 30px;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card .ring{width:56px;height:56px;border-radius:50%;background:var(--water-soft);color:var(--water-deep);display:grid;place-items:center;margin-bottom:20px;transition:background .4s,color .4s}
.card:hover .ring{background:var(--sun);color:#241404}
.card .ring .ico{width:26px;height:26px}
.card h3{font-size:1.28rem;margin-bottom:9px}.card p{color:var(--muted);font-size:.98rem}
.card .more{margin-top:16px;font-family:var(--ui);font-weight:700;font-size:.84rem;color:var(--water-deep);display:inline-flex;align-items:center;gap:7px}
.card .more .ico{width:15px;height:15px;transition:transform .3s}
.card:hover .more .ico{transform:translateX(5px)}
.band{position:relative;min-height:60vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--navy-700)}
.band-bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}
.band .wrap{position:relative;z-index:2}
.band .quote-mark{font-family:var(--display);font-size:5rem;line-height:.6;color:var(--sun);display:block}
.band h2{max-width:18ch;font-size:clamp(2.1rem,4.8vw,3.4rem);color:#fff}
.band p{max-width:50ch;margin-top:18px;font-size:1.18rem;color:rgba(255,255,255,.9)}
.band .who{margin-top:22px;font-family:var(--ui);font-weight:700}
.band .who span{color:var(--sun-soft);font-weight:600}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.stat .n{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,5vw,3.7rem);color:#fff;line-height:1;display:flex;align-items:baseline}
.stat .n .suf{color:var(--sun);font-size:.6em;margin-left:2px}
.stat .l{font-family:var(--ui);font-weight:600;color:rgba(255,255,255,.78);margin-top:8px;font-size:.96rem}
.stat .b{width:42px;height:3px;background:var(--sun);margin-bottom:18px}
.gallery{columns:3;column-gap:18px;margin-top:50px}
.gallery figure{break-inside:avoid;margin-bottom:18px;border-radius:3px;overflow:hidden;position:relative;box-shadow:var(--shadow-sm)}
.gallery img{width:100%;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;inset:auto 0 0 0;padding:26px 18px 14px;background:linear-gradient(transparent,rgba(21,32,46,.82));color:#fff;font-family:var(--ui);font-weight:700;font-size:.86rem;opacity:0;transform:translateY(8px);transition:.4s}
.gallery figure:hover figcaption{opacity:1;transform:none}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:18px}
.gbar{display:flex;align-items:center;gap:14px;margin-top:26px;font-family:var(--ui);font-weight:700;color:var(--ink);flex-wrap:wrap}
.gbar .stars{display:inline-flex;gap:2px;color:var(--sun)}.gbar .stars .ico{width:18px;height:18px}
.gbar .rate{font-family:var(--display);font-weight:800;font-size:1.4rem}
.gbar span{color:var(--muted);font-weight:600}
.review{background:var(--white);border:1px solid var(--line);border-radius:3px;padding:32px 28px;display:flex;flex-direction:column}
.review .stars{display:inline-flex;gap:3px;color:var(--sun);margin-bottom:16px}.review .stars .ico{width:17px;height:17px}
.review p{font-size:1.02rem;color:var(--ink);line-height:1.65}
.review .by{margin-top:22px;display:flex;align-items:center;gap:13px}
.review .by .av{width:48px;height:48px;border-radius:50%;background:var(--water-soft);color:var(--water-deep);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.05rem}
.review .by b{font-family:var(--ui);font-weight:800;display:block;font-size:.98rem}
.review .by span{font-size:.8rem;color:var(--muted);font-family:var(--ui);font-weight:600;display:inline-flex;align-items:center;gap:5px}
.review .by span .ico{width:13px;height:13px;color:var(--water)}
.areas{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}
.areas a{font-family:var(--ui);font-weight:700;background:var(--white);border:1px solid var(--line);padding:13px 22px;border-radius:2px;display:flex;align-items:center;gap:9px;transition:.3s;color:var(--navy)}
.areas a .ico{width:16px;height:16px;color:var(--water)}
.areas a:hover{background:var(--navy);color:#fff;transform:translateY(-3px)}.areas a:hover .ico{color:var(--sun)}
.area-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.area-card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:30px;transition:.35s}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.area-card .ring{width:48px;height:48px;border-radius:50%;background:var(--water-soft);color:var(--water-deep);display:grid;place-items:center;margin-bottom:16px}
.area-card .ring .ico{width:22px;height:22px}
.area-card h3{font-size:1.25rem;margin-bottom:8px}.area-card p{color:var(--muted);font-size:.96rem}
/* CTA band */
.cta-final{position:relative;overflow:hidden;background:var(--navy);color:#fff}
.cta-grid{display:grid;grid-template-columns:1.05fr .95fr}
.cta-copy{padding:92px 6vw 92px 0}
.cta-copy .wrap2{max-width:560px;margin-left:auto;padding-right:40px}
.cta-copy h2{color:#fff;font-size:clamp(2.1rem,4.6vw,3.2rem)}
.cta-copy p{color:rgba(255,255,255,.85);margin-top:16px;font-size:1.14rem}
.cta-rows{margin-top:30px;display:grid;gap:2px}
.cta-rows a{display:flex;align-items:center;gap:16px;padding:18px 0;border-top:1px solid rgba(255,255,255,.16);font-family:var(--ui);font-weight:700;font-size:1.08rem;transition:.3s}
.cta-rows a:last-child{border-bottom:1px solid rgba(255,255,255,.16)}
.cta-rows a:hover{color:var(--sun-soft);padding-left:8px}
.cta-rows a .ic{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;flex:none}
.cta-rows a .ic .ico{width:19px;height:19px}
.cta-rows a small{display:block;font-weight:600;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.cta-photo{background-size:cover;background-position:center;min-height:460px}
/* CONTACT FORM */
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:36px;box-shadow:var(--shadow)}
.form-card h3{font-size:1.5rem;margin-bottom:6px}
.form-card .fc-sub{color:var(--muted);margin-bottom:24px;font-size:.98rem}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--ui);font-weight:600;font-size:.86rem;margin-bottom:.4rem;color:var(--navy)}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:3px;font-family:var(--body);font-size:1rem;background:#fbfdff;transition:border .2s,box-shadow .2s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--water);box-shadow:0 0 0 3px rgba(14,142,163,.14)}
.field textarea{min-height:130px;resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.84rem;color:var(--muted);margin-top:.7rem}
.success{display:none;background:#e6f7ec;border:1px solid #9ad9b0;color:#1c6b3a;padding:14px 18px;border-radius:3px;margin-top:1rem;font-weight:600;font-family:var(--ui)}
.success.err{background:#fdecec;border-color:#f0b3b3;color:#a12626}
.hp{display:none !important}
.info-card{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:4px;padding:20px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.info-card .ic{width:48px;height:48px;flex:none;border-radius:50%;background:var(--water-soft);color:var(--water-deep);display:grid;place-items:center}
.info-card .ic .ico{width:21px;height:21px}
.info-card b{display:block;font-family:var(--ui);font-weight:800;color:var(--navy)}
.info-card a,.info-card span{color:var(--muted)}
.map-embed{margin-top:8px;border-radius:4px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.map-embed iframe{display:block;width:100%;height:240px;border:0}
.faq{max-width:840px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:4px;padding:24px 28px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.faq-item h3{font-size:1.14rem;margin-bottom:8px;color:var(--navy)}
.faq-item p{color:var(--muted);font-size:1rem}
/* FOOTER */
footer{background:var(--ink);color:#aeb8c6;padding:74px 0 30px}
.f-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:40px}
.f-brand img{height:40px;width:auto;margin-bottom:16px}
footer p{color:#8b97a8;font-size:.96rem;max-width:36ch}
footer h4{font-family:var(--ui);font-weight:800;color:#fff;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
footer ul{list-style:none;display:grid;gap:11px}
footer ul a,footer ul li{color:#9aa6b6;font-size:.96rem;transition:.25s}
footer ul a:hover{color:var(--sun)}
.f-bottom{margin-top:54px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.86rem;color:#73808f;font-family:var(--ui)}
.fab{position:fixed;right:18px;bottom:18px;z-index:55;background:var(--sun);color:#241404;width:60px;height:60px;border-radius:50%;display:none;place-items:center;box-shadow:0 16px 34px -10px rgba(221,143,67,.9);animation:pulse 2.4s infinite}
.fab .ico{width:24px;height:24px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(221,143,67,.55)}70%{box-shadow:0 0 0 18px rgba(221,143,67,0)}100%{box-shadow:0 0 0 0 rgba(221,143,67,0)}}
@media(max-width:1000px){
  .feature,.feature.flip{grid-template-columns:1fr;gap:40px}.feature.flip .ftext{order:0}
  .cards,.reviews,.area-cards{grid-template-columns:1fr 1fr}.stats{grid-template-columns:1fr 1fr;gap:40px}
  .gallery{columns:2}.cta-grid,.contact-grid{grid-template-columns:1fr;gap:40px}.cta-copy{padding:72px 0}
  .cta-copy .wrap2{padding:0 28px;max-width:none}.f-top{grid-template-columns:1fr 1fr}.hero-wm{display:none}
}
@media(max-width:680px){
  body{font-size:16px}.menu,.callbox small{display:none}.nav-right .callbox span:not(.ic){display:none}
  .burger{display:flex}
  .menu{position:fixed;inset:0;background:var(--navy);flex-direction:column;justify-content:center;gap:8px;transform:translateX(100%);transition:transform .45s cubic-bezier(.6,.05,.2,1)}
  .menu.open{transform:none}.menu a{color:#fff!important;font-size:1.5rem;font-family:var(--display)}
  .cards,.reviews,.stats,.f-top,.area-cards,.frow{grid-template-columns:1fr}.gallery{columns:1}
  .fmedia .badge{left:14px;bottom:14px}.hero h1{font-size:clamp(2.6rem,11vw,3.6rem)}
  .fab{display:grid}.section{padding:72px 0}.band{min-height:54vh}.page-hero{min-height:48vh}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.r{opacity:1;transform:none}}
