:root {
  --teal: #f59e0b;
  --teal-light: #fbbf24;
  --teal-glow: rgba(245,158,11,0.25);
  --orange: #ef4444;
  --dark: #0d0d0d;
  --dark2: #1a1208;
  --dark3: #1c1508;
  --text: #edf6f5;
  --muted: #a89880;
  --border: rgba(245,158,11,0.2);
  --fd: 'Playfair Display', serif;
  --fb: 'Be Vietnam Pro', sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{background:var(--dark);color:var(--text);font-family:var(--fb);overflow-x:clip}

@keyframes fadeUp{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes smoke{0%{transform:translateY(0) scale(1);opacity:.4}100%{transform:translateY(-90px) scale(2);opacity:0}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
@keyframes glow{0%,100%{text-shadow:0 0 30px rgba(245,158,11,.3)}50%{text-shadow:0 0 60px rgba(245,158,11,.7),0 0 100px rgba(245,158,11,.2)}}
@keyframes scan{0%,100%{border-color:rgba(245,158,11,.15)}50%{border-color:rgba(245,158,11,.6)}}
@keyframes gallery{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes reveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0% 0 0)}}

/* ── NAVBAR ── */
#nav{position:fixed;inset:0 0 auto;z-index:100;padding:18px 40px;display:flex;align-items:center;justify-content:space-between;transition:all .4s}
#nav.solid{background:rgba(13,13,13,.95);backdrop-filter:blur(16px);padding:12px 40px;border-bottom:1px solid var(--border)}
.logo{font-family:var(--fd);font-size:1.25rem;color:var(--teal);text-decoration:none;letter-spacing:.04em;animation:glow 3s ease-in-out infinite}
.logo em{color:var(--orange);font-style:normal}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--teal)}
.lang-bar{display:flex;gap:3px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:40px;padding:4px}
.lb{background:none;border:none;cursor:pointer;color:var(--muted);font-family:var(--fb);font-size:.72rem;font-weight:600;padding:4px 12px;border-radius:40px;transition:all .2s;white-space:nowrap}
.lb:hover{color:var(--text)}
.lb.on{background:var(--teal);color:#0d0d0d;font-weight:700}
.hbg{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-direction:column;gap:5px}
.hbg span{display:block;width:22px;height:2px;background:var(--teal);transition:all .3s;border-radius:2px}
@media(max-width:800px){.nav-links{display:none}.hbg{display:flex}}
@media(max-width:640px){#nav{padding-left:16px;padding-right:16px}#nav.solid{padding-left:16px;padding-right:16px}.logo{font-size:1.05rem}}

/* ── HERO ── */
#hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;transform:scale(1.06);transition:transform .1s linear}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(13,13,13,.2) 0%,rgba(13,13,13,.55) 45%,rgba(13,13,13,.9) 100%)}
.hero-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(13,13,13,.6) 100%)}

.hero-inner{position:relative;z-index:2;text-align:center;padding:0 24px;max-width:900px}

.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--teal);font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;margin-bottom:24px;opacity:0;animation:fadeDown .6s ease forwards .4s}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';display:block;width:28px;height:1px;background:var(--teal);opacity:.6}

.hero-h1{font-family:var(--fd);line-height:1.0;margin-bottom:8px}
.hero-h1 .l1{display:block;font-size:clamp(1rem,2.5vw,1.6rem);font-weight:400;font-style:italic;color:var(--muted);letter-spacing:.1em;opacity:0;animation:fadeDown .6s ease forwards .6s}
.hero-h1 .l2{display:block;font-size:clamp(3.5rem,9vw,7.5rem);font-weight:900;line-height:.92;letter-spacing:-.02em;color:var(--text);opacity:0;animation:fadeDown .7s ease forwards .8s}
.hero-h1 .l3{display:block;font-size:clamp(2rem,5vw,4rem);font-weight:700;color:var(--teal);opacity:0;animation:fadeDown .7s ease forwards 1s;animation:fadeDown .7s ease forwards 1s, glow 3s 1.8s ease-in-out infinite}

.hero-tagline{margin:28px 0 36px;color:var(--muted);font-size:1rem;letter-spacing:.04em;opacity:0;animation:fadeIn .8s ease forwards 1.3s}
.hero-tagline span{color:var(--teal)}

