/* ===== Da Oscar — dark vibrante retro-pop · nero + neon multicolor (rosa/arancio/giallo) ===== */
@font-face{font-family:'Unbounded';src:url('fonts/unbounded-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Unbounded';src:url('fonts/unbounded-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Unbounded';src:url('fonts/unbounded-800.woff2') format('woff2');font-weight:800;font-display:swap}
@font-face{font-family:'Unbounded';src:url('fonts/unbounded-900.woff2') format('woff2');font-weight:900;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-800.woff2') format('woff2');font-weight:800;font-display:swap}

:root{
  --bg:#0c0b11; --bg2:#13111b; --panel:#17151f; --panel2:#1d1a27;
  --ink:#f6f3ff; --muted:#a59fb8; --hair:rgba(255,255,255,.09);
  --pink:#ff4d94; --orange:#ff8c3b; --yellow:#ffd166; --violet:#9b5cff;
  --grad:linear-gradient(95deg,#ff4d94 0%,#ff8c3b 48%,#ffd166 100%);
  --grad-soft:linear-gradient(95deg,rgba(255,77,148,.16),rgba(255,140,59,.13),rgba(255,209,102,.14));
  --r:18px; --rl:28px; --maxw:1200px; --head:74px;
  --shadow:0 24px 60px -28px rgba(0,0,0,.7);
}
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:clip;scroll-padding-top:calc(var(--head) + 14px);-webkit-text-size-adjust:100%}
body{overflow-x:clip;font-family:'Manrope',system-ui,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;letter-spacing:.005em}
body.noscroll{overflow:hidden}
h1,h2,h3,h4{font-family:'Unbounded',system-ui,sans-serif;font-weight:800;line-height:1.04;letter-spacing:-.01em}
h1,h2,h3,h4,p,span,a,li{overflow-wrap:break-word}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
[hidden]{display:none!important}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.kicker{font-family:'Unbounded';font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--yellow)}

/* ===== background field: subtle moving neon glows ===== */
.bgfx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;mix-blend-mode:screen}
.blob.b1{width:560px;height:560px;background:radial-gradient(circle,var(--pink),transparent 65%);top:-180px;left:-120px;animation:drift1 22s ease-in-out infinite}
.blob.b2{width:520px;height:520px;background:radial-gradient(circle,var(--orange),transparent 65%);top:30%;right:-160px;animation:drift2 28s ease-in-out infinite}
.blob.b3{width:480px;height:480px;background:radial-gradient(circle,var(--violet),transparent 65%);bottom:-160px;left:30%;animation:drift3 26s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(80px,60px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-70px,40px)}}
@keyframes drift3{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,-50px)}}
main,header,footer{position:relative;z-index:1}

/* ===== intro / preloader ===== */
.intro{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:26px;transition:opacity .7s ease,transform .7s cubic-bezier(.7,0,.2,1)}
.intro.out{opacity:0;transform:translateY(-22px);pointer-events:none}
.intro-ring{position:relative;width:200px;height:200px;display:grid;place-items:center}
.intro-ring::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,var(--pink),var(--orange),var(--yellow),var(--violet),var(--pink));
  animation:spin 3.4s linear infinite;-webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 13px),#000 calc(100% - 12px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 13px),#000 calc(100% - 12px))}
.intro-ring img{width:118px;height:118px;border-radius:50%;animation:logopop 1.1s cubic-bezier(.2,.9,.2,1.2) both}
@keyframes logopop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.07)}100%{transform:scale(1);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
.intro-word{font-family:'Unbounded';font-weight:900;font-size:clamp(1.5rem,6vw,2.6rem);letter-spacing:.02em}
.intro-sub{font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}

/* ===== header ===== */
header{position:sticky;top:0;z-index:60;backdrop-filter:saturate(140%) blur(14px);
  background:rgba(12,11,17,.72);border-bottom:1px solid var(--hair);transition:background .3s}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--head);gap:18px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:54px;width:54px;border-radius:50%;object-fit:contain;background:#000;padding:3px}
