@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
:root{--bg:#ffffff;--fg:#1f2430;--muted:#5b6472;--card:#f7f8fb;--accent:#2563eb;--accent2:#06b6d4;--hbg:#111827;--hfg:#f3f6fb;--radius:18px;--font:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;--fhead:'Plus Jakarta Sans',system-ui,sans-serif;--maxw:1160px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--fg);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,.brand{font-family:var(--fhead);letter-spacing:-.02em;font-weight:700}
img{max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit}
header.site{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--hbg) 85%,transparent);color:var(--hfg);backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid color-mix(in srgb,var(--hfg) 12%,transparent)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:15px 24px;max-width:var(--maxw);margin:0 auto;position:relative}
.brand{font-weight:800;font-size:1.3rem;text-decoration:none;color:var(--hfg);display:flex;align-items:center;gap:9px}
.brand::before{content:'';width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 55%,transparent)}
.brand.has-logo::before{display:none}
.brand b{color:var(--accent)}
.brand .vx-logo-ico{font-size:1.4em;line-height:1}
.nav ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;align-items:center}
.nav ul a:not(.btn){text-decoration:none;opacity:.85;font-weight:600;font-size:.94rem;padding:8px 12px;border-radius:10px;transition:.15s}
.nav ul a:not(.btn):hover{opacity:1;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}
.nav-tog{display:none;background:transparent;border:0;color:var(--hfg);font-size:1.6rem;cursor:pointer;line-height:1;padding:4px 8px}
.btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;padding:13px 24px;border-radius:calc(var(--radius) - 4px);text-decoration:none;font-weight:700;border:0;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 8px 20px color-mix(in srgb,var(--accent) 35%,transparent)}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px color-mix(in srgb,var(--accent) 45%,transparent)}
.btn.ghost{background:transparent;border:1.5px solid color-mix(in srgb,var(--accent) 55%,transparent);color:var(--accent);box-shadow:none}
.btn.ghost:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}
.btn.sm{padding:9px 17px;font-size:.9rem}
.hero{padding:104px 0 96px;position:relative;overflow:hidden;background:radial-gradient(720px 380px at 78% -8%,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%),radial-gradient(520px 320px at 8% 108%,color-mix(in srgb,var(--accent2) 20%,transparent),transparent 65%)}
.hero .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative}
.hero.split .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero.center{text-align:center}.hero.center .lead{margin-left:auto;margin-right:auto}.hero.center .hero-cta,.hero.center .hero-stats{justify-content:center}.hero.center .badge{margin:0 auto 22px}
.hero h1{font-size:clamp(2.2rem,5.4vw,3.7rem);line-height:1.05;margin:0 0 20px;font-weight:800}
.lead{font-size:1.22rem;color:var(--muted);max-width:580px;margin:0 0 30px;line-height:1.6}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;padding:7px 15px;border-radius:999px;background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);margin-bottom:22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;margin-top:38px;flex-wrap:wrap}
.hero-stats .s b{display:block;font-family:var(--fhead);font-size:1.7rem;font-weight:800;color:var(--fg)}
.hero-stats .s span{color:var(--muted);font-size:.86rem}
.art{position:relative;aspect-ratio:4/3.4;border-radius:calc(var(--radius) + 8px);background:linear-gradient(150deg,var(--accent),var(--accent2));box-shadow:0 40px 80px -20px color-mix(in srgb,var(--accent) 50%,transparent);overflow:hidden}
.art::before{content:'';position:absolute;inset:0;background:radial-gradient(300px 200px at 30% 20%,rgba(255,255,255,.35),transparent 60%)}
.art .chip{position:absolute;background:rgba(255,255,255,.92);border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.22);padding:14px 16px;color:#111;font-weight:700;font-size:.9rem}
.art .chip.a{top:22px;left:22px}.art .chip.b{bottom:22px;right:22px}.art .chip small{display:block;font-weight:500;color:#666;font-size:.78rem}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--accent);margin-bottom:14px}
section{padding:72px 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 48px}
.sec-head h2{font-size:clamp(1.6rem,3.5vw,2.4rem);margin:0 0 12px}
.sec-head p{color:var(--muted);font-size:1.08rem}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{position:relative;background:var(--card);border:1px solid color-mix(in srgb,var(--fg) 10%,transparent);border-radius:var(--radius);padding:30px;transition:transform .2s,box-shadow .2s,border-color .2s;overflow:hidden}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transform-origin:left;transition:transform .25s}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -12px rgba(0,0,0,.16);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}
.card:hover::after{transform:scaleX(1)}
.ico{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,transparent),color-mix(in srgb,var(--accent2) 18%,transparent));margin-bottom:18px}
.card h3{margin:0 0 8px;font-size:1.2rem}.card p{margin:0;color:var(--muted)}
.about{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about .art{aspect-ratio:1/1}
.price{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tier{background:var(--card);border:1px solid rgba(128,128,128,.14);border-radius:var(--radius);padding:32px;text-align:center}
.tier.pop{border-color:var(--accent);box-shadow:0 18px 44px rgba(0,0,0,.12)}
.amt{font-size:2.2rem;font-weight:800;margin:12px 0;color:var(--accent)}
.menu-list{max-width:720px;margin:0 auto;display:grid;gap:12px}
.menu-item{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px dashed rgba(128,128,128,.25)}
.menu-item .pd{color:var(--accent);font-weight:700;white-space:nowrap}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{aspect-ratio:4/3;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent),var(--accent2));opacity:.92;display:flex;align-items:flex-end;padding:14px;color:#fff;font-weight:700}
.cta{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;text-align:center;border-radius:calc(var(--radius) + 8px);padding:56px 24px}
.cta h2{font-size:2rem;margin:0 0 12px}
.contact{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.field{width:100%;padding:13px 15px;border:1px solid rgba(128,128,128,.3);border-radius:var(--radius);margin-bottom:14px;font:inherit;background:var(--bg);color:var(--fg)}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.member{text-align:center}.member .ph{aspect-ratio:1/1;border-radius:20px;background:linear-gradient(135deg,var(--accent),var(--accent2));margin-bottom:12px}
.member b{display:block}.member span{color:var(--muted);font-size:.9rem}
.hours{max-width:520px;margin:0 auto}.hours .row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid rgba(128,128,128,.18)}
.faq{max-width:760px;margin:0 auto;display:grid;gap:12px}
.faq details{background:var(--card);border:1px solid rgba(128,128,128,.16);border-radius:var(--radius);padding:16px 20px}
.faq summary{font-weight:700;cursor:pointer}
.legal{max-width:800px}.legal h1{margin-top:0}.legal h2{margin-top:32px}
footer.site{background:var(--hbg);color:var(--hfg);padding:56px 0 28px}
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:32px}
.foot h4{margin:0 0 14px;font-size:.95rem;opacity:.75;text-transform:uppercase;letter-spacing:1px}
.foot .col a{display:block;opacity:.8;text-decoration:none;margin-bottom:9px;font-size:.95rem}.foot .col a:hover{opacity:1;color:var(--accent)}
.foot .brand{color:var(--hfg);margin-bottom:12px}
.foot-bottom{max-width:var(--maxw);margin:28px auto 0;padding:20px 24px 0;border-top:1px solid color-mix(in srgb,var(--hfg) 12%,transparent);opacity:.6;font-size:.85rem}
.muted{color:var(--muted)}
@media(max-width:860px){.hero.split .wrap,.about,.contact,.foot{grid-template-columns:1fr}.grid3,.price,.gallery,.team{grid-template-columns:1fr 1fr}
.nav-tog{display:block}
.nav ul{position:absolute;top:calc(100% + 1px);left:0;right:0;flex-direction:column;align-items:stretch;gap:4px;background:var(--hbg);padding:14px 18px;display:none;box-shadow:0 20px 40px rgba(0,0,0,.25)}
header.site.open .nav ul{display:flex}.nav ul .btn{justify-content:center;margin-top:6px}}
@media(max-width:520px){.grid3,.price,.gallery,.team{grid-template-columns:1fr}.hero{padding:72px 0 64px}}