.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .7s ease forwards 1.5s}
.btn-t{background:var(--teal);color:#0d0d0d;font-weight:700;font-size:.85rem;letter-spacing:.06em;padding:14px 32px;border:none;border-radius:2px;cursor:pointer;text-decoration:none;transition:all .25s;display:inline-flex;align-items:center;gap:8px;text-transform:uppercase}
.btn-t:hover{background:var(--teal-light);transform:translateY(-3px);box-shadow:0 10px 30px rgba(245,158,11,.35)}
.btn-o{background:transparent;color:var(--text);font-weight:600;font-size:.85rem;letter-spacing:.06em;padding:14px 32px;border:1px solid rgba(255,255,255,.2);border-radius:2px;cursor:pointer;text-decoration:none;transition:all .25s;display:inline-flex;align-items:center;gap:8px;text-transform:uppercase}
.btn-o:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-3px)}

.smoke-wrap{position:absolute;bottom:22%;left:0;right:0;pointer-events:none;z-index:1}
.smoke{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.18),transparent 70%);animation:smoke 5s ease-out infinite}
.smoke:nth-child(1){left:18%;width:32px;height:32px;animation-delay:0s}
.smoke:nth-child(2){left:42%;width:52px;height:52px;animation-delay:1.4s}
.smoke:nth-child(3){left:62%;width:36px;height:36px;animation-delay:.8s}
.smoke:nth-child(4){left:76%;width:46px;height:46px;animation-delay:2.2s}
.smoke:nth-child(5){left:50%;width:28px;height:28px;animation-delay:3s}

.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted);font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;opacity:0;animation:fadeIn 1s ease forwards 2.2s}
.hero-scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--teal),transparent);animation:bounce 1.8s ease-in-out infinite}