.brand .bt{font-family:'Unbounded';font-weight:800;font-size:1.18rem;line-height:1}
.brand .bs{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow);display:block;margin-top:3px}
.menu-links{display:flex;align-items:center;gap:4px}
.menu-links a{font-weight:600;font-size:.94rem;padding:9px 13px;border-radius:11px;color:var(--ink);opacity:.85;transition:.2s}
.menu-links a:hover,.menu-links a.active{opacity:1;background:var(--grad-soft)}
.nav-right{display:flex;align-items:center;gap:10px}
.langbtn{display:flex;align-items:center;gap:7px;padding:8px 12px;border-radius:999px;border:1px solid var(--hair);
  background:var(--panel);font-weight:600;font-size:.86rem;cursor:pointer;color:var(--ink)}
.langbtn:hover{border-color:var(--pink)}
.langbtn .chev{opacity:.6;font-size:.7rem}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-family:'Manrope';cursor:pointer;
  border:none;border-radius:999px;padding:12px 20px;font-size:.92rem;transition:transform .15s,box-shadow .2s;white-space:nowrap}
.btn-grad{background:var(--grad);color:#1a0d13;box-shadow:0 10px 30px -10px rgba(255,77,148,.6)}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(255,140,59,.65)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--hair)}
.btn-ghost:hover{border-color:var(--pink)}
.hamb{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--hair);
  border-radius:12px;background:var(--panel);cursor:pointer;align-items:center;justify-content:center}
.hamb span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.hamb.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamb.open span:nth-child(2){opacity:0}
.hamb.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;background:rgba(8,7,12,.96);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;padding:28px 24px;gap:8px;transform:translateX(100%);transition:transform .4s cubic-bezier(.7,0,.2,1);
  pointer-events:none;overflow-y:auto}
.drawer.open{transform:translateX(0);pointer-events:auto}
.drawer .dh{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.drawer .dx{width:44px;height:44px;border:1px solid var(--hair);border-radius:12px;background:var(--panel);font-size:1.4rem;cursor:pointer;color:var(--ink)}
.drawer a{font-family:'Unbounded';font-weight:700;font-size:1.5rem;padding:13px 6px;border-bottom:1px solid var(--hair)}
.drawer a:active{color:var(--pink)}
.drawer .dcta{margin-top:auto;display:flex;flex-direction:column;gap:10px}

/* ===== hero ===== */
.hero{padding:clamp(40px,7vw,84px) 0 clamp(36px,5vw,60px);position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.hero h1{font-size:clamp(2.3rem,6.2vw,4.6rem);font-weight:900;margin:16px 0 18px}
.hero h1 .yr{display:inline-block}
.hero-sub{font-size:clamp(1rem,2vw,1.18rem);color:var(--muted);max-width:46ch;margin-bottom:26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px}
.hero-media{position:relative}
.hero-photo{position:relative;border-radius:var(--rl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);
  border:1px solid var(--hair)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(12,11,17,.55))}
.hero-ring{position:absolute;width:140px;height:140px;right:-26px;top:-26px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--pink),var(--orange),var(--yellow),var(--violet),var(--pink));
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 17px),#000 calc(100% - 16px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 17px),#000 calc(100% - 16px));animation:spin 9s linear infinite;z-index:2}
.hero-chip{position:absolute;left:-18px;bottom:26px;background:var(--panel);border:1px solid var(--hair);
  border-radius:16px;padding:12px 16px;box-shadow:var(--shadow);z-index:2}
.hero-chip b{font-family:'Unbounded';display:block;font-size:1.2rem}
.hero-chip span{font-size:.78rem;color:var(--muted)}
.scrollcue{margin-top:30px;display:inline-flex;align-items:center;gap:9px;color:var(--muted);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase}
.scrollcue i{width:22px;height:34px;border:2px solid var(--hair);border-radius:12px;position:relative;display:inline-block}
.scrollcue i::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:3px;background:var(--yellow);transform:translateX(-50%);animation:cue 1.5s infinite}
@keyframes cue{0%{opacity:0;transform:translate(-50%,-3px)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,11px)}}

