/* ============ THE GYMNASTICS ACADEMY — playful frontend ============ */
:root{
  --paper:#FFF6EC; --paper-2:#FFE7D2; --paper-3:#FBEAD9;
  --ink:#2A1740; --ink-2:#4A3463; --ink-soft:#6B5A82;
  --line:rgba(42,23,64,.14); --line-2:rgba(42,23,64,.08);
  --coral:#FF5A6E; --coral-d:#E8425A; --marigold:#FFB02E;
  --periwinkle:#5B8CFF; --mint:#34CFA0; --plum:#2A1740; --plum-2:#3a2358;
  --radius-sm:14px; --radius:22px; --radius-lg:34px; --radius-pill:999px;
  --shadow:0 22px 48px -22px rgba(42,23,64,.40);
  --shadow-sm:0 10px 26px -14px rgba(42,23,64,.32);
  --shadow-lift:0 30px 60px -24px rgba(42,23,64,.45);
  --ease:cubic-bezier(.22,1,.36,1); --spring:cubic-bezier(.34,1.56,.64,1);
  --display:"Fraunces",Georgia,serif;
  --ui:"Bricolage Grotesque",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1180px;
}
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ui);background:var(--paper);color:var(--ink);line-height:1.62;font-weight:420;font-size:1.02rem;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
ul{list-style:none}
:focus-visible{outline:3px solid var(--periwinkle);outline-offset:3px;border-radius:6px}

.wrap{width:min(var(--wrap),92vw);margin-inline:auto}
.section{padding:clamp(64px,11vw,130px) 0;position:relative;scroll-margin-top:84px}
.eyebrow{font-family:var(--ui);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--coral-d);display:inline-flex;align-items:center;gap:.5em}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--coral);border-radius:2px;display:inline-block}
.h2{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 120,"SOFT" 40,"WONK" 1,"wght" 560;font-weight:560;line-height:1.04;letter-spacing:-.012em;font-size:clamp(2rem,5vw,3.4rem);color:var(--ink)}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-2);max-width:56ch}