/* ── STATS BAR ── */
#stats{background:var(--dark2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:32px 24px;text-align:center;border-right:1px solid var(--border);transition:background .3s}
.stat:hover{background:rgba(245,158,11,.06)}
.stat:last-child{border-right:none}
.stat-n{font-family:var(--fd);font-size:2.8rem;font-weight:900;color:var(--teal);line-height:1;margin-bottom:6px}
.stat-l{color:var(--muted);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
@media(max-width:640px){.stats-row{grid-template-columns:repeat(2,1fr)}.stat{border-bottom:1px solid var(--border)}.stat:nth-child(2),.stat:nth-child(4){border-right:none}}

/* ── SHARED ── */
.section{padding:100px 0}
.container{max-width:1240px;margin:0 auto;padding:0 40px}
@media(max-width:640px){.container{padding:0 20px}.section{padding:70px 0}}
.label{display:inline-flex;align-items:center;gap:8px;color:var(--teal);font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px}
.label::before{content:'';display:block;width:20px;height:1px;background:var(--teal)}
.title{font-family:var(--fd);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;line-height:1.15;margin-bottom:16px}
.divider{width:48px;height:2px;background:linear-gradient(to right,var(--teal),var(--orange));margin:20px 0;border-radius:1px}

.sh{opacity:0;transition:opacity .65s ease,transform .65s ease}
.sh.vis{opacity:1;transform:none!important}

/* ── WHY ── */
#why{background:var(--dark)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:60px}
.why-card{background:var(--dark2);padding:44px 36px;transition:background .3s;position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--teal),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.why-card:hover{background:var(--dark3)}
.why-card:hover::before{transform:scaleX(1)}
.why-num{font-family:var(--fd);font-size:5rem;font-weight:900;color:rgba(245,158,11,.08);line-height:1;margin-bottom:16px;transition:color .3s}
.why-card:hover .why-num{color:rgba(245,158,11,.15)}
.why-icon{font-size:2rem;margin-bottom:16px;display:block}
.why-h{font-family:var(--fd);font-size:1.2rem;color:var(--text);margin-bottom:10px}
.why-p{color:var(--muted);font-size:.88rem;line-height:1.8}
@media(max-width:800px){.why-grid{grid-template-columns:1fr}}

/* ── MENU — MOSAIC GRID ── */
#menu{background:linear-gradient(to bottom,var(--dark),var(--dark2))}
.menu-top{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:56px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.fb{background:none;border:1px solid var(--border);color:var(--muted);font-family:var(--fb);font-size:.75rem;font-weight:600;letter-spacing:.08em;padding:7px 20px;border-radius:0;cursor:pointer;transition:all .2s;text-transform:uppercase}
.fb:hover,.fb.on{background:var(--teal);border-color:var(--teal);color:#0d0d0d}

/* Mosaic layout */
.mosaic{display:grid;gap:3px}
.mosaic-row{display:grid;gap:3px}
.mosaic-row.r1{grid-template-columns:2fr 1fr 1fr}
.mosaic-row.r2{grid-template-columns:1fr 1fr 2fr}

.mc{position:relative;overflow:hidden;cursor:pointer;background:var(--dark3)}
.mc.tall{grid-row:span 1}
.mc-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block}
.mc:hover .mc-img{transform:scale(1.06)}

.mc-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.92) 0%,rgba(13,13,13,.3) 50%,transparent 100%);opacity:0;transition:opacity .35s;display:flex;flex-direction:column;justify-content:flex-end;padding:24px}
.mc:hover .mc-over{opacity:1}
.mc-tag{position:absolute;top:14px;left:14px;background:var(--teal);color:#0d0d0d;font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:0}
.mc-name{font-family:var(--fd);font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:5px;transform:translateY(8px);transition:transform .35s}
.mc:hover .mc-name{transform:translateY(0)}
.mc-desc{color:rgba(255,255,255,.7);font-size:.78rem;line-height:1.6;transform:translateY(8px);transition:transform .35s .05s;opacity:0}
.mc:hover .mc-desc{transform:translateY(0);opacity:1}

/* Mosaic heights */
.mosaic-row{height:280px}
@media(max-width:900px){.mosaic-row.r1,.mosaic-row.r2{grid-template-columns:1fr 1fr;height:220px}}
@media(max-width:560px){.mosaic-row.r1,.mosaic-row.r2{grid-template-columns:1fr;height:240px}}

/* ── GALLERY STRIP ── */
#gstrip{overflow:hidden;line-height:0;padding:3px 0;background:var(--dark2)}
.gtrack{display:flex;animation:gallery 28s linear infinite;width:max-content}
.gtrack:hover{animation-play-state:paused}
.gi{width:240px;height:180px;flex-shrink:0;overflow:hidden;margin:0 2px}
.gi img{width:100%;height:100%;object-fit:cover;filter:brightness(.8) saturate(1.1);transition:all .4s}
.gi:hover img{filter:brightness(1) saturate(1.3);transform:scale(1.04)}

/* ── TESTIMONIALS ── */
#testi{background:var(--dark)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:56px}
.tc{background:var(--dark2);padding:36px 32px;transition:background .3s;animation:scan 5s ease-in-out infinite;border:1px solid transparent}
.tc:nth-child(2){animation-delay:1.6s}
.tc:nth-child(3){animation-delay:3.2s}
.tc:hover{background:var(--dark3)}
.tc-stars{color:var(--teal);font-size:1rem;letter-spacing:3px;margin-bottom:20px}
.tc-quote{color:var(--text);font-size:.9rem;line-height:1.82;font-style:italic;margin-bottom:24px;padding-left:18px;border-left:2px solid var(--teal);position:relative}
.tc-aut{display:flex;align-items:center;gap:12px}
.tc-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--orange));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:800;color:#0d0d0d;font-size:.95rem;flex-shrink:0}
.tc-name{font-weight:600;font-size:.88rem}
.tc-loc{color:var(--muted);font-size:.75rem}
@media(max-width:800px){.testi-grid{grid-template-columns:1fr}}

/* ── CONTACT ── */
#contact{background:var(--dark2);border-top:1px solid var(--border)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:56px;align-items:start}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.info-row:last-child{border-bottom:none}
.info-ic{width:40px;height:40px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;color:var(--teal)}
.info-lbl{color:var(--muted);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}
.info-val{font-size:.95rem;font-weight:500}
.info-val a{color:var(--teal);text-decoration:none}
.info-val a:hover{color:var(--teal-light)}
.map-wrap{height:340px;border:1px solid var(--border);overflow:hidden}
.map-wrap iframe{width:100%;height:100%;border:none}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}

/* ── FOOTER ── */
footer{background:#070707;border-top:1px solid var(--border);padding:36px 40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.foot-logo{font-family:var(--fd);font-size:1.3rem;color:var(--teal);animation:glow 4s ease-in-out infinite}
.foot-copy{color:var(--muted);font-size:.78rem}

.fade-t{transition:opacity .22s}
.fade-t.fading{opacity:0}