*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#009fb2;
  --teal-dark:#007f8f;
  --gold:#e9b934;
  --ink:#0b1017;
  --ink-soft:#17202b;
  --white:#fff;
  --off-white:#f6f8f9;
  --gray:#738293;
  --line:#e4e9ee;
  --shadow:0 16px 36px rgba(11,16,23,.12);
}
html{scroll-behavior:smooth}
body{font-family:'Inter',Arial,sans-serif;background:var(--white);color:var(--ink);overflow-x:hidden}
body.menu-open{overflow:hidden}
img,video,iframe{max-width:100%}
a{color:inherit}
.skip-link{position:fixed;left:16px;top:12px;z-index:300;background:#fff;color:var(--ink);padding:10px 14px;border-radius:6px;font-weight:800;text-decoration:none;box-shadow:0 10px 24px rgba(0,0,0,.22);transform:translateY(-140%);transition:transform .2s}
.skip-link:focus{transform:translateY(0)}

/* Performance */
img {
  object-fit: cover;
}
.hero-slide {
  backface-visibility: hidden;
}
.gallery-item img, .cat-card img {
  content-visibility: auto;
  object-position: center;
  background: linear-gradient(110deg, #1a2430 8%, #243040 18%, #1a2430 33%);
  background-size: 200% 100%;
}
.gallery-item img.loaded, .cat-card img[src] {
  background: #0b1017;
}
.gallery-item img.error {
  background: linear-gradient(135deg, #00aabd, #006880);
}
.gallery-sentinel {
  width: 100%;
  height: 1px;
  grid-column: 1 / -1;
}
.gallery-sentinel--hidden {
  display: none;
}
.page-hidden .marquee-track,
.marquee-track.paused {
  animation-play-state: paused;
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
  .gallery-item, .gallery-item img { transition: none; }
}
@media (hover: hover) {
  .gallery-item:hover { transform: translateY(-5px); box-shadow: 0 15px 32px rgba(0, 159, 178, 0.25); }
  .gallery-item:hover img { transform: scale(1.04); }
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px clamp(18px,4vw,48px);
  background:rgba(11,16,23,.88);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  transition:padding .25s,background .25s,box-shadow .25s;
}
nav.scrolled{padding-top:11px;padding-bottom:11px;background:rgba(11,16,23,.96);box-shadow:0 12px 28px rgba(0,0,0,.2)}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;min-width:0;z-index:110}
.nav-logo-img{width:62px;height:auto;object-fit:contain;border-radius:5px;display:block}
.nav-wordmark{font-family:'Syne',Arial,sans-serif;font-weight:800;font-size:14px;color:#fff;line-height:1.05;letter-spacing:.02em}
.nav-wordmark span{color:var(--teal)}
.nav-links{display:flex;gap:24px;list-style:none;align-items:center}
.nav-links a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14px;font-weight:600;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--teal)}
.nav-cta,.drawer-cta{background:var(--teal);color:#fff!important;padding:10px 18px;border-radius:8px;font-weight:800!important}
.nav-cta:hover,.drawer-cta:hover{background:var(--teal-dark)}
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer;flex-direction:column;gap:6px;padding:8px;z-index:110}
.hamburger-line{width:25px;height:2px;background:#fff;transition:transform .25s,opacity .25s}
.nav-toggle.active .hamburger-line:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.active .hamburger-line:nth-child(2){opacity:0}
.nav-toggle.active .hamburger-line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.nav-drawer{position:fixed;inset:0;z-index:99;background:rgba(11,16,23,.98);display:flex;align-items:center;justify-content:center;transform:translateY(-100%);transition:transform .32s}
.nav-drawer.open{transform:translateY(0)}
.drawer-links{list-style:none;display:flex;flex-direction:column;align-items:center;gap:26px;text-align:center}
.drawer-links a{font-family:'Syne',Arial,sans-serif;font-size:25px;font-weight:800;color:#fff;text-decoration:none}

/* FLOATS */
.lang-float,.back-to-top{
  position:fixed;z-index:90;border:0;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:0 10px 28px rgba(0,0,0,.24);transition:transform .2s,opacity .2s,visibility .2s,background .2s;
}
.lang-float{left:24px;bottom:24px;width:54px;height:54px;background:var(--ink-soft);border:2px solid var(--teal);color:#fff;font-weight:800}
.lang-float:hover{background:var(--teal);transform:translateY(-3px)}
.lang-tooltip{position:absolute;left:68px;background:var(--ink-soft);color:#fff;padding:7px 12px;border-radius:6px;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:.2s}
.lang-float:hover .lang-tooltip{opacity:1;visibility:visible}
.back-to-top{right:24px;bottom:24px;width:48px;height:48px;background:var(--teal);opacity:0;visibility:hidden;transform:translateY(14px)}
.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2.5}

/* HERO */
.hero{min-height:88vh;position:relative;display:flex;align-items:center;overflow:hidden;background:var(--ink)}

/* Hero background slideshow */
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center 28%;
  opacity:0;transition:opacity 1.2s ease-in-out;
  filter:brightness(.65) saturate(1.08);transform:scale(1.04);
  transition:opacity 1.2s ease-in-out, transform 8s ease-out;
}
.hero-slide.active{opacity:1;transform:scale(1)}

.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(11,16,23,.88) 0%,rgba(11,16,23,.55) 48%,rgba(11,16,23,.08) 100%)}
.hero-content{position:relative;z-index:2;width:min(1160px,100%);margin:0;padding:130px clamp(20px,4vw,48px) 60px;max-width:58%;margin-left:clamp(20px,4vw,100px)}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(0,159,178,.16);border:1px solid rgba(91,221,233,.28);color:#8af0f8;padding:8px 15px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;margin-bottom:22px}
.badge-dot{width:7px;height:7px;background:var(--gold);border-radius:50%;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(233,185,52,.6)}50%{box-shadow:0 0 0 6px rgba(233,185,52,0)}}
.hero-title{font-family:'Syne',Arial,sans-serif;color:#fff;font-size:clamp(40px,6vw,72px);line-height:1.02;font-weight:800;max-width:720px;margin-bottom:22px}
.teal{color:#58dce8}.gold{color:var(--gold)}
.hero-sub{font-size:clamp(15px,1.8vw,18px);line-height:1.68;color:rgba(255,255,255,.76);max-width:520px;margin-bottom:30px}
.hero-btns,.soc-btns{display:flex;gap:13px;flex-wrap:wrap}
.btn-p,.btn-o,.s-btn,.text-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;border-radius:10px;font-weight:800;transition:transform .2s,box-shadow .2s,background .2s}
.btn-p,.s-btn,.text-link{background:var(--teal);color:#fff;padding:14px 24px}
.btn-p:hover,.s-btn:hover,.text-link:hover{transform:translateY(-2px);box-shadow:0 12px 25px rgba(0,170,189,.25);background:var(--teal-dark)}
.btn-o{color:#fff;border:1px solid rgba(255,255,255,.25);padding:14px 24px}
.btn-o:hover{background:rgba(255,255,255,.08)}
.btn-p svg,.btn-o svg,.s-btn svg,.text-link svg{width:18px;height:18px;flex:0 0 auto}
.hero-stats{display:flex;gap:28px;flex-wrap:wrap;margin-top:44px;padding-top:26px;border-top:1px solid rgba(255,255,255,.13)}
.stat-n{font-family:'Syne',Arial,sans-serif;color:#fff;font-size:28px;font-weight:800}
.stat-n span{color:#58dce8;font-size:.65em;margin-left:2px}
.stat-l{color:rgba(255,255,255,.58);font-size:12px;margin-top:4px}

.countdown-wrap{max-width:460px;background:rgba(11,16,23,.52);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:17px 18px;margin-bottom:28px;backdrop-filter:blur(14px)}
.countdown-title{font-family:'Syne',Arial,sans-serif;color:#70e6f1;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px}
.countdown-grid{display:flex;align-items:center;gap:12px}
.countdown-card{min-width:64px;text-align:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px}
.countdown-num{font-family:'Syne',Arial,sans-serif;color:#fff;font-size:24px;font-weight:800;line-height:1}
.countdown-lbl{color:rgba(255,255,255,.58);font-size:9px;font-weight:800;text-transform:uppercase;margin-top:5px}
.countdown-dots{color:#70e6f1;font-weight:800}

/* Hero progress bar + slide dots */
.hero-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.12);z-index:3}
.hero-progress-bar{height:100%;background:var(--teal);width:0;transition:width .1s linear}
.hero-slide-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.hs-dot{width:8px;height:8px;border-radius:50%;border:0;background:rgba(255,255,255,.3);cursor:pointer;transition:background .2s,transform .2s;padding:0}
.hs-dot.active{background:var(--teal);transform:scale(1.35)}

/* ============================================
   ANDROID STUDIO-STYLE HERO CARD STACK
   ============================================ */
.hero-card-stack{
  position:absolute;
  right: clamp(20px, 5vw, 80px);
  top:42%;
  transform:translateY(-50%);
  z-index:3;
  width:clamp(220px,28vw,320px);
  height:clamp(280px,36vw,400px);
  pointer-events:none;
}
.hcs-card{
  position:absolute;
  inset:0;
  border-radius:20px;
  overflow:hidden;
  background:var(--ink-soft);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 24px 60px rgba(0,0,0,.55),0 0 0 1px rgba(0,180,200,.08);
  transition:transform .55s cubic-bezier(0.34,1.56,0.64,1), opacity .4s;
}
.hcs-card--back2{
  transform:translateY(20px) translateX(14px) scale(0.88) rotate(5deg);
  opacity:.35;
  background: linear-gradient(135deg,#1a2533,#0d1620);
  z-index:1;
}
.hcs-card--back1{
  transform:translateY(12px) translateX(7px) scale(0.93) rotate(2.5deg);
  opacity:.6;
  background: linear-gradient(135deg,#1d2c3e,#111a26);
  z-index:2;
}
.hcs-card--front{
  z-index:3;
  pointer-events:auto;
  transform:translateY(0) rotate(0deg) scale(1);
  cursor:pointer;
}
.hcs-card--front img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease;
}
.hcs-card--front:hover img{transform:scale(1.04)}
.hcs-card-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:18px;
  background:linear-gradient(to top, rgba(11,16,23,.96) 0%, transparent 100%);
}
.hcs-card-tag{font-size:10px;font-weight:800;color:#70e6f1;text-transform:uppercase;letter-spacing:.12em;margin-bottom:5px}
.hcs-card-title{font-family:'Syne',Arial,sans-serif;color:#fff;font-size:18px;font-weight:800;line-height:1.1}

/* Card nav buttons */
.hcs-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:10;
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(11,16,23,.72);
  backdrop-filter:blur(8px);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  pointer-events:auto;
  transition:background .2s, border-color .2s, transform .2s;
}
.hcs-nav:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-50%) scale(1.1)}
.hcs-nav svg{width:16px;height:16px}
.hcs-nav--prev{left:-18px}
.hcs-nav--next{right:-18px}

/* Swipe-in animation class */
.hcs-card--front.swipe-left{animation:hcsSwipeLeft .5s cubic-bezier(0.36,0.07,0.19,0.97) forwards}
.hcs-card--front.swipe-right{animation:hcsSwipeRight .5s cubic-bezier(0.36,0.07,0.19,0.97) forwards}
.hcs-card--front.swipe-in-left{animation:hcsInLeft .5s cubic-bezier(0.34,1.56,0.64,1) forwards}
.hcs-card--front.swipe-in-right{animation:hcsInRight .5s cubic-bezier(0.34,1.56,0.64,1) forwards}

@keyframes hcsSwipeLeft{0%{transform:translateX(0) rotate(0) scale(1);opacity:1}100%{transform:translateX(-140%) rotate(-12deg) scale(0.8);opacity:0}}
@keyframes hcsSwipeRight{0%{transform:translateX(0) rotate(0) scale(1);opacity:1}100%{transform:translateX(140%) rotate(12deg) scale(0.8);opacity:0}}
@keyframes hcsInLeft{0%{transform:translateX(100%) rotate(8deg) scale(0.85);opacity:0}100%{transform:translateX(0) rotate(0) scale(1);opacity:1}}
@keyframes hcsInRight{0%{transform:translateX(-100%) rotate(-8deg) scale(0.85);opacity:0}100%{transform:translateX(0) rotate(0) scale(1);opacity:1}}

/* HCS dots */
.hcs-dots{
  position:absolute;bottom:-26px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;pointer-events:auto;z-index:10;
}
.hcs-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.28);transition:background .2s, transform .2s}
.hcs-dot.active{background:var(--teal);transform:scale(1.3)}

/* OPENING BAR */
.ob{background:var(--ink-soft);border-top:2px solid var(--teal);padding:20px clamp(20px,4vw,48px);display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}
.ob-item,.time-widget{display:flex;align-items:center;gap:12px}
.ob-icon{width:42px;height:42px;border-radius:10px;background:rgba(0,170,189,.12);display:flex;align-items:center;justify-content:center}
.ob-icon svg{width:21px;height:21px;stroke:var(--teal);fill:none;stroke-width:1.8}
.ob-lbl,.c-lbl{font-size:10px;color:#62dce8;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.ob-val{font-family:'Syne',Arial,sans-serif;color:#fff;font-weight:800;font-size:17px}
.ob-div{width:1px;height:40px;background:rgba(255,255,255,.09)}
.ob-pill{background:var(--gold);color:var(--ink);padding:9px 18px;border-radius:999px;font-weight:900;font-size:13px}
.time-widget{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:9px 14px;color:#fff}
.time-dot{width:8px;height:8px;border-radius:50%;background:var(--gray)}
.time-dot.open{background:#25d366;box-shadow:0 0 10px #25d366}
.time-dot.closed{background:#ea4335;box-shadow:0 0 10px #ea4335}
.time-txt{font-size:13px}.time-txt span{font-weight:800;color:#70e6f1}

/* PAGE HERO (inner pages) */
.page-hero{padding:145px clamp(20px,4vw,48px) 66px;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(0,159,178,.2),rgba(11,16,23,0) 48%),url("../images/Exterior front view.jpg") center 28%/cover;filter:brightness(.5)}
.page-hero-inner{position:relative;width:min(1100px,100%);margin:0 auto}
.page-hero .st{color:#fff;max-width:720px}.page-hero .ss{color:rgba(255,255,255,.74);margin-bottom:0}

/* SECTIONS */
.sec,.soc-sec{padding:80px clamp(20px,4vw,48px);width:min(1200px,100%);margin:0 auto}
.section-band{padding:80px 0;background:var(--off-white)}
.section-dark{padding:80px 0;background:var(--ink);color:#fff}
.section-dark .st{color:#fff}.section-dark .ss{color:rgba(255,255,255,.64)}
.section-inner{width:min(1200px,100%);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.ey{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);margin-bottom:12px}
.st{font-family:'Syne',Arial,sans-serif;font-size:clamp(30px,4vw,48px);font-weight:800;line-height:1.08;color:var(--ink);margin-bottom:16px}
.ss{font-size:16px;color:var(--gray);max-width:610px;line-height:1.72;margin-bottom:38px}

.quick-strip{width:min(1200px,100%);margin:0 auto;padding:30px clamp(20px,4vw,48px);display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.quick-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:0 10px 24px rgba(11,16,23,.06)}
.quick-num{font-family:'Syne',Arial,sans-serif;color:var(--teal);font-weight:800;font-size:13px;background:rgba(0,159,178,.1);border-radius:6px;padding:7px 8px}
.quick-item h2{font-family:'Syne',Arial,sans-serif;font-size:16px;line-height:1.2;margin-bottom:5px}
.quick-item p{font-size:13px;line-height:1.55;color:var(--gray)}

.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}
.cat-card{position:relative;overflow:hidden;border-radius:8px;aspect-ratio:1/1;cursor:pointer;border:1px solid rgba(11,16,23,.08);box-shadow:0 10px 25px rgba(11,16,23,.08);background:#f0f4f7}
.cat-card img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .35s}
.cat-card:hover img{transform:scale(1.04)}
.cat-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,16,23,.9),rgba(11,16,23,.05) 62%);display:flex;flex-direction:column;justify-content:flex-end;padding:14px}
.cat-tag{font-size:8px;font-weight:800;color:#70e6f1;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.cat-name{font-family:'Syne',Arial,sans-serif;color:#fff;font-size:16px;font-weight:800;line-height:1.05}
@media(max-width:768px){
  .cat-ov{padding:10px}
  .cat-tag{font-size:7px;margin-bottom:3px}
  .cat-name{font-size:13px}
}
.cat-desc{font-size:14px;line-height:1.58;color:var(--gray);margin:15px 0 20px}
.shop-card{background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:0 14px 32px rgba(11,16,23,.08);transition:transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);}
.shop-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(11,16,23,.14)}
.shop-card .cat-card{border:0;border-radius:0;box-shadow:none;aspect-ratio:4/3}
.shop-body{padding:22px}

.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.dept-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:20px;box-shadow:0 10px 24px rgba(11,16,23,.05);min-height:168px;transition:transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1);}
.dept-card:hover{transform:translateY(-4px);border-color:var(--teal);box-shadow:0 14px 32px rgba(11,16,23,.08)}
.dept-card span{display:inline-flex;font-family:'Syne',Arial,sans-serif;font-size:12px;font-weight:800;color:var(--teal);margin-bottom:14px}
.dept-card h3{font-family:'Syne',Arial,sans-serif;font-size:18px;line-height:1.2;margin-bottom:8px}
.dept-card p{font-size:14px;line-height:1.6;color:var(--gray)}

.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.vid-wrap{position:relative;overflow:hidden;border-radius:8px;background:#000;border:1px solid rgba(255,255,255,.1)}
.vid-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.vid-wrap.landscape{aspect-ratio:16/9}
.vid-wrap.portrait{aspect-ratio:9/16}
.vid-lbl{position:absolute;left:14px;bottom:14px;background:rgba(0,170,189,.9);color:#fff;border-radius:999px;padding:6px 13px;font-size:12px;font-weight:800}
.vid-sound-toggle{position:absolute;right:13px;top:13px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.16);background:rgba(11,16,23,.72);display:flex;align-items:center;justify-content:center;cursor:pointer}
.vid-sound-toggle svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}

.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.media-frame{border-radius:8px;overflow:hidden;box-shadow:var(--shadow);background:var(--ink)}
.media-frame img{width:100%;height:520px;object-fit:cover;object-position:center 18%;display:block}
.feats{display:flex;flex-direction:column;gap:18px;margin-top:26px}
.feat{display:flex;gap:14px;align-items:flex-start}
.feat-ico,.val-ico,.c-ico{width:42px;height:42px;border-radius:8px;background:rgba(0,170,189,.11);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat-ico svg,.val-ico svg{width:21px;height:21px;stroke:var(--teal);fill:none;stroke-width:1.8}
.feat-t,.val-t{font-family:'Syne',Arial,sans-serif;font-weight:800;font-size:16px;margin-bottom:5px}
.feat-d,.val-d{font-size:14px;line-height:1.55;color:var(--gray)}
.section-dark .feat-d{color:rgba(255,255,255,.58)}
.dir-wrap{margin-top:34px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);border-radius:8px;padding:20px}
.dir-header{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.dir-title{font-family:'Syne',Arial,sans-serif;font-size:16px;font-weight:800}
.dir-tabs{display:flex;gap:6px;background:rgba(0,0,0,.28);border-radius:8px;padding:4px}
.dir-tab{border:0;background:transparent;color:rgba(255,255,255,.65);font-size:11px;font-weight:800;padding:8px 10px;border-radius:6px;cursor:pointer}
.dir-tab.active{background:var(--teal);color:#fff}
.dir-pane{display:none;flex-direction:column;gap:10px}.dir-pane.active{display:flex}
.dir-row{display:flex;justify-content:space-between;gap:14px;background:rgba(255,255,255,.05);border-radius:8px;padding:12px}
.dir-shop{font-weight:800}.dir-type{color:#70e6f1;font-size:12px;text-align:right}

.val-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}

/* Shop Card Button Styling */
.shop-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.shop-body .text-link {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 12px 16px;
  border-radius: 8px;
  background: var(--teal);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  transition: opacity .2s, transform .2s;
}
.shop-body .text-link:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

/* =============================================
   RECOMMENDATION FORM (contact.html)
   ============================================= */
.rec-form-wrap{display:flex;justify-content:center;padding:0 16px}
.rec-form-card{background:var(--ink-soft);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:36px 32px;max-width:560px;width:100%}
.rec-icon{width:56px;height:56px;background:rgba(0,170,189,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--teal)}
.rec-form-card h3{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:700;margin:0 0 8px;color:#fff}
.rec-form-card>p{color:rgba(255,255,255,.56);font-size:.95rem;margin:0 0 24px}
.rec-fields{display:flex;flex-direction:column;gap:16px}
.rec-field-group{display:flex;flex-direction:column;gap:6px}
.rec-field-group label{font-size:.88rem;font-weight:600;color:#fff;letter-spacing:.02em}
.rec-optional{font-weight:400;color:rgba(255,255,255,.45)}
.rec-required{color:#e05}
.rec-field-group input,.rec-field-group select,.rec-field-group textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px;color:#fff;font-size:.95rem;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}
.rec-field-group input:focus,.rec-field-group select:focus,.rec-field-group textarea:focus{border-color:var(--teal)}
.rec-field-group select option{background:var(--ink-soft)}
.rec-field-group textarea{resize:vertical;min-height:80px}
.rec-img-drop{border:2px dashed rgba(255,255,255,.15);border-radius:10px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .2s;color:rgba(255,255,255,.45);text-align:center}
.rec-img-drop:hover{border-color:var(--teal);color:var(--teal)}
.rec-img-drop p{margin:0;font-size:.9rem}
.rec-img-preview{position:relative;display:inline-block;margin-top:8px}
.rec-img-preview img{max-width:100%;max-height:160px;border-radius:10px;display:block}
.rec-img-remove{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.7);border:none;color:#fff;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}
.rec-submit-btn{width:100%;margin-top:20px;padding:14px 20px;background:#25D366;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;font-family:'Syne',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s,transform .1s}
.rec-submit-btn:hover{background:#1ebe5a;transform:translateY(-1px)}
.rec-submit-btn:active{transform:translateY(0)}
.rec-note{text-align:center;font-size:.82rem;color:rgba(255,255,255,.4);margin:10px 0 0}
@media(max-width:500px){.rec-form-card{padding:24px 18px}}
.val-ico{margin-bottom:14px}

.faq-container{max-width:820px}
.faq-item{border-bottom:1px solid var(--line);padding:12px 0}
.faq-quest{width:100%;border:0;background:transparent;display:flex;justify-content:space-between;gap:18px;text-align:left;cursor:pointer;padding:14px 0;font-family:'Syne',Arial,sans-serif;font-size:18px;font-weight:800;color:var(--ink)}
.faq-quest svg{width:20px;height:20px;flex:0 0 auto;transition:transform .2s}
.faq-item.active .faq-quest{color:var(--teal)}.faq-item.active .faq-quest svg{transform:rotate(180deg)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .25s}
.faq-ans p{padding:0 0 16px;color:var(--gray);font-size:14px;line-height:1.65}
.faq-item.active .faq-ans{max-height:220px}

.find-grid{display:grid;grid-template-columns:.9fr 1.5fr;gap:36px;align-items:start}
.c-cards{display:flex;flex-direction:column;gap:13px}
.c-card{display:flex;align-items:flex-start;gap:14px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:17px;text-decoration:none;box-shadow:0 10px 25px rgba(11,16,23,.05)}
.section-dark .c-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.09)}
.c-ico svg{width:22px;height:22px}
.c-val{font-weight:800;color:var(--ink)}
.section-dark .c-val{color:#fff}
.c-sub{font-size:12px;color:var(--gray);line-height:1.45;margin-top:3px}
.map-wrap{height:460px;border-radius:8px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
.soc-sec{text-align:center}.soc-sec .ss,.soc-sec .st{margin-left:auto;margin-right:auto}
.s-btn.wa{background:#25d366}.s-btn.ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#bc1888)}.s-btn.ph{background:var(--teal)}

footer{
  background:var(--ink);
  border-top:1px solid rgba(255,255,255,.07);
  padding:52px clamp(20px,4vw,48px) 28px;
}
.f-inner{
  width:min(1200px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px 24px;
  padding-bottom:36px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.f-brand .f-logo{font-family:'Syne',Arial,sans-serif;font-weight:800;color:#fff;font-size:18px;margin-bottom:14px;display:block}
.f-brand .f-logo span{color:#70e6f1}
.f-brand p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.72;margin-bottom:18px;max-width:240px}
.f-social{display:flex;gap:10px}
.f-soc-btn{
  width:38px;height:38px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:background .2s,border-color .2s,transform .2s;
}
.f-soc-btn:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-2px)}
.f-soc-btn svg{width:17px;height:17px}
.f-col h4{font-family:'Syne',Arial,sans-serif;font-size:13px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.f-col ul{list-style:none}
.f-col ul li{margin-bottom:9px}
.f-col ul li a{font-size:13px;color:rgba(255,255,255,.52);text-decoration:none;transition:color .2s}
.f-col ul li a:hover{color:var(--teal)}
.f-contact-item{display:flex;align-items:flex-start;gap:9px;margin-bottom:11px}
.f-contact-item svg{width:15px;height:15px;stroke:var(--teal);fill:none;stroke-width:2;flex-shrink:0;margin-top:1px}
.f-contact-item span{font-size:13px;color:rgba(255,255,255,.52);line-height:1.45}
.f-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  padding-top:24px;
  width:min(1200px,100%);margin:0 auto;
}
.f-copy{font-size:12px;color:rgba(255,255,255,.35)}
@media(max-width:920px){
  .f-inner{grid-template-columns:1fr 1fr;gap:32px 24px}
  .f-brand p{max-width:100%}
}
@media(max-width:620px){
  footer{padding:40px 16px 24px}
  .f-inner{grid-template-columns:1fr 1fr;gap:24px 16px}
  .f-brand{grid-column:1/-1;text-align:center}
  .f-brand p{max-width:100%}
  .f-social{justify-content:center}
  .f-bottom{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:8px 20px}
}

.modal-overlay{position:fixed;inset:0;background:rgba(11,16,23,.86);backdrop-filter:blur(12px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.25s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-box{width:min(600px,100%);background:var(--ink-soft);color:#fff;border:1px solid rgba(0,170,189,.3);border-radius:10px;padding:32px;position:relative;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.modal-close{position:absolute;right:18px;top:18px;background:transparent;border:0;color:#fff;cursor:pointer}.modal-close svg{width:24px;height:24px}
.modal-subtitle{font-size:11px;color:#70e6f1;font-weight:800;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.modal-title{font-family:'Syne',Arial,sans-serif;font-size:30px;font-weight:800;margin-bottom:12px}
.modal-desc{font-size:15px;line-height:1.65;color:rgba(255,255,255,.72);margin-bottom:22px}
.modal-items{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.modal-item-pill{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:8px;padding:11px;font-size:14px}
.modal-item-pill svg{width:16px;height:16px;stroke:var(--teal);fill:none;stroke-width:2}
.modal-cta-btn{display:flex;justify-content:center;align-items:center;gap:10px;background:var(--teal);color:#fff;text-decoration:none;border-radius:8px;padding:14px;font-weight:800}
.modal-cta-btn svg{width:18px;height:18px}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s,transform .65s}.reveal.revealed{opacity:1;transform:translateY(0)}

/* ===========================================
   MARQUEE SECTION WITH SWIPE CONTROLS
   =========================================== */
.marquee-section{
  background:var(--ink-soft);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:28px 0 0;
}
.marquee-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 clamp(20px,4vw,48px) 18px;
}
.marquee-label{
  font-family:'Syne',Arial,sans-serif;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:rgba(255,255,255,.42);
}
.marquee-controls{
  display:flex;
  align-items:center;
  gap:10px;
}
.mq-ctrl-btn{
  width:38px;height:38px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background .2s, border-color .2s, color .2s, transform .15s;
}
.mq-ctrl-btn:hover{background:var(--teal);border-color:var(--teal);color:#fff;transform:scale(1.08)}
.mq-ctrl-btn svg{width:16px;height:16px}
.mq-pause .icon-pause,.mq-pause .icon-play{width:14px;height:14px;fill:currentColor}

.marquee-viewport{
  overflow:hidden;
  position:relative;
  width:100%;
  /* fade edges */
  mask-image:linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
}
.marquee-track{
  display:flex;
  width:max-content;
  gap:18px;
  padding:0 clamp(20px,4vw,48px) 32px;
  animation:scroll-marquee 48s linear infinite;
  will-change:transform;
}
.marquee-track.paused,.marquee-track:hover{
  animation-play-state:paused;
}
.marquee-img{
  width:280px;
  height:185px;
  object-fit:cover;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(0,0,0,.32);
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s;
  flex-shrink:0;
  cursor:pointer;
}
.marquee-img:hover{
  transform:scale(1.04) translateY(-4px);
  border-color:var(--teal);
  box-shadow:0 16px 36px rgba(0,159,178,.22);
}
@keyframes scroll-marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* Photo Gallery & Filters */
.gallery-filters {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin: 10px 0 40px;
}
.filter-btn {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.75);
  padding: 10px 22px;
  border-radius: 30px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s ease;
  font-family: 'Syne', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.filter-btn:hover {
  background: rgba(0, 159, 178, 0.12);
  color: #fff;
  border-color: var(--teal);
  transform: translateY(-2px);
}
.filter-btn.active {
  background: var(--teal);
  color: #fff;
  border-color: var(--teal);
  box-shadow: 0 6px 16px rgba(0, 159, 178, 0.35);
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  grid-auto-rows: 260px;
  gap: 18px;
  overflow-x: visible;
  overflow-y: visible;
}
.gallery-item {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25);
  background: #000;
  contain: layout style paint;
  transition: box-shadow 0.4s ease, opacity 0.4s ease;
}
.gallery-item.hide { display: none; }
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.3s ease;
  display: block;
  opacity: 0.92;
}
.gallery-item img.loaded { opacity: 1; }
.gallery-item-info {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11, 16, 23, 0.92) 0%, rgba(11, 16, 23, 0.4) 50%, rgba(11, 16, 23, 0) 100%);
  display: flex; flex-direction: column; justify-content: flex-end; padding: 22px;
  opacity: 1; transition: opacity 0.3s ease;
}
@media (hover: hover) {
  .gallery-item:hover .gallery-item-info { opacity: 1; }
}
.gallery-item-category { font-size: 10px; font-weight: 800; color: var(--teal); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 5px; }
.gallery-item-title { font-family: 'Syne', sans-serif; font-size: 16px; font-weight: 700; color: #fff; line-height: 1.25; }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; background: rgba(11, 16, 23, 0.97);
  backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px);
  z-index: 300; display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden; transition: opacity 0.35s ease, visibility 0.35s ease; padding: 40px;
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox-content { position: relative; max-width: 85%; max-height: 80vh; display: flex; flex-direction: column; align-items: center; }
.lightbox-img {
  max-width: 100%; max-height: 72vh; width: auto; height: auto;
  border-radius: 6px; border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
  transform: scale(0.97); transition: transform 0.3s ease;
}
.lightbox.open .lightbox-img { transform: scale(1); }
.lightbox-caption { color: rgba(255, 255, 255, 0.85); margin-top: 15px; font-size: 15px; text-align: center; font-weight: 500; max-width: 600px; line-height: 1.5; }
.lightbox-close {
  position: absolute; top: 24px; right: 24px;
  background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff; width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; z-index: 310;
}
.lightbox-close:hover { background: rgba(234, 67, 53, 0.2); border-color: #ea4335; transform: scale(1.05); }
.lightbox-close svg { width: 22px; height: 22px; fill: currentColor; }
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff; width: 50px; height: 50px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.25s; z-index: 310;
}
.lightbox-nav:hover { background: var(--teal); border-color: var(--teal); transform: translateY(-50%) scale(1.05); }
.lightbox-nav.prev { left: 24px; }
.lightbox-nav.next { right: 24px; }
.lightbox-nav svg { width: 24px; height: 24px; stroke: currentColor; fill: none; stroke-width: 2.5; }

/* Floor Grid */
.floor-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 36px; }
.floor-card {
  background: var(--ink-soft); border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 8px; overflow: hidden; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s, box-shadow 0.4s;
}
.floor-card:hover { transform: translateY(-6px); border-color: var(--teal); box-shadow: 0 20px 40px rgba(0, 170, 189, 0.12); }
.floor-img-wrap { width: 100%; height: 220px; overflow: hidden; position: relative; }
.floor-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1); }
.floor-card:hover .floor-img-wrap img { transform: scale(1.05); }
.floor-info { padding: 24px; }
.floor-badge { display: inline-block; font-size: 10px; font-weight: 800; color: var(--teal); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 10px; }
.floor-info h3 { font-family: 'Syne', Arial, sans-serif; font-size: 20px; font-weight: 800; color: #fff; margin-bottom: 8px; }
.floor-info p { font-size: 14px; line-height: 1.6; color: var(--gray); }

/* =====================
   RESPONSIVE
   ===================== */
@media(max-width:1100px){
  .hero-card-stack{width:clamp(200px,22vw,260px);height:clamp(250px,30vw,320px)}
  .hero-content{max-width:65%;margin-left:clamp(20px,3vw,80px)}
}
@media(max-width:920px){
  .nav-links{display:none}.nav-toggle{display:flex}
  .hero{min-height:auto;flex-direction:column;align-items:center;padding-bottom:40px}
  .hero-content{max-width:100%;padding-right:clamp(20px,4vw,48px);margin-left:0;padding-top:110px;padding-bottom:20px;text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
  .countdown-wrap{margin-left:auto;margin-right:auto}
  .hero-overlay{background:linear-gradient(180deg,rgba(11,16,23,.72),rgba(11,16,23,.88))}
  .hero-card-stack{
    position:relative;top:auto;right:auto;transform:none;
    width:clamp(160px,40vw,220px);height:clamp(200px,50vw,280px);
    margin:0 auto;pointer-events:auto;
  }
  .hcs-card--front{pointer-events:auto}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .vid-grid,.split,.find-grid{grid-template-columns:1fr}
  .quick-strip,.dept-grid{grid-template-columns:1fr}
  .vid-wrap.landscape,.vid-wrap.portrait{aspect-ratio:16/10}
  .val-grid{grid-template-columns:1fr 1fr}
  .media-frame img{height:380px}
  .floor-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-auto-rows:240px}
}
@media(max-width:620px){
  nav{padding:12px 16px}.nav-logo-img{width:58px}.nav-wordmark{font-size:12px}
  .hero-content{padding:100px 18px 40px}.hero-title{font-size:34px;line-height:1.05}.hero-sub{font-size:14px;line-height:1.58;margin-bottom:22px}
  .countdown-wrap{padding:14px;margin-bottom:22px}.countdown-grid{gap:7px}.countdown-card{min-width:0;flex:1;padding:9px 5px}.countdown-num{font-size:20px}.countdown-dots{display:none}
  .hero-btns .btn-p,.hero-btns .btn-o,.soc-btns .s-btn,.text-link{width:100%}
  .hero-stats{display:none}
  .ob{align-items:stretch;justify-content:flex-start}.ob-item,.time-widget,.ob-pill{width:100%}.ob-div{display:none}
  .sec,.section-inner,.soc-sec{padding-top:56px;padding-bottom:56px}.page-hero{padding-top:118px;padding-bottom:48px}.quick-strip{padding-top:22px;padding-bottom:22px}
  .ss{margin-bottom:28px}.cat-ov{padding:18px}.cat-name{font-size:22px}
  .shop-card .cat-card{aspect-ratio:16/11}
  .media-frame img{height:310px;object-position:center top}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));grid-auto-rows:170px;gap:8px}
  .gallery-item-title{font-size:13px}.gallery-item-category{font-size:8px}
  .gallery-item-info{padding:14px}
  .gallery-filters{flex-wrap:wrap;gap:8px}
  .val-grid,.modal-items{grid-template-columns:1fr}
  .dir-header{align-items:stretch}.dir-tabs{width:100%}.dir-tab{flex:1;padding-left:5px;padding-right:5px}
  .dir-row{flex-direction:column}.dir-type{text-align:left}
  .map-wrap{height:330px}
  .modal-box{padding:28px 20px}
  .lang-float{left:16px;bottom:16px;width:48px;height:48px}.lang-tooltip{display:none}
  .back-to-top{right:16px;bottom:16px;width:46px;height:46px}
  .floor-grid{grid-template-columns:1fr;gap:20px}
  .marquee-img{width:220px;height:148px}
  .lightbox{padding:20px}
  .lightbox-nav{width:42px;height:42px}
  .lightbox-nav.prev{left:10px}
  .lightbox-nav.next{right:10px}
  .lightbox-close{top:16px;right:16px;width:38px;height:38px}
}
/* --- Celebration elements --- */
.confetti-container,
.balloons-container{
  position:fixed;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:999;
  display:none;
}
.confetti-container.active,
.balloons-container.active{
  display:block;
}
.confetti{
  position:absolute;
  width:12px;
  height:12px;
  top:-20px;
  border-radius:3px;
  animation:confettiFall linear forwards;
}
@keyframes confettiFall{
  to{
    transform:translateY(110vh) rotate(1080deg);
  }
}
.balloon{
  position:absolute;
  bottom:-150px;
  width:60px;
  height:75px;
  border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
  animation:balloonRise linear forwards;
}
.balloon:before{
  content:'';
  position:absolute;
  bottom:-25px;
  left:50%;
  width:2px;
  height:30px;
  background:#ddd;
  transform:translateX(-50%);
}
@keyframes balloonRise{
  to{
    transform:translateY(-120vh) rotate(15deg);
  }
}

/* =============================================
   404 PAGE
   ============================================= */
.not-found-section{min-height:100vh;background:var(--ink);display:flex;align-items:center;justify-content:center;padding:40px 24px;text-align:center}
.not-found-inner{max-width:560px}
.nf-code{font-family:'Syne',Arial,sans-serif;font-size:clamp(80px,18vw,140px);font-weight:800;color:rgba(255,255,255,.06);line-height:1;margin-bottom:-20px;letter-spacing:-4px}
.nf-title{font-family:'Syne',Arial,sans-serif;font-size:clamp(26px,5vw,40px);font-weight:800;color:#fff;margin-bottom:16px}
.nf-sub{font-size:16px;color:rgba(255,255,255,.58);line-height:1.7;margin-bottom:36px}
.nf-btns{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.nf-links{margin-top:48px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.nf-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;padding:8px 14px;border:1px solid rgba(255,255,255,.1);border-radius:8px;transition:color .2s,border-color .2s}
.nf-links a:hover{color:var(--teal);border-color:var(--teal)}

/* =============================================
   RECOMMENDATION FORM
   ============================================= */
.rec-form-wrap{display:flex;justify-content:center;padding:0 16px}
.rec-form-card{background:var(--ink-soft);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:36px 32px;max-width:560px;width:100%}
.rec-icon{width:56px;height:56px;background:rgba(0,170,189,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:#00aabd}
.rec-form-card h3{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:700;margin:0 0 8px;color:#fff}
.rec-form-card>p{color:rgba(255,255,255,.55);font-size:.95rem;margin:0 0 24px}
.rec-fields{display:flex;flex-direction:column;gap:16px}
.rec-field-group{display:flex;flex-direction:column;gap:6px}
.rec-field-group label{font-size:.88rem;font-weight:600;color:#fff;letter-spacing:.02em}
.rec-optional{font-weight:400;color:rgba(255,255,255,.45)}
.rec-required{color:#e05}
.rec-field-group input,.rec-field-group select,.rec-field-group textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px;color:#fff;font-size:.95rem;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}
.rec-field-group input:focus,.rec-field-group select:focus,.rec-field-group textarea:focus{border-color:#00aabd}
.rec-field-group select option{background:#131b24}
.rec-field-group textarea{resize:vertical;min-height:80px}
.rec-img-drop{border:2px dashed rgba(255,255,255,.15);border-radius:10px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .2s;color:rgba(255,255,255,.45);text-align:center}
.rec-img-drop:hover{border-color:#00aabd;color:#00aabd}
.rec-img-drop p{margin:0;font-size:.9rem}
.rec-img-preview{position:relative;display:inline-block;margin-top:8px}
.rec-img-preview img{max-width:100%;max-height:160px;border-radius:10px;display:block}
.rec-img-remove{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.7);border:none;color:#fff;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}
.rec-submit-btn{width:100%;margin-top:20px;padding:14px 20px;background:#25D366;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;font-family:'Syne',sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .2s,transform .1s}
.rec-submit-btn:hover{background:#1ebe5a;transform:translateY(-1px)}
.rec-submit-btn:active{transform:translateY(0)}
.rec-note{text-align:center;font-size:.82rem;color:rgba(255,255,255,.45);margin:10px 0 0}
@media(max-width:500px){.rec-form-card{padding:24px 18px}}
.img-lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(11,16,23,.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
  padding:20px;
}
.img-lightbox.open{opacity:1;visibility:visible}
.img-lightbox-close{
  position:absolute;top:16px;right:16px;z-index:310;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.6);width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .2s,color .2s;
}
.img-lightbox-close:hover{background:rgba(234,67,53,.25);color:#fff}
.img-lightbox-close svg{width:18px;height:18px}
.img-lightbox-stage{
  display:flex;flex-direction:column;align-items:center;gap:0;
  max-height:90vh;
}
.img-lightbox-img{
  max-width:55vw;max-height:68vh;object-fit:contain;border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  transform:scale(.96);transition:transform .35s cubic-bezier(.25,.8,.25,1),opacity .3s ease;
  cursor:default;user-select:none;-webkit-user-select:none;
}
.img-lightbox.open .img-lightbox-img{transform:scale(1)}
.img-lightbox-img.slide-out-left{animation:lbSlideOutLeft .22s ease forwards}
.img-lightbox-img.slide-out-right{animation:lbSlideOutRight .22s ease forwards}
.img-lightbox-img.slide-in-left{animation:lbSlideInLeft .3s ease forwards}
.img-lightbox-img.slide-in-right{animation:lbSlideInRight .3s ease forwards}
@keyframes lbSlideOutLeft{to{transform:translateX(-50px) scale(.95);opacity:0}}
@keyframes lbSlideOutRight{to{transform:translateX(50px) scale(.95);opacity:0}}
@keyframes lbSlideInLeft{from{transform:translateX(-50px) scale(.95);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}
@keyframes lbSlideInRight{from{transform:translateX(50px) scale(.95);opacity:0}to{transform:translateX(0) scale(1);opacity:1}}
.img-lightbox-img.zoomed{
  max-width:none;max-height:none;
  transform:scale(2);cursor:grab;transition:none;
}
.img-lightbox-img.zoomed:active{cursor:grabbing}
.img-lightbox-caption{
  color:rgba(255,255,255,.85);font-size:15px;font-weight:600;
  text-align:center;max-width:500px;line-height:1.4;
  padding:16px 20px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.img-lightbox-controls{
  display:flex;align-items:center;gap:24px;
  padding:18px 0 8px;
}
.img-lightbox-nav{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.5);width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .2s,border-color .2s,color .2s,transform .15s;
}
.img-lightbox-nav:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);color:#fff;transform:scale(1.1)}
.img-lightbox-nav svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.img-lightbox-counter{
  color:rgba(255,255,255,.3);font-size:12px;font-weight:700;
  letter-spacing:.1em;min-width:60px;text-align:center;
}
@media(max-width:920px){
  .img-lightbox-img{max-width:70vw}
}
@media(max-width:620px){
  .img-lightbox{padding:12px}
  .img-lightbox-close{top:10px;right:10px;width:36px;height:36px}
  .img-lightbox-close svg{width:16px;height:16px}
  .img-lightbox-img{max-width:85vw;max-height:60vh}
  .img-lightbox-caption{font-size:13px;padding:12px 16px 0;max-width:280px}
  .img-lightbox-controls{gap:18px;padding:14px 0 4px}
  .img-lightbox-nav{width:40px;height:40px}
  .img-lightbox-nav svg{width:18px;height:18px}
  .img-lightbox-counter{font-size:11px}
}