/* buttons */
.btn{--bg:var(--coral);--fg:var(--ink);display:inline-flex;align-items:center;gap:.6em;justify-content:center;background:var(--bg);color:var(--fg);padding:.95em 1.5em;border-radius:var(--radius-pill);font-weight:700;letter-spacing:.01em;font-size:1rem;box-shadow:var(--shadow-sm);transition:transform .35s var(--spring),box-shadow .35s var(--ease),background .25s var(--ease);will-change:transform}
.btn:hover{transform:translateY(-3px) scale(1.015);box-shadow:var(--shadow)}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn .ic{width:1.15em;height:1.15em;flex:0 0 auto}
.btn--ink{--bg:var(--plum);--fg:var(--paper)}
.btn--ghost{--bg:transparent;--fg:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.btn--ghost:hover{box-shadow:inset 0 0 0 2px var(--ink);background:rgba(42,23,64,.06)}
.btn--sm{padding:.6em 1em;font-size:.9rem}

/* header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,246,236,.86);backdrop-filter:saturate(160%) blur(12px);-webkit-backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line-2)}
.nav{display:flex;align-items:center;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand__mark{width:42px;height:42px;flex:0 0 auto}
.brand__txt b{display:block;font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 40,"SOFT" 60,"WONK" 1,"wght" 700;font-size:1.18rem;line-height:1;color:var(--ink);letter-spacing:-.01em}
.brand__txt span{display:block;font-family:var(--ui);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.nav__links{display:flex;gap:6px;align-items:center}
.nav__links a{font-weight:600;font-size:.96rem;color:var(--ink-2);padding:.5em .9em;border-radius:var(--radius-pill);transition:background .2s,color .2s}
.nav__links a:hover{background:rgba(42,23,64,.07);color:var(--ink)}
.nav__call{display:inline-flex}
.nav__toggle{display:none;width:46px;height:46px;border-radius:14px;align-items:center;justify-content:center;background:rgba(42,23,64,.06)}
.nav__toggle svg{width:24px;height:24px}
.nav__menu{display:none}
@media (max-width:860px){
  .nav__links,.nav__call{display:none}
  .nav__toggle{display:inline-flex}
  .nav__menu{display:none}
  .nav.open .nav__menu{display:flex;position:absolute;inset:auto 0 auto 0;top:100%;flex-direction:column;gap:6px;padding:16px 5vw 24px;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav.open .nav__menu a{padding:.9em 1em;border-radius:14px}
  .nav.open .nav__menu a:hover{background:var(--paper-2)}
  .nav.open .nav__menu .btn{margin-top:8px}
}

/* hero */
.hero{position:relative;padding:clamp(40px,7vw,80px) 0 clamp(60px,10vw,110px);overflow:hidden}
.hero__dots{position:absolute;inset:0;z-index:-2;background-image:radial-gradient(rgba(42,23,64,.10) 1.4px,transparent 1.4px);background-size:26px 26px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 60% 35%,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse 80% 70% at 60% 35%,#000 30%,transparent 80%)}
.hero__ribbon{position:absolute;z-index:-1;width:140%;left:-20%;top:-6%;height:auto;opacity:.95;animation:sway 9s ease-in-out infinite;transform-origin:50% 50%}
.hero__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,5vw,70px);align-items:center}
.hero__name-dev{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 70,"WONK" 1,"wght" 500;color:var(--coral-d);font-size:clamp(1.2rem,2.4vw,1.7rem);margin-top:.3em;display:block}
.hero__title{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 60,"WONK" 1,"wght" 620;font-weight:620;line-height:.98;letter-spacing:-.015em;font-size:clamp(2.7rem,7.4vw,5.6rem);margin:.18em 0 .35em}
.hero__title em{font-style:italic;color:var(--coral-d);position:relative;white-space:nowrap}
.hero__title em::after{content:"";position:absolute;left:-4%;right:-4%;bottom:.06em;height:.16em;background:linear-gradient(90deg,var(--coral),var(--marigold),var(--mint));border-radius:4px;opacity:.85}
.hero__lead{margin-bottom:1.6rem}
.status-pill{display:inline-flex;align-items:center;gap:.55em;background:var(--paper-2);border:1px solid var(--line);padding:.5em .95em;border-radius:var(--radius-pill);font-weight:600;font-size:.9rem;color:var(--ink-2);margin-bottom:1.5rem}
.status-pill .dot{width:9px;height:9px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(255,90,110,.18);flex:0 0 auto}
.status-pill b{color:var(--ink)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:1.6rem}
.rating-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--ink-soft);font-size:.96rem}
.rating-row b{color:var(--ink)}
.stars{display:inline-flex;color:var(--marigold)}
.stars svg{width:18px;height:18px}
.wo-pill{display:inline-flex;align-items:center;gap:.5em;background:var(--plum);color:var(--paper);padding:.5em .9em;border-radius:var(--radius-pill);font-weight:700;font-size:.78rem;letter-spacing:.04em}
.wo-pill .sym{color:var(--mint);font-weight:800}

/* medal seal */
.seal{position:relative;width:clamp(230px,27vw,300px);aspect-ratio:1;margin-inline:auto}
.seal__ring{position:absolute;inset:-16px;width:calc(100% + 32px);height:calc(100% + 32px);animation:spin 24s linear infinite}
.seal__core{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 32% 26%,var(--plum-2),var(--plum) 72%);box-shadow:var(--shadow),inset 0 0 0 4px rgba(255,176,46,.25);display:grid;place-content:center;text-align:center;gap:.1em;color:var(--paper)}
.seal__core::before{content:"";position:absolute;inset:10px;border-radius:50%;border:2px dashed rgba(255,176,46,.35)}
.seal__num{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1,"wght" 700;font-size:clamp(3rem,9vw,4.4rem);line-height:1;color:var(--paper)}
.seal__stars{color:var(--marigold);display:flex;gap:3px;justify-content:center;margin:.1em 0}
.seal__stars svg{width:16px;height:16px}
.seal__cap{font-family:var(--ui);font-weight:600;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,246,236,.78)}
.seal__chip{position:absolute;width:clamp(48px,7vw,62px);aspect-ratio:1;border-radius:50%;background:var(--paper);box-shadow:var(--shadow-sm);display:grid;place-items:center;color:var(--ink);animation:float 6s ease-in-out infinite}
.seal__chip svg{width:54%;height:54%}
.seal__chip.c1{top:-4%;left:-6%;color:var(--coral);animation-delay:.1s}
.seal__chip.c2{top:6%;right:-10%;color:var(--marigold);animation-delay:1.2s}
.seal__chip.c3{bottom:-2%;left:4%;color:var(--mint);animation-delay:2.1s}
.seal__chip.c4{bottom:8%;right:-6%;color:var(--periwinkle);animation-delay:3s}
.seal__chip.c5{top:42%;left:-14%;color:var(--coral);animation-delay:1.7s}