/* ===== ticker / marquee ribbon ===== */
.ribbon{overflow:hidden;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  background:var(--grad);padding:13px 0}
.ribbon .track{display:flex;width:max-content;animation:marq 26s linear infinite}
.ribbon:hover .track{animation-play-state:paused}
.ribbon span{font-family:'Unbounded';font-weight:800;font-size:1.05rem;color:#180c11;padding:0 26px;white-space:nowrap;letter-spacing:.01em}
.ribbon .dot{color:#180c11;opacity:.55}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===== sections ===== */
section{padding:clamp(54px,8vw,90px) 0}
.sec-head{max-width:720px;margin-bottom:38px}
.sec-head h2{font-size:clamp(1.8rem,4.4vw,3rem);margin:12px 0}
.sec-head p{color:var(--muted);font-size:1.05rem}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* feature cards */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat{background:var(--panel);border:1px solid var(--hair);border-radius:var(--rl);padding:26px;transition:transform .25s,border-color .25s}
.feat:hover{transform:translateY(-5px);border-color:var(--pink)}
.feat .ic{width:54px;height:54px;border-radius:15px;background:var(--grad-soft);display:grid;place-items:center;font-size:1.5rem;margin-bottom:16px}
.feat h3{font-size:1.18rem;margin-bottom:8px}
.feat p{color:var(--muted);font-size:.96rem}

/* menu preview / full menu */
.menu-tabs{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}
.menu-tab{font-weight:700;font-size:.9rem;padding:9px 16px;border-radius:999px;border:1px solid var(--hair);
  background:var(--panel);cursor:pointer;color:var(--ink);transition:.2s}
.menu-tab:hover{border-color:var(--orange)}
.menu-tab.active{background:var(--grad);color:#1a0d13;border-color:transparent}
.menu-cat{margin-bottom:14px}
.menu-cat h3{font-size:1.5rem;margin:30px 0 14px;display:flex;align-items:center;gap:12px}
.menu-cat h3::before{content:"";width:34px;height:4px;border-radius:3px;background:var(--grad)}
.menu-list{display:grid;gap:2px}
.menu-row{display:flex;align-items:baseline;gap:12px;padding:11px 0;border-bottom:1px dashed var(--hair)}
.menu-row .nm{font-weight:600;font-size:1.04rem}
.menu-row .ds{font-size:.84rem;color:var(--muted);display:block;margin-top:2px}
.menu-row .ln{flex:1;border-bottom:1px dotted rgba(255,255,255,.16);transform:translateY(-4px);min-width:18px}
.menu-row .pr{font-family:'Unbounded';font-weight:700;font-size:1rem;color:var(--yellow);white-space:nowrap}
.menu-note{color:var(--muted);font-size:.86rem;margin-top:22px;padding:14px 18px;background:var(--panel);border:1px solid var(--hair);border-radius:14px}

/* about / story */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.about-grid .imgwrap{border-radius:var(--rl);overflow:hidden;aspect-ratio:4/5;border:1px solid var(--hair);box-shadow:var(--shadow)}
.about-grid .imgwrap img{width:100%;height:100%;object-fit:cover}
.about-grid p{color:var(--muted);margin-bottom:16px}
.about-grid p strong{color:var(--ink)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}
.stat{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:22px 18px;text-align:center}
.stat b{font-family:'Unbounded';font-weight:900;font-size:clamp(1.8rem,4vw,2.6rem);display:block}
.stat span{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery figure{position:relative;aspect-ratio:1/1;border-radius:var(--r);overflow:hidden;cursor:pointer;border:1px solid var(--hair);margin:0}
.gallery figure.tall{aspect-ratio:1/1}
.gallery figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery figure:hover img{transform:scale(1.08)}
.gallery figure figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 14px 12px;
  background:linear-gradient(transparent,rgba(8,7,12,.85));font-size:.82rem;font-weight:600;opacity:0;transition:.3s}
.gallery figure:hover figcaption{opacity:1}

/* lightbox */
.lbx{position:fixed;inset:0;z-index:200;background:rgba(6,5,10,.94);display:flex;align-items:center;justify-content:center;padding:30px}
.lbx img{max-width:92vw;max-height:86vh;border-radius:14px;box-shadow:var(--shadow)}
.lbx .lx{position:absolute;top:20px;right:24px;width:48px;height:48px;border-radius:50%;border:1px solid var(--hair);background:var(--panel);color:var(--ink);font-size:1.5rem;cursor:pointer}
.lbx .la{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:1px solid var(--hair);background:var(--panel);color:var(--ink);font-size:1.6rem;cursor:pointer}
.lbx .la.prev{left:18px}.lbx .la.next{right:18px}

/* reviews marquee */
.rev-agg{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:30px}
.rev-badge{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--hair);border-radius:16px;padding:14px 20px}
.rev-badge b{font-family:'Unbounded';font-weight:900;font-size:1.7rem}
.rev-badge .st{color:var(--yellow);font-size:1.05rem;letter-spacing:1px}
.rev-badge span{color:var(--muted);font-size:.85rem}
.marquee{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee-track{display:flex;width:max-content;gap:18px;animation:marq 60s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.rev-card{width:340px;flex-shrink:0;background:var(--panel);border:1px solid var(--hair);border-radius:var(--rl);padding:22px}
.rev-card .st{color:var(--yellow);font-size:1rem;letter-spacing:1px;margin-bottom:9px}
.rev-card p{font-size:.96rem;margin-bottom:14px}
.rev-card .who{display:flex;align-items:center;gap:11px}
.rev-card .av{width:40px;height:40px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
  font-family:'Unbounded';font-weight:800;color:#1a0d13;flex-shrink:0}
.rev-card .nm{font-weight:700;font-size:.92rem;display:block}
.rev-card .src{font-size:.76rem;color:var(--muted)}

/* contact */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:26px}
.loc-card{background:var(--panel);border:1px solid var(--hair);border-radius:var(--rl);padding:26px}
.loc-card .bd{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#1a0d13;background:var(--grad);padding:5px 11px;border-radius:999px;margin-bottom:14px}
.loc-card h3{font-size:1.4rem;margin-bottom:6px}
.loc-card .zone{color:var(--yellow);font-size:.9rem;margin-bottom:16px}
.loc-card .ln{display:flex;gap:11px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--hair);font-size:.96rem}
.loc-card .ln .lb{color:var(--muted);min-width:96px;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;padding-top:2px}
.loc-card .cta-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hours-list{display:grid;gap:0}
.hours-list .hr{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--hair);font-size:.95rem}
.hours-list .hr.closed{color:var(--muted)}
.map-wrap{border-radius:var(--rl);overflow:hidden;border:1px solid var(--hair);height:380px}
.map-wrap iframe{width:100%;height:100%;border:0;filter:saturate(.9) contrast(1.05)}

/* faq */
.faq-list{max-width:820px;margin:0 auto}
.faq-item{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);margin-bottom:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;color:var(--ink);font-family:'Manrope';
  font-weight:700;font-size:1.06rem;padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq-q .pl{font-size:1.4rem;color:var(--pink);transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-q .pl{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:var(--muted)}
.faq-a div{padding:0 22px 20px}
.faq-item.open .faq-a{max-height:340px}

/* cta band */
.cta-band{background:var(--grad-soft);border:1px solid var(--hair);border-radius:var(--rl);padding:clamp(34px,5vw,56px);text-align:center}
.cta-band h2{font-size:clamp(1.7rem,4vw,2.7rem);margin-bottom:14px}
.cta-band p{color:var(--muted);max-width:50ch;margin:0 auto 24px}
.cta-band .row{display:flex;flex-wrap:wrap;gap:13px;justify-content:center}

/* page header (subpages) */
.phead{padding:clamp(46px,7vw,80px) 0 10px;text-align:center}
.phead h1{font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:900;margin:14px 0}
.phead p{color:var(--muted);max-width:60ch;margin:0 auto;font-size:1.08rem}

/* footer */
footer{border-top:1px solid var(--hair);background:var(--bg2);padding:54px 0 30px;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:34px;margin-bottom:34px}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.foot-brand img{height:56px;width:56px;border-radius:50%;background:#000;padding:3px;object-fit:contain}
.foot-brand b{font-family:'Unbounded';font-size:1.2rem}
.foot-col h4{font-family:'Unbounded';font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--yellow);margin-bottom:14px}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:.93rem;margin-bottom:9px}
.foot-col a:hover{color:var(--ink)}
.socials{display:flex;gap:10px;margin-top:8px}
.socials a{width:42px;height:42px;border-radius:50%;border:1px solid var(--hair);display:grid;place-items:center;background:var(--panel)}
.socials a:hover{border-color:var(--pink)}
.foot-bot{border-top:1px solid var(--hair);padding-top:22px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:var(--muted);font-size:.84rem}

/* FAB */
.fab{position:fixed;right:18px;bottom:18px;z-index:70;display:flex;flex-direction:column;gap:11px}
.fab a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);transition:transform .2s}
.fab a:hover{transform:scale(1.08)}
.fab .wa{background:#25d366}
.fab .ph{background:var(--grad)}
.fab a svg{width:27px;height:27px}

/* language modal */
.lang-modal{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px}
.lang-modal .bd{position:absolute;inset:0;background:rgba(6,5,10,.55);backdrop-filter:blur(3px);animation:fade .25s}
.lang-card{position:relative;width:min(420px,92vw);max-height:78vh;background:var(--panel2);border:1px solid var(--hair);
  border-radius:var(--rl);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;animation:pop .3s cubic-bezier(.2,.9,.2,1.05)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:scale(.96);filter:blur(4px)}to{opacity:1;transform:scale(1);filter:blur(0)}}
.lang-card .lh{display:flex;justify-content:space-between;align-items:center;padding:20px 22px 14px}
.lang-card .lh h3{font-size:1.15rem}
.lang-card .lx{width:38px;height:38px;border-radius:50%;border:1px solid var(--hair);background:var(--panel);color:var(--ink);font-size:1.25rem;cursor:pointer}
.lang-card .lsearch{margin:0 22px 12px;display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--hair);border-radius:12px;padding:11px 14px}
.lang-card .lsearch input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-family:'Manrope';font-size:.96rem}
.lang-list{overflow-y:auto;padding:4px 14px 16px}
.lang-row{width:100%;display:flex;align-items:center;gap:13px;padding:13px 12px;border-radius:13px;border:none;background:none;color:var(--ink);font-family:'Manrope';font-size:1rem;font-weight:600;cursor:pointer;text-align:left}
.lang-row:hover{background:var(--grad-soft)}
.lang-row .fl{font-size:1.35rem}
.lang-row .ck{margin-left:auto;color:var(--pink);font-weight:800;opacity:0}
.lang-row.active .ck{opacity:1}
.lang-row.active{background:var(--grad-soft)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== responsive ===== */
@media(max-width:1024px){
  .menu-links{display:none}
  .hamb{display:flex}
  .nav-right .btn-grad{display:none}
}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .hero-media{max-width:420px;margin:0 auto}
  .about-grid{grid-template-columns:1fr;gap:28px}
  .about-grid .imgwrap{max-width:440px;margin:0 auto;aspect-ratio:5/4}
  .feats{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .loc-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:24px}
}
/* phones: keep header on one tidy line, no overlaps */
@media(max-width:640px){
  .nav{gap:10px}
  .brand{min-width:0}
  .brand .bs{display:none}            /* long tagline crowds the logo+lang+hamburger on phones */
  .nav-right{gap:8px}
  .langbtn{padding:8px 10px}
  /* hero multicolor ring must not sit over the text/photo edge on small screens */
  .hero-ring{width:100px;height:100px;right:-12px;top:-12px}
  .hero-chip{left:-8px}
}
@media(max-width:520px){
  body{font-size:16px}
  .wrap{padding:0 16px}
  .brand img{height:44px;width:44px}
  .brand .bt{font-size:1.02rem}
  .gallery{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .rev-card{width:280px}
  .menu-row .pr{font-size:.92rem}
  .fab a{width:52px;height:52px}
  .hero-chip{left:50%;transform:translateX(-50%);bottom:-18px}
  .hero-media{padding-bottom:14px}
}
@media(max-width:380px){
  .nav{gap:8px}
  .brand img{height:40px;width:40px}
  .brand .bt{font-size:.94rem}
  .langbtn{padding:7px 9px;font-size:.8rem}
  .langbtn .chev{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.1ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .blob{animation:none!important}
  .marquee-track,.ribbon .track{animation:marq 60s linear infinite!important}
  .intro-ring::before{animation:spin 3s linear infinite!important}
}
