/* ===== Shared flythrough structure + sections. Theme via :root vars per page. ===== */
:root{
  --bg:#05070d; --ink:#eaf1f8; --muted:#8ea4ba; --line:rgba(150,180,210,.14);
  --accent:#e8b86a; --accent-ink:#1a1205; --panel:#0a1320;
  --coast-fill:rgba(20,40,60,.28); --coast-stroke:#7fd0ff;
  --disp:"Bricolage Grotesque",sans-serif; --body:"Archivo",sans-serif; --mono:"Space Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:11px}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}

/* chrome */
.ann{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(5,7,13,.65);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);text-align:center;padding:8px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.nav{position:fixed;top:34px;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 32px;background:var(--nav-bg,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.logo{font-family:var(--disp);font-weight:800;font-size:20px;letter-spacing:-.02em;color:var(--ink)}
.logo b{color:var(--accent)}
.nav nav{display:flex;gap:24px;font-size:14px;color:var(--ink);white-space:nowrap;opacity:.88}
.navr{display:flex;align-items:center;gap:16px;color:var(--ink)}
.lang{font-family:var(--mono);font-size:11px;letter-spacing:.12em;opacity:.8}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:var(--accent-ink);font-weight:600;font-size:14px;padding:11px 20px;border-radius:999px;border:none;cursor:pointer;transition:transform .25s,box-shadow .25s}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 30px rgba(0,0,0,.35)}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.45);color:#fff}