/* marquee */
.marquee{background:var(--plum);color:var(--paper);overflow:hidden;padding:18px 0;border-top:3px solid var(--marigold);border-bottom:3px solid var(--coral)}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scrollx 28s linear infinite}
.marquee__track span{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 80,"SOFT" 50,"WONK" 1,"wght" 600;font-size:clamp(1.4rem,3vw,2rem);padding:0 1.1em;display:inline-flex;align-items:center;gap:1.1em}
.marquee__track span::after{content:"\2726";color:var(--marigold);font-size:.7em}
.marquee__track span:nth-child(4n+1){color:var(--coral)}
.marquee__track span:nth-child(4n+2){color:var(--marigold)}
.marquee__track span:nth-child(4n+3){color:var(--mint)}
.marquee__track span:nth-child(4n){color:var(--periwinkle)}

/* info strip */
.info-strip{background:var(--paper-3);border-bottom:1px solid var(--line)}
.info-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.info-card{display:flex;flex-direction:column;gap:8px;padding:clamp(22px,3vw,34px) clamp(18px,2.4vw,30px);border-right:1px solid var(--line);min-width:0}
.info-card:last-child{border-right:0}
.info-card .ic{width:34px;height:34px;color:var(--coral-d)}
.info-card label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.info-card .val{font-weight:600;font-size:1.02rem;color:var(--ink);line-height:1.4;word-break:break-word}
.info-card a.val:hover{color:var(--coral-d)}
@media (max-width:860px){.info-grid{grid-template-columns:1fr 1fr}.info-card:nth-child(2n){border-right:0}.info-card:nth-child(-n+2){border-bottom:1px solid var(--line)}}
@media (max-width:480px){.info-grid{grid-template-columns:1fr}.info-card{border-right:0;border-bottom:1px solid var(--line)}.info-card:last-child{border-bottom:0}}