/* tour stage */
.tour{position:relative;height:460vh}
.stage{position:sticky;top:0;height:100vh;overflow:hidden;background:var(--stage-bg,radial-gradient(120% 90% at 50% 30%,#0a1626,#05070d 70%))}
.tscene{position:absolute;inset:0;z-index:3;opacity:0;will-change:opacity}
.tscene .scene{position:absolute;inset:0}
.scrim{position:absolute;inset:0;z-index:4;pointer-events:none;background:var(--scrim,radial-gradient(130% 100% at 50% 40%,transparent 45%,rgba(2,4,8,.7) 100%))}
.cam{position:absolute;inset:0;margin:auto;width:min(120vw,170vh);aspect-ratio:1000/685;z-index:2;transform-origin:50% 50%;will-change:transform}
.cam svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.coast{fill:var(--coast-fill);stroke:var(--coast-stroke);stroke-width:2;stroke-linejoin:round;filter:drop-shadow(0 0 16px var(--coast-glow,rgba(120,200,255,.22)))}
.grid-ln{stroke:var(--grid,rgba(120,170,210,.08));stroke-width:1}

.fly-pin{position:absolute;transform:translate(-50%,-50%);z-index:6}
.fly-pin .ring{display:block;width:13px;height:13px;border-radius:50%;background:var(--pc,#e8b86a);box-shadow:0 0 0 4px rgba(255,255,255,.08),0 0 22px var(--pc,#e8b86a)}
.fly-pin .pulse{position:absolute;inset:0;margin:auto;width:13px;height:13px;border-radius:50%;border:1.5px solid var(--pc,#e8b86a);animation:flyping 2.6s ease-out infinite}
@keyframes flyping{0%{transform:scale(1);opacity:.9}100%{transform:scale(3.4);opacity:0}}
.fly-reyk{position:absolute;transform:translate(-50%,-50%);z-index:5;display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--muted);white-space:nowrap}
.fly-reyk .d{width:6px;height:6px;border:1.4px solid var(--muted);border-radius:50%}

/* copy */
.tcopy{position:absolute;z-index:10;left:0;right:0;bottom:0;padding:0 0 9vh;pointer-events:none}
.tcopy .inner{max-width:1280px;margin:0 auto;padding:0 48px}
.tc-eye{color:var(--accent);margin-bottom:16px}
.tc-title{font-family:var(--disp);font-weight:800;font-size:clamp(42px,7vw,100px);line-height:.9;letter-spacing:-.03em;text-wrap:balance;max-width:16ch;color:#fff}
.tc-sub{color:#d3deea;font-size:clamp(15px,1.6vw,19px);line-height:1.5;max-width:42ch;margin-top:22px}
.tc-facts{display:flex;gap:30px;margin-top:24px;flex-wrap:wrap}
.tc-facts .f{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tc-facts .f b{display:block;font-family:var(--disp);font-weight:700;font-size:24px;color:#fff;margin-top:6px;letter-spacing:0}
.tc-cta{display:flex;gap:14px;margin-top:26px;pointer-events:auto;flex-wrap:wrap;align-items:center}
.tc-price{font-family:var(--disp);color:#cdd9e6}.tc-price b{color:#fff;font-size:22px}

/* dots */
.dots{position:fixed;right:30px;top:50%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;gap:14px;transition:opacity .35s}
.fly-dot{display:flex;align-items:center;gap:10px;justify-content:flex-end;cursor:pointer}
.fly-dot .t{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:0;transition:.25s;white-space:nowrap}
.fly-dot .c{width:9px;height:9px;border-radius:50%;border:1.5px solid rgba(180,200,220,.5);transition:.25s}
.fly-dot.on .c{background:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent)}
.fly-dot.on .t,.fly-dot:hover .t{opacity:1;color:#fff}
.scrollhint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:11;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
.scrollhint .l{width:30px;height:1px;background:var(--muted);position:relative;overflow:hidden}
.scrollhint .l::after{content:"";position:absolute;inset:0;background:var(--accent);animation:flyslide 2s ease-in-out infinite}
@keyframes flyslide{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* sections */
.section{padding:94px 0;position:relative}
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:42px}
.shead .mono{color:var(--accent)}
.shead h2{font-family:var(--disp);font-weight:800;font-size:clamp(28px,3.4vw,46px);letter-spacing:-.02em;line-height:1;margin-top:12px}
.shead p{color:var(--muted);max-width:42ch;font-size:15px}
.cond{background:var(--cond-bg,transparent);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.condgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.condcell{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px}
.condcell .ct{font-family:var(--disp);font-weight:700;font-size:16px;display:flex;align-items:center;gap:9px}
.condcell .ct .d{width:8px;height:8px;border-radius:50%;background:var(--ac,var(--accent));box-shadow:0 0 10px var(--ac,var(--accent))}
.condcell .cr{color:var(--muted);font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;margin:4px 0 14px}
.condrow{display:flex;justify-content:space-between;padding:6px 0;border-top:1px solid var(--line);font-size:12.5px}
.condrow .k{color:var(--muted)}.condrow .v{font-family:var(--mono);font-size:11.5px}

.hotels{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.hcard{position:relative;border-radius:18px;overflow:hidden;min-height:400px;border:1px solid var(--line);cursor:pointer}
.hcard .scene{position:absolute;inset:0;transition:transform 1s ease}
.hcard:hover .scene{transform:scale(1.06)}
.hcard__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform 1s ease}
.hcard:hover .hcard__img{transform:scale(1.06)}
.hcard .ov{position:absolute;inset:0;z-index:10;background:linear-gradient(0deg,var(--card-veil,rgba(5,7,13,.93)),rgba(5,7,13,.1) 55%,transparent);padding:26px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.hcard .top{position:absolute;top:0;left:0;right:0;padding:22px 26px;display:flex;justify-content:space-between;z-index:11;color:#fff}
.hcard .reg{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#dfeaf3}
.hcard .yr{font-family:var(--mono);font-size:10px;letter-spacing:.1em;border:1px solid rgba(255,255,255,.3);padding:5px 10px;border-radius:999px;color:#dfeaf3}
.hcard h3{font-family:var(--disp);font-weight:800;font-size:26px;line-height:1.04;letter-spacing:-.02em;margin-bottom:9px}
.hcard .vibe{color:#dfeaf3;font-size:13.5px;margin:0 0 16px;max-width:34ch;line-height:1.45}
.hcard .foot{display:flex;align-items:center;justify-content:space-between}
.hcard .from{font-family:var(--disp);font-size:13px;color:#cdd9e6;white-space:nowrap}.hcard .from b{color:#fff;font-size:19px}
.hcard .go{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ac,var(--accent))}

.statsrow{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:20px}
.stat{border:1px solid var(--line);border-radius:16px;padding:28px;background:var(--panel)}
.stat .big{font-family:var(--disp);font-weight:800;font-size:44px;letter-spacing:-.02em;line-height:1}
.stat .lbl{color:var(--muted);font-size:13px;margin-top:8px}
.stat .stars{color:var(--accent);font-size:20px;letter-spacing:3px}
.revq{border:1px solid var(--line);border-radius:16px;padding:28px;display:flex;flex-direction:column;justify-content:space-between;background:var(--panel)}
.revq p{font-family:var(--disp);font-weight:500;font-size:18px;line-height:1.4;text-wrap:pretty}
.revq .meta{color:var(--accent);font-family:var(--mono);font-size:11px;letter-spacing:.08em;margin-top:16px}

.book{border:1px solid var(--line);border-radius:24px;padding:34px;background:var(--panel);position:relative;overflow:hidden}
.btabs{display:flex;gap:10px;margin-bottom:24px}
.btab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:9px 16px;border-radius:999px;border:1px solid var(--line);cursor:pointer;color:var(--muted)}
.btab.act{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.bform{display:grid;grid-template-columns:1.4fr 1fr 1fr auto auto;gap:14px;align-items:end}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field .ctl{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;padding:13px 14px;color:var(--ink);font-size:14px;width:100%;font-family:var(--body)}
.step{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;padding:7px}
.step button{width:30px;height:30px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:16px;cursor:pointer}
.step span{min-width:26px;text-align:center;font-family:var(--disp);font-weight:700}
.reassure{margin-top:18px;color:var(--muted);font-size:13px}.reassure b{color:var(--accent)}

footer{border-top:1px solid var(--line);padding:48px 0 66px;color:var(--muted)}
.foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.foot .coords{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--accent);white-space:nowrap}
.foot .logo{color:var(--ink)}
.foot>div:last-child{max-width:46%;text-align:right}

@media (max-width:820px){
  .hotels{grid-template-columns:1fr}.condgrid{grid-template-columns:1fr 1fr}.bform{grid-template-columns:1fr 1fr}
  .statsrow{grid-template-columns:1fr}.dots{display:none}.tcopy .inner{padding:0 28px}.nav nav{display:none}
}