/* about */
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:start}
.about__head{position:sticky;top:96px}
.values{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.value{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:transform .4s var(--spring),box-shadow .4s var(--ease)}
.value:hover{transform:translateY(-4px) rotate(-.6deg);box-shadow:var(--shadow)}
.value__ic{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;margin-bottom:14px}
.value:nth-child(1) .value__ic{background:rgba(255,90,110,.16);color:var(--coral-d)}
.value:nth-child(2) .value__ic{background:rgba(255,176,46,.18);color:#c97e00}
.value:nth-child(3) .value__ic{background:rgba(52,207,160,.18);color:#1c9e75}
.value:nth-child(4) .value__ic{background:rgba(91,140,255,.18);color:#3b66d6}
.value__ic svg{width:26px;height:26px}
.value h3{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 40,"SOFT" 50,"WONK" 1,"wght" 600;font-size:1.35rem;margin-bottom:6px;line-height:1.1}
.value p{color:var(--ink-2);font-size:.97rem}
@media (max-width:860px){.about__grid{grid-template-columns:1fr}.about__head{position:static}.values{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.values{grid-template-columns:1fr}}

/* programs */
.prog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(30px,4vw,48px)}
.prog-note{color:var(--ink-soft);max-width:34ch}
.prog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.prog{position:relative;border-radius:var(--radius-lg);padding:26px 22px 24px;overflow:hidden;border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow-sm);transition:transform .45s var(--spring),box-shadow .45s var(--ease);display:flex;flex-direction:column;min-height:300px}
.prog:hover{transform:translateY(-6px) rotate(var(--tilt,0deg)) scale(1.01);box-shadow:var(--shadow-lift)}
.prog:nth-child(odd){--tilt:-1.1deg}
.prog:nth-child(even){--tilt:1.1deg}
.prog__bg{position:absolute;inset:auto -10% -30% 0;height:60%;opacity:.16;z-index:0;transform:rotate(-8deg)}
.prog__bg svg{width:100%;height:100%}
.prog>*{position:relative;z-index:1}
.prog__ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:14px}
.prog__ic svg{width:30px;height:30px}
.prog__tag{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35em .7em;border-radius:var(--radius-pill);margin-bottom:14px}
.prog h3{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 48,"SOFT" 55,"WONK" 1,"wght" 600;font-size:1.5rem;line-height:1.05;margin-bottom:8px}
.prog p{color:var(--ink-2);font-size:.94rem;margin-bottom:16px}
.prog__age{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:.82rem;color:var(--ink-soft);margin-top:auto}
.prog__age b{color:var(--ink)}
.prog--coral .prog__ic{background:var(--coral);color:var(--paper)}
.prog--coral .prog__tag{background:var(--coral);color:var(--ink)}
.prog--coral .prog__bg{color:var(--coral)}
.prog--marigold .prog__ic{background:var(--marigold);color:var(--ink)}
.prog--marigold .prog__tag{background:rgba(255,176,46,.22);color:#9a6400}
.prog--marigold .prog__bg{color:var(--marigold)}
.prog--mint .prog__ic{background:var(--mint);color:var(--ink)}
.prog--mint .prog__tag{background:rgba(52,207,160,.22);color:#157a59}
.prog--mint .prog__bg{color:var(--mint)}
.prog--peri .prog__ic{background:var(--periwinkle);color:var(--paper)}
.prog--peri .prog__tag{background:rgba(91,140,255,.18);color:#3b66d6}
.prog--peri .prog__bg{color:var(--periwinkle)}
.prog--feature{background:linear-gradient(165deg,var(--coral) 0%,var(--coral-d) 100%);color:var(--ink);border-color:transparent}
.prog--feature h3,.prog--feature p,.prog--feature .prog__age{color:var(--ink)}
.prog--feature .prog__ic{background:var(--paper);color:var(--coral-d)}
.prog--feature .prog__tag{background:var(--ink);color:var(--marigold)}
.prog--feature .prog__bg{color:rgba(255,255,255,.5)}
@media (max-width:1000px){.prog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.prog-grid{grid-template-columns:1fr}}

/* stats */
.stats{background:var(--plum);color:var(--paper);position:relative;overflow:hidden}
.stats__ribbon{position:absolute;inset:auto 0 -30% 0;height:120%;opacity:.18;z-index:0;color:var(--marigold)}
.stats__ribbon svg{width:100%;height:100%}
.stats .wrap{position:relative;z-index:1}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:14px}
.stat__num{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 40,"WONK" 1,"wght" 700;font-size:clamp(2.6rem,6vw,4.2rem);line-height:1;color:var(--marigold)}
.stat:nth-child(2) .stat__num{color:var(--coral)}
.stat:nth-child(3) .stat__num{color:var(--mint)}
.stat:nth-child(4) .stat__num{color:var(--periwinkle)}
.stat__lbl{font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.8rem;color:rgba(255,246,236,.8);margin-top:.5em}
@media (max-width:700px){.stats__grid{grid-template-columns:1fr 1fr;gap:10px}}

/* popular times */
.popular{background:var(--paper-2)}
.popular__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(30px,5vw,64px);align-items:center}
.popular__live{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:.82rem;color:var(--coral-d);margin-bottom:10px}
.popular__live .dot{width:9px;height:9px;border-radius:50%;background:var(--coral);animation:pulse 2s ease-in-out infinite}
.chart{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,3vw,30px) clamp(18px,3vw,30px) clamp(16px,2vw,22px);box-shadow:var(--shadow-sm)}
.chart__bars{display:flex;align-items:flex-end;gap:6px;height:200px;padding-top:10px}
.bar{flex:1;min-width:0;border-radius:6px 6px 3px 3px;background:linear-gradient(180deg,var(--mint),#19a87c);position:relative;transition:filter .2s,transform .2s;cursor:default;height:0}
.bar.peak{background:linear-gradient(180deg,var(--coral),var(--coral-d))}
.bar.now{outline:3px solid var(--periwinkle);outline-offset:2px}
.bar:hover{filter:brightness(1.08);transform:translateY(-2px)}
.chart__axis{display:flex;justify-content:space-between;margin-top:10px;font-size:.72rem;color:var(--ink-soft);font-weight:600;letter-spacing:.04em}
.chart__legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;font-size:.84rem;color:var(--ink-soft)}
.chart__legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:6px;vertical-align:-1px}
@media (max-width:860px){.popular__grid{grid-template-columns:1fr}}

/* reviews */
.reviews__top{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,60px);align-items:center;margin-bottom:clamp(34px,5vw,56px)}
.rev-score{background:var(--paper-3);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);text-align:center}
.rev-score__big{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 30,"WONK" 1,"wght" 700;font-size:clamp(3.4rem,9vw,5rem);line-height:1;color:var(--ink)}
.rev-score__stars{color:var(--marigold);display:flex;gap:4px;justify-content:center;margin:.3em 0}
.rev-score__stars svg{width:24px;height:24px}
.rev-score__cap{color:var(--ink-soft);font-weight:600;font-size:.95rem}
.dist{display:flex;flex-direction:column;gap:9px}
.dist__row{display:grid;grid-template-columns:18px 1fr 34px;align-items:center;gap:12px;font-size:.9rem;color:var(--ink-soft)}
.dist__bar{height:9px;border-radius:6px;background:var(--paper-3);overflow:hidden}
.dist__bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--marigold),#f0991a);width:0;transition:width 1.1s var(--ease)}
.dist__row span:last-child{text-align:right;font-weight:700;color:var(--ink)}
.dist__row[data-r="5"] .dist__bar i{background:linear-gradient(90deg,var(--mint),#19a87c)}
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:clamp(30px,4vw,44px)}
.quote{background:var(--plum);color:var(--paper);border-radius:var(--radius);padding:24px 26px;font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 24,"SOFT" 60,"WONK" 1,"wght" 480;font-size:clamp(1.1rem,2vw,1.4rem);line-height:1.3;position:relative}
.quote::before{content:"\201C";position:absolute;top:-8px;left:14px;font-size:3.4rem;color:var(--marigold);line-height:1;font-family:var(--display)}
.quote:nth-child(2){background:var(--coral);color:var(--ink)}
.quote:nth-child(2)::before{color:var(--plum)}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(30px,4vw,46px)}
.tag{display:inline-flex;align-items:center;gap:.5em;background:var(--paper-3);border:1px solid var(--line);padding:.5em .95em;border-radius:var(--radius-pill);font-weight:600;font-size:.86rem;color:var(--ink-2)}
.tag b{color:var(--coral-d)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;transition:transform .4s var(--spring),box-shadow .4s var(--ease)}
.review:hover{transform:translateY(-5px) rotate(-.5deg);box-shadow:var(--shadow)}
.review__head{display:flex;align-items:center;gap:12px}
.avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:var(--paper);flex:0 0 auto;font-family:var(--ui)}
.av-1{background:linear-gradient(135deg,var(--coral),var(--coral-d))}
.av-2{background:linear-gradient(135deg,var(--periwinkle),#3b66d6)}
.av-3{background:linear-gradient(135deg,var(--mint),#19a87c)}
.review__name{font-weight:700;font-size:.98rem}
.review__meta{font-size:.78rem;color:var(--ink-soft)}
.review__stars{color:var(--marigold);display:flex;gap:2px;margin-top:4px}
.review__stars svg{width:16px;height:16px}
.review__body{color:var(--ink-2);font-size:.95rem;line-height:1.6}
.review__foot{display:flex;gap:14px;margin-top:auto;padding-top:6px;font-size:.78rem;color:var(--ink-soft);font-weight:600}
.review__foot button{display:inline-flex;align-items:center;gap:.4em;transition:color .2s}
.review__foot button:hover{color:var(--coral-d)}
.review__foot svg{width:15px;height:15px}
.rev-cta{margin-top:clamp(28px,4vw,40px);display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:1000px){.rev-grid{grid-template-columns:1fr 1fr}}
@media (max-width:760px){.reviews__top{grid-template-columns:1fr}.quotes{grid-template-columns:1fr}.rev-grid{grid-template-columns:1fr}}

/* gallery */
.gallery{background:var(--paper-3)}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(24px,3vw,36px)}
.filter{padding:.55em 1.1em;border-radius:var(--radius-pill);font-weight:600;font-size:.9rem;background:var(--paper);border:1px solid var(--line);color:var(--ink-2);transition:all .25s var(--ease)}
.filter:hover{border-color:var(--ink)}
.filter.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;grid-auto-rows:160px}
.tile{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;display:grid;place-items:center;color:var(--paper);box-shadow:var(--shadow-sm);border:1px solid rgba(255,255,255,.2);transition:transform .5s var(--spring),box-shadow .5s var(--ease)}
.tile:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--shadow-lift)}
.tile svg{width:46px;height:46px;opacity:.9;transition:transform .5s var(--spring)}
.tile:hover svg{transform:scale(1.15) rotate(-6deg)}
.tile__cap{position:absolute;left:14px;bottom:12px;font-weight:700;font-size:.9rem;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.tile--coral{background:linear-gradient(150deg,#ff7a8a,var(--coral-d))}
.tile--marigold{background:linear-gradient(150deg,#ffc24d,#f0991a);color:var(--ink)}
.tile--peri{background:linear-gradient(150deg,#7aa3ff,#3b66d6)}
.tile--mint{background:linear-gradient(150deg,#5be0b3,#19a87c)}
.tile--plum{background:linear-gradient(150deg,var(--plum-2),var(--plum))}
.tile--big{grid-row:span 2}
.tile--add{border:2px dashed var(--ink-soft);background:transparent;color:var(--ink-soft);flex-direction:column;gap:8px}
.tile--add:hover{background:rgba(42,23,64,.05);transform:translateY(-3px)}
.tile--add svg{width:30px;height:30px;opacity:1}
.tile--add span{font-weight:700;font-size:.86rem}
@media (max-width:760px){.gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:140px}}
@media (max-width:420px){.gal-grid{grid-template-columns:1fr}}

/* visit */
.visit__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,50px);align-items:stretch}
.map-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);min-height:360px;background:var(--paper-3)}
.map-card iframe{width:100%;height:100%;min-height:360px;border:0;display:block}
.visit__details{display:flex;flex-direction:column;gap:18px}
.detail{display:flex;gap:16px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow-sm)}
.detail__ic{width:44px;height:44px;border-radius:12px;background:var(--paper-3);display:grid;place-items:center;flex:0 0 auto;color:var(--coral-d)}
.detail__ic svg{width:24px;height:24px}
.detail h3{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 30,"SOFT" 50,"WONK" 1,"wght" 600;font-size:1.2rem;margin-bottom:3px}
.detail p{color:var(--ink-2);font-size:.94rem;line-height:1.5}
.detail a{color:var(--coral-d);font-weight:700}
.detail a:hover{text-decoration:underline}
.hours table{width:100%;border-collapse:collapse;margin-top:6px}
.hours tr td{padding:7px 0;font-size:.92rem;border-bottom:1px solid var(--line-2)}
.hours tr:last-child td{border-bottom:0}
.hours tr td:first-child{font-weight:600;color:var(--ink-2)}
.hours tr td:last-child{text-align:right;color:var(--ink);font-weight:600}
.hours tr.today td{color:var(--coral-d);font-weight:800}
.hours__note{font-size:.8rem;color:var(--ink-soft);margin-top:10px}
.visit__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
@media (max-width:860px){.visit__grid{grid-template-columns:1fr}}

/* footer */
.site-footer{background:var(--plum);color:var(--paper);padding:clamp(56px,8vw,90px) 0 30px;position:relative;overflow:hidden}
.foot__ribbon{position:absolute;inset:auto 0 -10% 0;height:60%;opacity:.12;color:var(--coral);z-index:0}
.foot__ribbon svg{width:100%;height:100%}
.site-footer .wrap{position:relative;z-index:1}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
.foot__brand .brand__mark{width:54px;height:54px;margin-bottom:14px}
.foot__brand b{font-family:var(--display);font-style:italic;font-variation-settings:"opsz" 60,"SOFT" 60,"WONK" 1,"wght" 700;font-size:1.7rem;display:block;line-height:1}
.foot__brand .dev{font-family:var(--display);font-style:italic;color:var(--marigold);font-size:1.1rem;display:block;margin-top:6px}
.foot__brand p{color:rgba(255,246,236,.7);margin-top:14px;max-width:34ch;font-size:.94rem}
.foot__col h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--marigold);margin-bottom:14px;font-weight:700}
.foot__col ul{display:flex;flex-direction:column;gap:9px}
.foot__col a{color:rgba(255,246,236,.82);font-size:.94rem;transition:color .2s}
.foot__col a:hover{color:var(--paper)}
.foot__bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;border-top:1px solid rgba(255,246,236,.16);font-size:.84rem;color:rgba(255,246,236,.6)}
.foot__bottom a:hover{color:var(--paper)}
@media (max-width:760px){.foot__top{grid-template-columns:1fr 1fr}}
@media (max-width:440px){.foot__top{grid-template-columns:1fr}}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
[data-reveal][data-d="4"]{transition-delay:.32s}

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes sway{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(10px) rotate(1.4deg)}}
@keyframes scrollx{to{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,90,110,.5)}50%{box-shadow:0 0 0 8px rgba(255,90,110,0)}}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  [data-reveal]{opacity:1 !important;transform:none !important}
  .bar{transition:none}
}
