﻿*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --sand:#F7F0E3;--sand2:#EDE2CA;--sand3:#D4BF99;
  --ocean:#0E3A52;--ocean2:#1A5C7A;--ocean3:#2B8BAD;
  --gold:#f4ba18;--gold2:#f4ba18;--gold3:#f4ba18;
  --white:#FFFFFF;--offwhite:#FDFAF4;--charcoal:#1C1C1C;--mid:#5A5A5A;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{min-height:100vh;min-height:100svh;min-height:100dvh;background:var(--offwhite);font-family:'DM Sans',sans-serif;color:var(--charcoal);cursor:auto;overflow-x:hidden}
body.modal-open{overflow:hidden}
html.admin-mode-root #pre,html.admin-mode-root #cur,html.admin-mode-root #cur2{display:none !important}
[data-asset-kind="background"]{background-position:center;background-repeat:no-repeat;background-size:cover}
[data-asset-kind="image"] img{display:block;max-width:100%;max-height:100%;object-fit:contain}
[data-asset-kind="background"].has-custom-asset{
  background-position:center center !important;
  background-repeat:no-repeat !important;
  background-size:cover !important;
  background-color:rgba(14,58,82,.14);
}
.about-art.has-custom-asset,.em.has-custom-asset,.t-bg.has-custom-asset{background-color:var(--ocean)}
.logo-slot{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:50%}
.logo-slot img{display:block}

/* CURSOR */
#cur,#cur2{position:fixed;border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);display:none}
#cur{width:10px;height:10px;background:var(--gold2);top:0;left:0;transition:width .25s,height .25s}
#cur2{width:36px;height:36px;border:1.5px solid var(--gold2);top:0;left:0;opacity:.6}

/* PRELOADER */
#pre{position:fixed;inset:0;z-index:100000;background:var(--ocean);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .9s,transform .9s}
#pre.hide{opacity:0;transform:translateY(-100%);pointer-events:none}
.pre-logo{font-family:'Playfair Display',serif;font-size:52px;font-weight:400;color:var(--white);text-align:center;line-height:1.1;opacity:0;animation:riseIn .8s .2s forwards}
.pre-logo span{display:block;font-size:13px;font-weight:300;letter-spacing:.5em;text-transform:uppercase;color:var(--gold2);margin-top:8px;font-family:'DM Sans',sans-serif}
.pre-prog{width:240px;height:2px;background:rgba(255,255,255,.1);margin-top:48px;overflow:hidden}
.pre-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));width:0;animation:fillBar 1.6s .4s cubic-bezier(.4,0,.2,1) forwards}
.pre-txt{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:14px}
@keyframes fillBar{to{width:100%}}
@keyframes riseIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* RIBBON */
.ribbon{background:var(--ocean);padding:15px 0;overflow:hidden}
#top-ribbon,#hero-ribbon-old{display:none}
#tour-ribbon{position:relative;z-index:5;margin-top:-22px}
.ribbon-track{display:flex;white-space:nowrap;animation:ribbonMove 35s linear infinite}
.ribbon-item{display:inline-flex;align-items:center;gap:12px;padding:0 38px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.62);font-weight:500}
.ribbon-item b{color:var(--gold2);font-weight:500}
.ribbon-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.75;flex-shrink:0}
@keyframes ribbonMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* PILL NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:10000;padding:34px 56px;display:flex;align-items:center;justify-content:center;pointer-events:none}
.nav-pill{position:relative;display:flex;align-items:center;background:rgba(255,255,255,.12);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border:2px solid rgba(7,44,82,.52);border-radius:100px;padding:7px 14px 7px 30px;box-shadow:0 8px 40px rgba(0,0,0,.18),0 1px 0 rgba(255,255,255,.15) inset,0 0 0 1px rgba(16,79,140,.24);transition:background .4s,border-color .4s,box-shadow .4s;pointer-events:all;max-width:1180px;width:100%}
#nav.scrolled .nav-pill{background:rgba(253,250,244,.94);border-color:rgba(244,186,24,.2);box-shadow:0 12px 50px rgba(0,0,0,.1),0 1px 0 rgba(255,255,255,.8) inset}
.nav-top-row{display:flex;align-items:center;gap:18px;min-width:0}
.nav-logo-pill{display:flex;align-items:center;gap:14px;text-decoration:none;flex-shrink:0}
.nav-logo-pill img{width:92px;height:92px;object-fit:contain;border-radius:50%}
.nav-logo-pill-text{font-family:'Playfair Display',serif;font-size:29px;font-weight:700;color:var(--white);line-height:.92;transition:color .3s}
.nav-logo-pill-text span{display:block;font-size:12px;font-weight:300;letter-spacing:.32em;text-transform:uppercase;font-family:'DM Sans',sans-serif;opacity:.7}
#nav.scrolled .nav-logo-pill-text{color:var(--ocean)}
.nav-burger{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;width:64px;height:52px;appearance:none;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);border-radius:18px;padding:0 16px;cursor:pointer;flex-shrink:0;color:var(--white);transition:transform .25s,background .25s,border-color .25s,box-shadow .25s}
.nav-burger span{display:block;width:24px;height:2.5px;border-radius:999px;transition:transform .25s,opacity .25s,width .25s,background .25s}
.nav-burger span:nth-child(1){background:var(--ocean3)}
.nav-burger span:nth-child(2){width:18px}
.nav-burger span:nth-child(2){background:var(--gold)}
.nav-burger span:nth-child(3){background:#111111}
.nav-burger:hover{transform:translateY(-1px);background:rgba(255,255,255,.16);box-shadow:0 10px 24px rgba(0,0,0,.18)}
#nav.scrolled .nav-burger{background:rgba(14,58,82,.06);border-color:rgba(14,58,82,.12);color:var(--ocean);box-shadow:none}
#nav.nav-open .nav-burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
#nav.nav-open .nav-burger span:nth-child(2){opacity:0}
#nav.nav-open .nav-burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.nav-links-pill{display:flex;align-items:center;gap:8px;margin-left:auto}
.nav-links-pill a{font-size:14px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.8);text-decoration:none;padding:12px 20px;border-radius:100px;transition:all .25s;white-space:nowrap}
#nav.scrolled .nav-links-pill a{color:var(--mid)}
.nav-links-pill a:hover{background:rgba(255,255,255,.15);color:var(--white)}
#nav.scrolled .nav-links-pill a:hover{background:rgba(14,58,82,.06);color:var(--ocean)}
.nav-cta-pill{background:var(--gold) !important;color:var(--white) !important;border-radius:100px;font-weight:600 !important;box-shadow:0 4px 20px rgba(244,186,24,.35);padding:16px 32px !important}
.nav-cta-pill:hover{background:var(--ocean) !important;box-shadow:0 6px 28px rgba(14,58,82,.4) !important;transform:translateY(-1px) !important}

/* HERO */
#hero{position:relative;height:100vh;height:100svh;height:100dvh;min-height:clamp(500px,100svh,700px);overflow:hidden;display:flex;align-items:center}
#hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;z-index:0;transform:none;backface-visibility:hidden;will-change:auto;filter:saturate(1.06) contrast(1.04) brightness(1.03)}
#hero::before{display:none}
#hero::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:92px;background:var(--offwhite);clip-path:ellipse(56% 100% at 50% 100%);pointer-events:none;z-index:4}
#hero>.hero-overlay,#hero>.hero-grain,#hero>.hero-sweep,#hero>.hero-content,#hero>.hero-scroll{display:none !important}
.hero-curve-marquee{position:absolute;left:-1%;right:-1%;bottom:2px;height:108px;z-index:3;overflow:hidden;pointer-events:none;clip-path:ellipse(56.3% 100% at 50% 100%);background:linear-gradient(180deg,#123f58 0%,#0e3a52 48%,#0a2c3f 100%);box-shadow:0 -1px 0 rgba(255,255,255,.08) inset}
.btn-gold{display:inline-flex;align-items:center;gap:10px;background:var(--gold);color:var(--white);padding:16px 32px;border-radius:100px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;text-decoration:none;box-shadow:0 8px 30px rgba(244,186,24,.4);transition:all .35s;position:relative;overflow:hidden}
.btn-gold::before{content:'';position:absolute;inset:0;background:var(--ocean);border-radius:100px;transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.77,0,.175,1)}
.btn-gold:hover::before{transform:scaleX(1)}
.btn-gold span,.btn-gold svg{position:relative;z-index:1}
.btn-gold:hover{box-shadow:0 12px 40px rgba(14,58,82,.4);transform:translateY(-2px)}

/* SECTIONS */
.s-label{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;font-weight:600;color:var(--gold);margin-bottom:16px}
.s-label::before{content:'';width:28px;height:2px;background:var(--gold);flex-shrink:0}
.s-title{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,62px);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--ocean)}
.s-title em{font-style:italic;font-weight:400;color:var(--gold)}
.s-body{font-size:15px;line-height:1.85;color:var(--mid);font-weight:300}

/* ABOUT */
#about{padding:64px 80px 24px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;background:var(--offwhite);position:relative}
#about::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--sand3),transparent)}
.about-visual{position:relative;height:540px}
.ab-img{position:absolute;border-radius:20px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.12)}
.ab1{width:60%;height:70%;top:0;left:0;z-index:2}
.ab2{width:48%;height:56%;bottom:0;right:0;z-index:3;border:5px solid var(--offwhite)}
.ab3{width:30%;height:30%;top:1%;right:4%;z-index:1;border:5px solid var(--offwhite)}
.ab4{width:32%;height:31%;bottom:0;left:18%;z-index:1;border:5px solid var(--offwhite)}
.ab-badge{position:absolute;top:46%;left:56%;transform:translate(-50%,-50%);z-index:4;width:104px;height:104px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 12px 40px rgba(244,186,24,.45);font-family:'Playfair Display',serif;text-align:center;animation:pulseGlow 3s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{box-shadow:0 12px 40px rgba(244,186,24,.45),0 0 0 0 rgba(244,186,24,.25)}50%{box-shadow:0 12px 40px rgba(244,186,24,.45),0 0 0 18px rgba(244,186,24,0)}}
.ab-badge-n{font-size:32px;font-weight:700;color:var(--white);line-height:1}
.ab-badge-s{font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.8);font-family:'DM Sans',sans-serif}
.about-art-primary{background:radial-gradient(circle at 50% 28%,rgba(255,252,238,.12),transparent 18%),linear-gradient(155deg,#0e3a52,#1a6a8f,#4ab8d4,#7ed4e8);isolation:isolate}
.about-art-primary.has-custom-asset{background-position:24% center !important}
.about-art-primary::before{content:'';position:absolute;inset:0;z-index:0;background:repeating-radial-gradient(ellipse at 50% 80%,transparent 0,transparent 25px,rgba(255,255,255,.05) 25px,rgba(255,255,255,.05) 26px)}
.about-art-primary::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;z-index:1;background:linear-gradient(to top,rgba(5,20,35,.7),transparent);pointer-events:none}
.about-primary-caption{position:absolute;bottom:20px;left:20px;z-index:5;font-family:'Playfair Display',serif;font-size:20px;font-style:italic;color:rgba(255,255,255,.85)}
.about-pillars{--about-pillars-bg:none;position:relative;display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;padding:18px;border-radius:24px;overflow:hidden;isolation:isolate}
.about-pillars::before{content:'';position:absolute;inset:0;background-image:var(--about-pillars-bg);background-position:center;background-repeat:no-repeat;background-size:cover;opacity:.38;filter:saturate(1.04) contrast(1.02);z-index:0}
.about-pillars::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(253,250,244,.18),rgba(253,250,244,.08));z-index:0;pointer-events:none}
.about-pillars>*{position:relative;z-index:1}
.pillar{padding:24px;background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.1));backdrop-filter:blur(8px) saturate(130%);-webkit-backdrop-filter:blur(8px) saturate(130%);border:1px solid rgba(255,255,255,.34);border-radius:16px;border-top:3px solid rgba(255,255,255,.22);transition:all .35s;position:relative;overflow:hidden;box-shadow:0 10px 26px rgba(14,58,82,.08),inset 0 1px 0 rgba(255,255,255,.34)}
.pillar:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(14,58,82,.12),inset 0 1px 0 rgba(255,255,255,.42);border-top-color:var(--gold);background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,.14))}
.pillar-icon{font-size:26px;margin-bottom:10px}
.pillar-t{font-size:13px;font-weight:600;color:var(--ocean);margin-bottom:6px}
.pillar-b{font-size:12px;color:var(--mid);line-height:1.65;font-weight:300}

/* TOURS */
#tours{background:#16516f;position:relative;overflow:visible;isolation:isolate}
.tours-pin{position:sticky;top:0;height:100vh;height:100dvh;height:100svh;margin-bottom:-100vh;margin-bottom:-100dvh;margin-bottom:-100svh;z-index:0;pointer-events:none;overflow:hidden;background:
  linear-gradient(180deg,rgba(37,117,150,.28) 0%,rgba(46,137,174,.22) 34%,rgba(59,165,202,.16) 60%,rgba(20,78,104,.34) 100%),
  radial-gradient(circle at 18% 28%,rgba(244,186,24,.22),transparent 28%),
  radial-gradient(circle at 82% 18%,rgba(190,238,248,.24),transparent 24%),
  linear-gradient(90deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,0) 42%,rgba(8,28,42,.08) 100%),
  linear-gradient(180deg,#2b84a6 0%,#1e6686 44%,#16516f 100%)}
.tours-stage-word{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);font-family:'Bebas Neue',cursive;font-size:22vw;color:rgba(255,255,255,.11);white-space:nowrap;pointer-events:none;letter-spacing:.05em;z-index:2}
.tours-content{position:relative;z-index:3;min-height:92vh;display:flex;flex-direction:column;padding:4.5vh 0 2.5vh}
.tours-head{padding:0 80px;display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px}
.tours-head .s-label{color:var(--gold2)}
.tours-head .s-label::before{background:var(--gold2)}
.tours-head .s-title{color:var(--white)}
.view-all-link{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold2);text-decoration:none;font-weight:500;border-bottom:1px solid rgba(244,186,24,.3);padding-bottom:3px;transition:all .3s}
.view-all-link:hover{color:var(--white);border-bottom-color:var(--white)}
.tours-outer{overflow-x:auto;overflow-y:hidden;scrollbar-width:none;padding:0 80px 4px;position:relative;z-index:2;-webkit-overflow-scrolling:touch}
.tours-outer::-webkit-scrollbar{display:none}
.tours-strip{display:flex;gap:3px;user-select:none;cursor:grab;min-width:max-content}
.tours-strip:active{cursor:grabbing}
.t-card{flex:0 0 382px;height:360px;position:relative;overflow:hidden;border-radius:24px;transition:flex .55s cubic-bezier(.25,.46,.45,.94),border-radius .3s,transform .3s;scroll-snap-align:start}
.t-card:hover{flex:0 0 418px;border-radius:28px;transform:translateY(-3px)}
.t-bg{position:absolute;inset:0;transition:transform .7s ease;background-size:cover;background-position:center}
.t-card:hover .t-bg{transform:scale(1.08)}
.t-card:hover .t-bg.has-custom-asset{transform:none}
.tc1 .t-bg{background:linear-gradient(160deg,#1d5a79 0%,#2f89ad 44%,#4fc8df 76%,#b1edf7 100%)}
.tc2 .t-bg{background:linear-gradient(160deg,#184865 0%,#276b8f 42%,#3fa5cb 74%,#8fddef 100%)}
.tc3 .t-bg{background:linear-gradient(160deg,#5a3111 0%,#9c6128 44%,#d39a4b 76%,#f2d39a 100%)}
.tc4 .t-bg{background:linear-gradient(160deg,#163954 0%,#295f82 44%,#4d97bc 76%,#a2d8ec 100%)}
.tc5 .t-bg{background:linear-gradient(160deg,#214d28 0%,#3c7c4b 44%,#6ebd7c 76%,#c1ebc9 100%)}
.t-scene{position:absolute;inset:0;opacity:.14;transition:opacity .4s}
.t-card:hover .t-scene{opacity:.22}
.tc1 .t-scene,.tc2 .t-scene{background:repeating-radial-gradient(ellipse at 50% 120%,transparent 0,transparent 30px,rgba(255,255,255,.06) 30px,rgba(255,255,255,.06) 31px)}
.tc3 .t-scene,.tc4 .t-scene{background:repeating-linear-gradient(-15deg,transparent,transparent 40px,rgba(255,255,255,.04) 40px,rgba(255,255,255,.04) 41px)}
.t-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,22,34,.56) 0%,rgba(7,22,34,.2) 54%,rgba(7,22,34,.04) 100%)}
.t-body{position:absolute;bottom:0;left:0;right:0;padding:22px 24px 20px;transform:translateY(18px);transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.t-card:hover .t-body{transform:translateY(0)}
.t-tag{display:inline-block;background:var(--gold);color:var(--white);font-size:8px;letter-spacing:.19em;text-transform:uppercase;font-weight:700;padding:5px 13px;border-radius:100px;margin-bottom:12px}
.t-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--white);line-height:1.08;margin-bottom:8px;max-width:14ch}
.t-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.t-meta span{font-size:10px;color:rgba(255,255,255,.82);display:flex;align-items:center;gap:5px}
.t-price{font-family:'Playfair Display',serif;font-size:23px;font-weight:700;color:var(--gold3);margin-bottom:14px}
.t-price small{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:300;color:rgba(255,255,255,.68)}
.t-btn{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(10px);color:var(--white);padding:11px 18px;border-radius:100px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;text-decoration:none;transition:all .3s}
.t-btn:hover{background:var(--gold);border-color:var(--gold)}
.t-num{position:absolute;top:14px;right:20px;font-family:'Bebas Neue',cursive;font-size:62px;color:rgba(255,255,255,.12);line-height:1}
.tours-incl{text-align:center;margin-top:20px;padding:16px 80px 28px}
.incl-strip{display:inline-flex;gap:24px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:100px;padding:14px 32px;flex-wrap:wrap;justify-content:center}
.incl-item{display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.62)}
.incl-item::before{content:'✦';color:var(--gold);font-size:9px}

/* SOCIALS */
#socials{position:relative;padding:32px 80px 24px;background:linear-gradient(180deg,#10384f 0%,#f4eee1 44%,var(--offwhite) 100%)}
.socials-shell{width:min(1180px,100%);margin:0 auto;padding:28px 32px;border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(247,240,227,.98));border:1px solid rgba(14,58,82,.08);box-shadow:0 18px 48px rgba(12,44,61,.08);display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:22px;align-items:center}
.socials-title{font-family:'Playfair Display',serif;font-size:clamp(30px,3.2vw,42px);line-height:1;letter-spacing:-.03em;color:var(--ocean);margin-bottom:10px}
.socials-text{font-size:14px;line-height:1.8;color:var(--mid);max-width:36ch}
.socials-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.social-card{display:flex;flex-direction:column;gap:10px;min-height:150px;padding:18px;border-radius:24px;background:rgba(14,58,82,.04);border:1px solid rgba(14,58,82,.08);text-decoration:none;transition:transform .28s,box-shadow .28s,border-color .28s,background .28s}
.social-card:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(14,58,82,.1);border-color:rgba(244,186,24,.35);background:rgba(255,255,255,.98)}
.social-card strong{font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--ocean)}
.social-card small{font-size:12px;line-height:1.65;color:var(--mid)}
.social-mark{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--ocean),var(--ocean3));font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--white);box-shadow:0 10px 24px rgba(14,58,82,.16)}
.social-mark svg{width:22px;height:22px;display:block;flex-shrink:0}
.social-card.is-highlight{background:linear-gradient(160deg,#10384f 0%,#19597a 100%);border-color:rgba(244,186,24,.28);box-shadow:0 18px 42px rgba(14,58,82,.22)}
.social-card.is-highlight strong,.social-card.is-highlight small{color:rgba(255,255,255,.94)}
.social-card.is-highlight .social-mark{background:linear-gradient(135deg,var(--gold),#ffd45b);color:var(--ocean);box-shadow:0 10px 28px rgba(244,186,24,.28)}
.social-card.is-disabled{background:rgba(14,58,82,.03);opacity:.78}
.social-card.is-disabled .social-mark{background:linear-gradient(135deg,#bac9d1,#d9e2e7);color:var(--ocean)}

/* EXPERIENCE */
#exp{padding:30px 80px 24px;background:var(--offwhite)}
#exp>.rR{width:min(980px,100%);margin:0 auto}
.exp-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:200px 200px 200px;gap:12px}
.em{border-radius:18px;overflow:hidden;position:relative;transition:transform .4s}
.em:hover{transform:scale(.98)}
.em span{position:absolute;bottom:14px;left:14px;right:14px;font-family:'Playfair Display',serif;font-size:16px;font-style:italic;color:rgba(255,255,255,.9);text-shadow:0 2px 10px rgba(0,0,0,.4);z-index:2}
.em:nth-child(1){grid-row:1/3;background:linear-gradient(150deg,#0e3a52,#1a6a8f,#4ab8d4)}
.em:nth-child(2){background:linear-gradient(150deg,#1a3820,#2e6e3e,#5ab87a)}
.em:nth-child(3){background:linear-gradient(150deg,#3a2008,#8a4a18,#d4902a)}
.em:nth-child(4){grid-column:1/3;background:linear-gradient(150deg,#0a1520,#1a3a55,#3b7a9a)}
.em::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%)}
.exp-features{margin-top:48px}
.exp-feat{display:flex;gap:22px;align-items:flex-start;padding-bottom:28px;margin-bottom:28px;border-bottom:1px solid var(--sand2)}
.exp-feat:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.exp-feat-num{font-family:'Playfair Display',serif;font-size:44px;font-weight:700;color:var(--sand3);line-height:1;flex-shrink:0;min-width:60px}
.exp-feat-t{font-size:14px;font-weight:600;color:var(--ocean);margin-bottom:6px}
.exp-feat-b{font-size:13px;color:var(--mid);line-height:1.75;font-weight:300}

/* PROCESS */
#process{position:relative;padding:0;background:#081e2a;text-align:center;overflow:clip;isolation:isolate}
.process-pin{position:sticky;top:0;height:100vh;height:100dvh;height:100svh;margin-bottom:-100vh;margin-bottom:-100dvh;margin-bottom:-100svh;z-index:0;overflow:hidden;pointer-events:none;background:
  radial-gradient(circle at 50% 100%,rgba(117,193,215,.26),transparent 30%),
  radial-gradient(circle at 18% 18%,rgba(244,186,24,.12),transparent 20%),
  radial-gradient(circle at 82% 14%,rgba(255,255,255,.08),transparent 24%),
  linear-gradient(180deg,rgba(8,30,42,.9) 0%,rgba(10,36,49,.8) 32%,rgba(16,56,79,.72) 56%,rgba(8,30,42,.88) 100%),
  linear-gradient(180deg,#0a2230 0%,#12384d 45%,#0c2b3d 100%)}
.process-overlay{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(6,22,32,.68) 0%,rgba(6,22,32,.48) 22%,rgba(6,22,32,.34) 50%,rgba(6,22,32,.7) 100%),
  radial-gradient(circle at 50% 15%,rgba(247,240,227,.28),transparent 34%),
  linear-gradient(90deg,rgba(8,30,42,.4) 0%,rgba(8,30,42,.14) 50%,rgba(8,30,42,.4) 100%)}
.process-content{position:relative;z-index:3;min-height:84vh;display:flex;flex-direction:column;justify-content:flex-start;padding:56px 80px 88px}
.process-content::before{content:'HOW';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Bebas Neue',cursive;font-size:30vw;color:rgba(255,255,255,.07);pointer-events:none;z-index:0;letter-spacing:.05em}
.process-content>*{position:relative;z-index:1}
#process .s-label{color:var(--gold2)}
#process .s-label::before{background:var(--gold2)}
#process .s-title{color:var(--white)}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px auto 0;max-width:1620px;width:100%}
.p-step{background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:56px 40px;position:relative;transition:all .4s;overflow:hidden}
.p-step:first-child{border-radius:28px 0 0 28px}
.p-step:last-child{border-radius:0 28px 28px 0}
.p-step::before{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(to right,var(--gold),var(--gold2));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.p-step:hover::before{transform:scaleX(1)}
.p-step:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,.22);z-index:2;border-radius:28px;background:rgba(255,255,255,.94)}
.p-num{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--sand),var(--sand2));display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--ocean);margin:0 auto 28px;transition:all .4s}
.p-step:hover .p-num{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--white);box-shadow:0 8px 30px rgba(244,186,24,.4)}
.p-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--ocean);margin-bottom:14px}
.p-text{font-size:13px;color:var(--mid);line-height:1.8;font-weight:300}
.p-connect{position:absolute;top:40px;right:-15px;width:30px;height:2px;background:rgba(247,240,227,.58);z-index:10}
.p-step:last-child .p-connect{display:none}

/* BOOKING */
#booking{position:fixed;inset:0;z-index:120000;display:grid;place-items:center;padding:28px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s,visibility .35s}
#booking.open{opacity:1;visibility:visible;pointer-events:auto}
.booking-backdrop{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,22,35,.58),rgba(5,22,35,.82));backdrop-filter:blur(14px)}
.booking-shell{position:relative;width:min(1040px,100%);height:min(900px,calc(100vh - 56px));height:min(900px,calc(100svh - 56px));height:min(900px,calc(100dvh - 56px));max-height:calc(100vh - 56px);max-height:calc(100svh - 56px);max-height:calc(100dvh - 56px);display:grid;grid-template-columns:minmax(220px,250px) minmax(0,1fr);background:linear-gradient(180deg,rgba(255,255,255,.94) 0%,rgba(250,245,236,.98) 100%);border:1px solid rgba(255,255,255,.54);border-radius:32px;overflow:hidden;box-shadow:0 34px 110px rgba(5,22,35,.32);transform:translateY(30px) scale(.97);transition:transform .4s cubic-bezier(.22,1,.36,1)}
#booking.open .booking-shell{transform:none}
.booking-close{position:absolute;top:16px;right:16px;z-index:7;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(5,22,35,.32);color:var(--white);font-size:28px;line-height:1;cursor:pointer;backdrop-filter:blur(12px);transition:transform .25s,background .25s,border-color .25s}
.booking-close:hover{background:rgba(5,22,35,.48);border-color:rgba(255,255,255,.32);transform:rotate(90deg)}
.booking-side{position:relative;display:flex;align-items:flex-end;padding:18px;background:
  radial-gradient(circle at top right,rgba(244,186,24,.28),transparent 30%),
  radial-gradient(circle at bottom left,rgba(89,184,217,.18),transparent 28%),
  linear-gradient(165deg,#072130 0%,#0f4d6c 52%,#0e6a8a 100%);
min-height:0;overflow:hidden}
.booking-side::before{content:'';position:absolute;inset:18px;border-radius:26px;border:1px solid rgba(255,255,255,.08);pointer-events:none}
.booking-story{position:relative;padding:24px 22px;border-radius:26px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:var(--white);overflow:auto;display:flex;flex-direction:column;justify-content:space-between;gap:24px;backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.booking-story::before{content:'';position:absolute;top:-110px;right:-70px;width:240px;height:240px;border-radius:50%;border:1px solid rgba(255,255,255,.14)}
.booking-story::after{content:'';position:absolute;left:-100px;bottom:-130px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.05)}
.booking-story::-webkit-scrollbar{width:8px}
.booking-story::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.booking-kicker{position:relative;display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.72)}
.booking-kicker::before{content:'';width:30px;height:1px;background:var(--gold3)}
.booking-story-title{position:relative;font-family:'Playfair Display',serif;font-size:clamp(34px,3.3vw,46px);line-height:.97;letter-spacing:-.03em;max-width:240px;margin-top:16px}
.booking-story-copy{position:relative;font-size:13px;line-height:1.8;color:rgba(255,255,255,.74);margin-top:16px;max-width:250px}
.booking-story-grid{position:relative;display:grid;gap:12px}
.booking-story-card{padding:14px 16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);border-radius:18px;backdrop-filter:blur(10px)}
.booking-story-card strong{display:block;font-size:13px;letter-spacing:.04em;color:var(--white);margin-bottom:5px}
.booking-story-card span{display:block;font-size:12px;line-height:1.6;color:rgba(255,255,255,.68)}
.booking-story-pills{position:relative;display:flex;flex-wrap:wrap;gap:10px}
.booking-story-pill{padding:9px 14px;border-radius:100px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.booking-nori-pop{position:relative;width:100%;padding:18px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.08));border:1px solid rgba(255,255,255,.14);color:var(--white);backdrop-filter:blur(12px);box-shadow:0 20px 34px rgba(0,0,0,.12)}
.booking-nori-pop::before{content:'';position:absolute;top:16px;right:16px;width:62px;height:62px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.26),transparent 70%);opacity:.9}
.booking-nori-chip{position:relative;display:inline-flex;align-items:center;gap:8px;min-height:30px;padding:0 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);font-size:9px;letter-spacing:.18em;text-transform:uppercase}
.booking-nori-chip::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(244,186,24,.16)}
.booking-nori-pop h4{position:relative;margin:14px 0 8px;font-family:'Playfair Display',serif;font-size:28px;line-height:.95;letter-spacing:-.03em;max-width:10ch}
.booking-nori-pop p{position:relative;font-size:12px;line-height:1.7;color:rgba(255,255,255,.78)}
.booking-nori-btn{position:relative;width:100%;min-height:48px;margin-top:16px;padding:0 18px;border:none;border-radius:999px;background:linear-gradient(135deg,#fff1c4,#f4ba18);color:var(--ocean);font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;cursor:pointer;box-shadow:0 14px 30px rgba(244,186,24,.22);transition:transform .25s,box-shadow .25s}
.booking-nori-btn:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(244,186,24,.28)}
.booking-nori-note{position:relative;margin-top:12px;font-size:11px;line-height:1.55;color:rgba(255,255,255,.66)}
.booking-form{position:relative;display:flex;flex-direction:column;height:100%;min-height:0;background:
  linear-gradient(180deg,rgba(255,255,255,.92) 0%,rgba(247,240,227,.94) 100%);
overflow:hidden}
.booking-form::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--gold),var(--ocean3),#59b8d9)}
.booking-water-fill{position:absolute;left:0;right:0;bottom:0;height:var(--booking-water-height,12%);opacity:var(--booking-water-opacity,.34);background:
  linear-gradient(180deg,rgba(89,184,217,.04) 0%,rgba(89,184,217,.18) 24%,rgba(27,124,164,.28) 58%,rgba(7,73,103,.54) 100%);
pointer-events:none;transition:height .35s cubic-bezier(.22,1,.36,1),opacity .35s ease;z-index:1}
.booking-water-fill::before{content:'';position:absolute;left:-12%;right:-12%;top:-18px;height:34px;background:radial-gradient(32px 12px at 18px 22px,rgba(255,255,255,.6) 0 40%,transparent 42%) repeat-x;background-size:64px 34px;animation:bookingWave 6s linear infinite;opacity:.9}
.booking-water-fill::after{content:'';position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(255,255,255,.18),transparent 18%),
  radial-gradient(circle at 18% 24%,rgba(255,255,255,.24),transparent 18%),
  radial-gradient(circle at 78% 16%,rgba(255,255,255,.18),transparent 16%);
mix-blend-mode:screen;opacity:.72}
.booking-form-scroll{position:relative;z-index:2;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:26px}
.booking-form-scroll::-webkit-scrollbar{width:10px}
.booking-form-scroll::-webkit-scrollbar-thumb{background:rgba(14,58,82,.16);border-radius:999px}
.booking-form-card{position:relative;max-width:560px;min-height:100%;margin:0 auto;padding:24px;border-radius:28px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.8);box-shadow:0 28px 70px rgba(14,58,82,.12),inset 0 1px 0 rgba(255,255,255,.72);backdrop-filter:blur(14px)}
.booking-form-card>*{position:relative;z-index:2}
.booking-form-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.booking-badge{min-width:138px;padding:12px 14px;border-radius:20px;background:linear-gradient(135deg,#fff5cf,#f4ba18);box-shadow:0 14px 30px rgba(244,186,24,.16);font-family:'Playfair Display',serif;font-size:17px;line-height:1.05;color:var(--ocean)}
.booking-badge span{display:block;margin-bottom:6px;font-family:'DM Sans',sans-serif;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(14,58,82,.65)}
.form-title{font-family:'Playfair Display',serif;font-size:32px;font-weight:700;color:var(--ocean);margin-bottom:6px;line-height:1}
.form-sub{display:none}
.form-sub-clean{font-size:13px;color:var(--mid);line-height:1.7;max-width:33ch}
.booking-form-strip{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.booking-form-strip span{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border-radius:999px;background:rgba(14,58,82,.05);border:1px solid rgba(14,58,82,.08);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--ocean)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.fg{margin-bottom:12px}
.fl{display:block;font-size:10px;letter-spacing:.17em;text-transform:uppercase;font-weight:700;color:var(--ocean);margin-bottom:8px}
.fc{width:100%;padding:14px 16px;border:1.5px solid rgba(212,191,153,.7);background:rgba(255,255,255,.68);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--charcoal);outline:none;transition:all .3s;border-radius:16px;appearance:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.fc:focus{border-color:var(--gold);background:var(--white);box-shadow:0 0 0 4px rgba(244,186,24,.1),0 14px 30px rgba(244,186,24,.08)}
.fc::placeholder{color:#bbb}
select.fc{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M0 0l5 7 5-7z' fill='%23f4ba18'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:38px;cursor:pointer}
.g-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:16px;background:rgba(255,255,255,.62);border:1.5px solid rgba(212,191,153,.56);box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.g-btn{width:40px;height:40px;border:1.5px solid rgba(212,191,153,.72);background:var(--white);border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--ocean);transition:all .2s;flex-shrink:0;box-shadow:0 10px 24px rgba(14,58,82,.06)}
.g-btn:hover{background:var(--gold);color:var(--white);border-color:var(--gold);transform:translateY(-1px)}
#gcount{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--ocean);min-width:36px;text-align:center}
.fnote{display:none}
.booking-note{font-size:12px;color:var(--mid);line-height:1.75;padding:16px 18px;background:linear-gradient(135deg,rgba(247,240,227,.94),rgba(253,250,244,.98));border:1px solid rgba(244,186,24,.14);border-radius:18px;margin:6px 0 20px}
.booking-note strong{color:var(--gold)}
.fnote strong{color:var(--gold)}
.btn-submit{width:100%;min-height:58px;padding:0 18px;background:linear-gradient(135deg,var(--ocean),var(--ocean2));color:var(--white);border:none;font-family:'DM Sans',sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;cursor:pointer;border-radius:18px;transition:all .35s;position:relative;overflow:hidden;box-shadow:0 14px 36px rgba(14,58,82,.24)}
.btn-submit::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold),var(--gold2));border-radius:18px;transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.77,0,.175,1)}
.btn-submit:hover::before{transform:scaleX(1)}
.btn-submit span{position:relative;z-index:1}
#bsub span{font-size:0}
#bsub span::after{content:'Send My Booking Request';font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.btn-submit:hover{box-shadow:0 18px 46px rgba(244,186,24,.35);transform:translateY(-2px)}
.form-success{display:none;min-height:100%;text-align:center;padding:34px 20px;align-items:center;justify-content:center;flex-direction:column}
.success-wave{font-size:52px;margin-bottom:18px}
.form-success h3{font-family:'Playfair Display',serif;font-size:28px;color:var(--ocean);margin-bottom:10px}
.form-success p{font-size:14px;color:var(--mid);line-height:1.8;font-weight:300}

@keyframes bookingWave{
  from{background-position:0 0}
  to{background-position:128px 0}
}

/* CHATBOT */
.travel-chat{position:fixed;inset:0;z-index:120100;display:grid;place-items:end end;padding:18px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s,visibility .3s}
.travel-chat.open{opacity:1;visibility:visible;pointer-events:auto}
.travel-chat-backdrop{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,22,35,.5),rgba(5,22,35,.78));backdrop-filter:blur(14px)}
.travel-chat-shell{position:relative;width:min(460px,calc(100vw - 36px));max-height:min(700px,calc(100vh - 36px));max-height:min(700px,calc(100svh - 36px));max-height:min(700px,calc(100dvh - 36px));display:flex;flex-direction:column;border-radius:28px;overflow:hidden;background:linear-gradient(180deg,#ffffff 0%,#fbf6eb 100%);border:1px solid rgba(255,255,255,.46);box-shadow:0 28px 80px rgba(5,22,35,.32);transform:translateY(18px) scale(.98);transition:transform .35s cubic-bezier(.22,1,.36,1)}
.travel-chat.open .travel-chat-shell{transform:none}
.travel-chat-close{position:absolute;top:14px;right:14px;z-index:5;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.14);color:var(--white);font-size:24px;line-height:1;cursor:pointer;backdrop-filter:blur(10px);transition:transform .25s,background .25s}
.travel-chat-close:hover{transform:rotate(90deg);background:rgba(255,255,255,.24)}
.travel-chat-aside{position:relative;padding:20px 18px 16px;background:
  radial-gradient(circle at top right,rgba(244,186,24,.24),transparent 34%),
  linear-gradient(160deg,#082435 0%,#104866 48%,#c89230 150%);
color:var(--white);display:flex;flex-direction:column;gap:10px;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.14)}
.travel-chat-aside::before{content:'';position:absolute;top:-110px;right:-80px;width:260px;height:260px;border-radius:50%;border:1px solid rgba(255,255,255,.14)}
.travel-chat-badge{position:relative;display:inline-flex;align-items:center;width:max-content;min-height:28px;padding:0 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);font-size:9px;letter-spacing:.18em;text-transform:uppercase}
.travel-chat-aside h3{position:relative;font-family:'Playfair Display',serif;font-size:24px;line-height:1;letter-spacing:-.03em;max-width:12ch}
.travel-chat-aside p{position:relative;font-size:13px;line-height:1.6;color:rgba(255,255,255,.8)}
.travel-chat-pills{display:none}
.travel-chat-pill{padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.84)}
.travel-chat-status{position:relative;margin-top:4px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:11px;line-height:1.55;color:rgba(255,255,255,.76)}
.travel-chat-status.is-error{background:rgba(154,40,40,.16);border-color:rgba(255,138,138,.22);color:rgba(255,228,228,.92)}
.travel-chat-panel{display:flex;flex-direction:column;min-height:0;padding:16px 16px 18px;background:linear-gradient(180deg,#ffffff 0%,#fcf7ee 100%)}
.travel-chat-top{display:none}
.travel-chat-kicker{display:inline-flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--gold)}
.travel-chat-kicker::before{content:'';width:28px;height:1px;background:currentColor}
.travel-chat-top h4{margin-top:10px;font-family:'Playfair Display',serif;font-size:30px;color:var(--ocean);line-height:1}
.travel-chat-top-actions{display:flex;flex-wrap:wrap;gap:10px}
.travel-chat-mini{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border-radius:999px;background:rgba(14,58,82,.05);border:1px solid rgba(14,58,82,.08);color:var(--ocean);text-decoration:none;font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:transform .25s,background .25s,border-color .25s}
.travel-chat-mini:hover{transform:translateY(-1px);background:rgba(244,186,24,.12);border-color:rgba(244,186,24,.3)}
.travel-chat-thread{display:flex;flex-direction:column;gap:12px;min-height:0;flex:1;overflow:auto;padding-right:4px}
.travel-chat-thread::-webkit-scrollbar{width:8px}
.travel-chat-thread::-webkit-scrollbar-thumb{background:rgba(14,58,82,.16);border-radius:999px}
.travel-chat-message{display:flex;flex-direction:column;gap:8px;max-width:100%}
.travel-chat-message.is-user{margin-left:auto;align-items:flex-end}
.travel-chat-message.is-assistant{align-items:flex-start}
.travel-chat-bubble{padding:14px 16px;border-radius:20px;background:rgba(14,58,82,.06);border:1px solid rgba(14,58,82,.08);color:var(--charcoal);font-size:13px;line-height:1.65;white-space:pre-wrap}
.travel-chat-message.is-user .travel-chat-bubble{background:linear-gradient(135deg,var(--ocean),var(--ocean2));border-color:rgba(14,58,82,.34);color:var(--white);border-bottom-right-radius:10px}
.travel-chat-message.is-assistant .travel-chat-bubble{border-bottom-left-radius:10px}
.travel-chat-message.is-system .travel-chat-bubble{background:rgba(244,186,24,.12);border-color:rgba(244,186,24,.2)}
.travel-chat-meta{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid)}
.travel-chat-form{display:grid;gap:10px;padding-top:14px;margin-top:14px;border-top:1px solid rgba(14,58,82,.08)}
.travel-chat-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--ocean)}
.travel-chat-compose{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end}
.travel-chat-compose textarea{width:100%;min-height:54px;max-height:140px;padding:13px 15px;border-radius:18px;border:1.5px solid rgba(212,191,153,.7);background:rgba(247,240,227,.78);font-family:'DM Sans',sans-serif;font-size:13px;line-height:1.55;color:var(--charcoal);outline:none;resize:none;transition:border-color .25s,box-shadow .25s,background .25s}
.travel-chat-compose textarea:focus{border-color:var(--gold);background:var(--white);box-shadow:0 0 0 4px rgba(244,186,24,.1)}
.travel-chat-send{min-width:108px;min-height:54px;padding:0 18px;border:none;border-radius:18px;background:linear-gradient(135deg,var(--ocean),var(--ocean2));color:var(--white);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;cursor:pointer;box-shadow:0 14px 30px rgba(14,58,82,.18);transition:transform .25s,box-shadow .25s}
.travel-chat-send:hover{transform:translateY(-1px);box-shadow:0 18px 36px rgba(14,58,82,.22)}
.travel-chat-send[disabled]{opacity:.65;cursor:wait}
.travel-chat-note{display:none}
.travel-chat-typing{display:inline-flex;align-items:center;gap:6px}
.travel-chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:chatPulse 1.2s ease-in-out infinite}
.travel-chat-typing span:nth-child(2){animation-delay:.15s}
.travel-chat-typing span:nth-child(3){animation-delay:.3s}
@keyframes chatPulse{0%,80%,100%{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}

@media(max-width:980px){
  .travel-chat-shell{width:min(440px,calc(100vw - 28px));max-height:calc(100vh - 28px);max-height:calc(100svh - 28px);max-height:calc(100dvh - 28px)}
}

/* TESTIMONIALS */
#testi{position:relative;padding:56px 0 64px;overflow:hidden;isolation:isolate;background:url("https://kglopbyqtdyldrhnakxk.supabase.co/storage/v1/object/public/Demo%20Bucket/reviews.jpeg") center 58% / cover fixed no-repeat}
#testi::before{content:'';position:absolute;inset:0;z-index:0;background:
  linear-gradient(180deg,rgba(7,27,38,.78) 0%,rgba(7,27,38,.56) 24%,rgba(7,27,38,.42) 52%,rgba(7,27,38,.74) 100%),
  radial-gradient(circle at 50% 16%,rgba(255,255,255,.12),transparent 26%),
  linear-gradient(90deg,rgba(8,30,42,.46) 0%,rgba(8,30,42,.12) 50%,rgba(8,30,42,.46) 100%);pointer-events:none}
.testi-content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center}
.testi-head{padding:0 80px;text-align:center;margin-bottom:40px}
.testi-head .s-label{justify-content:center;color:var(--gold2)}
.testi-head .s-label::before{background:var(--gold2)}
.testi-head .s-title{color:var(--white)}
.testi-runner{overflow:hidden;position:relative;z-index:2}
.testi-track{display:flex;gap:24px;animation:testiRun 45s linear infinite}
.testi-track:hover{animation-play-state:paused}
.tc{flex:0 0 400px;background:rgba(14,58,82,.38);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:36px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all .4s;box-shadow:0 18px 36px rgba(8,30,42,.18)}
.tc:hover{background:rgba(14,58,82,.48);transform:translateY(-6px);border-color:rgba(244,186,24,.3)}
.tc-q{font-family:'Playfair Display',serif;font-size:56px;color:var(--gold2);line-height:.7;margin-bottom:12px;opacity:.7}
.tc-stars{color:var(--gold2);font-size:14px;letter-spacing:3px;margin-bottom:14px}
.tc-text{font-size:14px;line-height:1.85;color:rgba(255,255,255,.7);font-style:italic;margin-bottom:26px;font-weight:300}
.tc-auth{display:flex;align-items:center;gap:12px}
.tc-av{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--white);flex-shrink:0}
.tc-name{font-weight:600;font-size:14px;color:var(--white)}
.tc-from{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px}
@keyframes testiRun{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* CTA BAND */
#ctaband{padding:48px 80px;background:linear-gradient(135deg,var(--sand) 0%,var(--offwhite) 100%);display:flex;align-items:center;justify-content:space-between;gap:48px;border-top:1px solid var(--sand2)}
.ctaband-title{font-family:'Playfair Display',serif;font-size:clamp(32px,4vw,54px);font-weight:700;color:var(--ocean);line-height:1.05;letter-spacing:-.02em}
.ctaband-title em{font-style:italic;color:var(--gold)}
.ctaband-sub{font-size:15px;color:var(--mid);margin-top:12px;font-weight:300;max-width:480px}
.ctaband-btns{display:flex;gap:16px;flex-shrink:0;align-items:center}
.btn-ocean{display:inline-flex;align-items:center;gap:10px;background:transparent;border:2px solid var(--ocean);color:var(--ocean);padding:15px 28px;border-radius:100px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;text-decoration:none;transition:all .3s}
.btn-ocean:hover{background:var(--ocean);color:var(--white)}

/* FOOTER */
footer{background:var(--ocean);padding:90px 80px 40px;color:rgba(255,255,255,.6)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:70px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo-wrap{display:flex;align-items:center;gap:12px;text-decoration:none;margin-bottom:18px}
.footer-logo-wrap img{width:44px;height:44px;object-fit:contain;border-radius:50%;background:rgba(255,255,255,.08);padding:3px}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--white);line-height:1.1}
.footer-brand-name span{display:block;font-size:10px;letter-spacing:.25em;text-transform:uppercase;font-family:'DM Sans',sans-serif;font-weight:300;opacity:.6;margin-top:1px}
.footer-desc{font-size:13px;line-height:1.8;max-width:270px;margin-bottom:28px;font-weight:300}
.footer-socials{display:flex;gap:10px}
.soc{width:38px;height:38px;border:1px solid rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);text-decoration:none;font-size:14px;transition:all .3s}
.soc:hover{background:var(--gold);border-color:var(--gold);color:var(--white)}
.footer-col h4{font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--white);margin-bottom:22px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;transition:color .3s;display:flex;align-items:center;gap:8px;font-weight:300}
.footer-col ul li a:hover{color:var(--gold2)}
.footer-col ul li a::before{content:'';width:14px;height:1px;background:currentColor;opacity:.4;flex-shrink:0}
.footer-bot{padding-top:30px;display:flex;justify-content:space-between;align-items:center;font-size:12px}
.footer-bot a{color:var(--gold2);text-decoration:none}

/* ADMIN ASSET EDITOR */
body.admin-mode{cursor:default}
body.admin-mode *{cursor:default !important}
body.admin-mode .reveal,body.admin-mode .rL,body.admin-mode .rR{opacity:1 !important;transform:none !important}
body.admin-mode .fl-wa,body.admin-mode .fl-book{display:none !important}
body.admin-mode #booking{display:none !important}
body.admin-mode .t-card,body.admin-mode .t-card:hover{flex:0 0 382px;height:360px;border-radius:24px}
body.admin-mode .t-card:hover .t-bg,body.admin-mode .t-card:hover .t-body{transform:none}
body.admin-mode .t-body{transform:translateY(0)}
body.admin-mode [data-asset-slot]{isolation:isolate}
body.admin-mode [data-asset-slot]::after{content:'';position:absolute;inset:8px;border:2px dashed rgba(244,186,24,.55);border-radius:inherit;pointer-events:none;z-index:24}
.asset-holder-control{position:absolute;inset:0;z-index:30;display:none;align-items:flex-end;justify-content:flex-start;padding:14px;border-radius:inherit;background:linear-gradient(180deg,rgba(5,22,35,.05),rgba(5,22,35,.52));border:none;color:var(--white);text-align:left;transition:background .25s,transform .25s;overflow:auto}
body.admin-mode [data-asset-slot]>.asset-holder-control{display:flex}
.asset-holder-control.is-dragging{background:linear-gradient(180deg,rgba(244,186,24,.15),rgba(5,22,35,.58))}
.asset-holder-panel{display:grid;gap:10px;width:min(280px,100%)}
.asset-holder-pill{display:grid;gap:5px;max-width:min(280px,100%);padding:10px 12px;border-radius:16px;background:rgba(5,22,35,.82);border:1px solid rgba(255,255,255,.14);box-shadow:0 14px 30px rgba(0,0,0,.2)}
.asset-holder-pill strong{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700}
.asset-holder-pill span{font-size:11px;line-height:1.45;color:rgba(255,255,255,.74)}
.asset-holder-actions{display:flex;flex-wrap:wrap;gap:8px}
.asset-holder-btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(244,186,24,.92);color:#0b2433;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;cursor:pointer}
.asset-holder-btn.is-secondary{background:rgba(255,255,255,.12);color:var(--white)}
.asset-holder-field{display:grid;gap:6px;padding:10px 12px;border-radius:16px;background:rgba(5,22,35,.82);border:1px solid rgba(255,255,255,.14);box-shadow:0 14px 30px rgba(0,0,0,.16)}
.asset-holder-field span{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.84)}
.asset-holder-input{width:100%;min-height:64px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.1);color:var(--white);font-family:'DM Sans',sans-serif;font-size:12px;line-height:1.45;resize:vertical}
.asset-holder-input::placeholder{color:rgba(255,255,255,.48)}
@media(max-width:900px){
  .asset-holder-control{padding:10px}
  .asset-holder-panel{width:min(240px,100%)}
  .asset-holder-pill,.asset-holder-field{padding:8px 10px}
  .asset-holder-input{min-height:56px;font-size:11px}
}

/* FLOAT BUTTONS */
.fl-wa{position:fixed;bottom:36px;left:36px;z-index:9999;display:flex;align-items:center;gap:10px;background:#25D366;color:var(--white);padding:13px 22px;border-radius:100px;box-shadow:0 8px 30px rgba(37,211,102,.35);text-decoration:none;font-size:12px;font-weight:600;letter-spacing:.04em;transition:all .4s;opacity:0;transform:translateY(20px)}
.fl-wa.vis{opacity:1;transform:translateY(0)}
.fl-wa:hover{background:#128c7e;transform:translateY(-3px);box-shadow:0 14px 40px rgba(18,140,126,.4)}
.fl-book{position:fixed;right:24px;bottom:18px;z-index:9999;width:124px;height:154px;display:flex;align-items:flex-end;justify-content:center;text-decoration:none;transition:transform .4s,opacity .4s,filter .4s;opacity:0;transform:translateY(18px) scale(.9);filter:drop-shadow(0 18px 38px rgba(8,30,42,.28));overflow:visible}
.fl-book::before{content:'';position:absolute;left:18px;right:18px;bottom:10px;height:22px;border-radius:50%;background:radial-gradient(circle,rgba(255,251,242,.46) 0%,rgba(255,251,242,.18) 42%,transparent 76%);opacity:.7;transition:opacity .35s,transform .35s}
.fl-book.vis{opacity:1;transform:none}
.fl-book:hover{transform:translateY(-5px) scale(1.03);filter:drop-shadow(0 22px 48px rgba(8,30,42,.34))}
.fl-book:hover::before{opacity:1;transform:scale(1.08)}
.fl-book-beacon{position:relative;display:block;width:118px;height:146px;overflow:visible;pointer-events:none}
.fl-book-rotor,.fl-book-aura{position:absolute;left:52%;top:30px;pointer-events:none}
.fl-book-rotor{width:240vw;height:150vh;transform-origin:0 50%;transform:translateY(-50%) rotate(0deg);opacity:.94;animation:flBookSweep 8s linear infinite;will-change:transform}
.fl-book-rotor::before{content:'';position:absolute;left:0;top:50%;width:100%;height:30%;transform:translateY(-50%);clip-path:polygon(0 50%,100% 0,100% 100%);background:linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.34) 10%,rgba(255,252,245,.16) 26%,rgba(255,252,245,.06) 44%,rgba(255,252,245,0) 72%);filter:blur(4px)}
.fl-book-rotor::after{content:'';position:absolute;left:-6px;top:50%;width:72px;height:72px;transform:translateY(-50%);background:radial-gradient(circle,rgba(255,255,255,.98) 0%,rgba(255,255,255,.34) 26%,rgba(255,255,255,0) 72%);filter:blur(6px)}
.fl-book-aura{width:78px;height:78px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.98) 0%,rgba(255,255,255,.44) 22%,rgba(255,251,241,.1) 56%,transparent 74%);opacity:.94;animation:flBookPulse 2.4s ease-in-out infinite}
.fl-book-icon{position:absolute;left:50%;bottom:0;width:68px;height:126px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none;filter:drop-shadow(0 8px 14px rgba(0,0,0,.22))}
.fl-book-brace{display:none}
.fl-book-spire{width:8%;height:5%;background:#090909;clip-path:polygon(50% 0,0 100%,100% 100%)}
.fl-book-roof{width:46%;height:9%;margin-top:-1%;background:linear-gradient(180deg,#1a1a1a 0%,#050505 100%);clip-path:polygon(50% 0,10% 100%,90% 100%);filter:drop-shadow(0 2px 3px rgba(0,0,0,.18))}
.fl-book-lantern{position:relative;width:34%;height:14%;margin-top:-1%;background:linear-gradient(180deg,#2d2d2d 0%,#101010 100%);border:2px solid #101010;border-bottom-width:3px;border-radius:6px 6px 8px 8px;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.08) inset}
.fl-book-lantern::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.75) 0 16%,rgba(17,17,17,.82) 16% 25%,rgba(255,255,255,.28) 25% 48%,rgba(17,17,17,.82) 48% 56%,rgba(255,255,255,.28) 56% 78%,rgba(17,17,17,.82) 78% 86%,rgba(255,255,255,.65) 86% 100%);opacity:.92}
.fl-book-lantern::after{content:'';position:absolute;left:12%;right:12%;top:14%;height:20%;background:linear-gradient(180deg,rgba(255,255,255,.34),rgba(255,255,255,0));opacity:.7}
.fl-book-lamp{position:absolute;left:50%;top:50%;width:24%;aspect-ratio:1;transform:translate(-50%,-50%);border-radius:50%;background:#ffffff;box-shadow:0 0 18px rgba(255,255,255,1),0 0 38px rgba(255,255,255,.82);animation:flBookLamp 1.9s ease-in-out infinite}
.fl-book-gallery{position:relative;width:76%;height:5%;margin-top:-1%;background:linear-gradient(180deg,#f1f4f6 0%,#c7cfd7 100%);border:2px solid #101010;border-radius:999px}
.fl-book-gallery::before{content:'';position:absolute;inset:1px 7px;background:repeating-linear-gradient(90deg,transparent 0 7px,#111111 7px 9px,transparent 9px 16px);opacity:.58}
.fl-book-body{position:relative;width:44%;height:62%;margin-top:-1%;background:linear-gradient(to bottom,#171513 0 18%,#d4be95 18% 38%,#191715 38% 58%,#d4be95 58% 79%,#171513 79% 100%);clip-path:polygon(17% 0,83% 0,100% 100%,0 100%);box-shadow:inset 0 0 0 2px rgba(17,17,17,.62),inset 8px 0 10px rgba(255,255,255,.14),inset -10px 0 12px rgba(0,0,0,.2)}
.fl-book-body::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.16) 0 18%,rgba(255,255,255,0) 18% 82%,rgba(0,0,0,.14) 82% 100%);opacity:.95}
.fl-book-body::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(to bottom,rgba(255,255,255,.06) 0 2px,rgba(0,0,0,0) 2px 34px);mix-blend-mode:soft-light;opacity:.55}
.fl-book-window{position:absolute;left:50%;transform:translateX(-50%);width:16%;border-radius:999px;background:#161616;box-shadow:0 0 0 1px rgba(255,255,255,.26)}
.fl-book-window-top{top:24%;height:9%}
.fl-book-window-mid{top:48%;height:9%}
.fl-book-door{position:absolute;left:50%;bottom:7%;width:22%;height:16%;transform:translateX(-50%);border-radius:8px 8px 0 0;background:#161616;box-shadow:0 0 0 1px rgba(255,255,255,.14)}
.fl-book-base{position:relative;width:96%;height:8%;margin-top:-1%;background:linear-gradient(180deg,#f5f1ea 0%,#c2cad4 100%);border:2px solid #111111;border-bottom-width:4px;border-radius:12px 12px 8px 8px}
.fl-book-base::before{content:'';position:absolute;left:8%;right:8%;top:4px;height:2px;background:rgba(17,17,17,.15);border-radius:999px}
@keyframes flBookSweep{from{transform:translateY(-50%) rotate(0deg)}to{transform:translateY(-50%) rotate(360deg)}}
@keyframes flBookPulse{0%,100%{opacity:.82;transform:translate(-50%,-50%) scale(.9)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}}
@keyframes flBookLamp{0%,100%{opacity:.86;box-shadow:0 0 16px rgba(255,255,255,1),0 0 32px rgba(255,255,255,.58)}50%{opacity:1;box-shadow:0 0 24px rgba(255,255,255,1),0 0 48px rgba(255,255,255,.82)}}
@media(prefers-reduced-motion:reduce){
  .fl-book-rotor{animation-duration:18s}
  .fl-book-aura,.fl-book-lamp{animation-duration:5s}
}

/* REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s,transform .9s}
.rL{opacity:0;transform:translateX(-36px);transition:opacity .9s,transform .9s}
.rR{opacity:0;transform:translateX(36px);transition:opacity .9s,transform .9s}
.reveal.on,.rL.on,.rR.on{opacity:1;transform:none}
[data-d="1"]{transition-delay:.1s}[data-d="2"]{transition-delay:.2s}[data-d="3"]{transition-delay:.3s}[data-d="4"]{transition-delay:.4s}

@media(pointer:coarse){
  body{cursor:auto}
  #cur,#cur2{display:none !important}
}

@media(max-width:1100px){
  #about{grid-template-columns:1fr;gap:32px}
  .hero-content{padding:0 40px}
  .p-connect{display:none}
  #about,#exp,#ctaband{padding:34px 40px}
  #socials{padding:24px 40px 22px}
  #about{padding-bottom:22px}
  .about-visual{height:500px;width:min(100%,540px);margin:0 auto}
  .ab1{width:62%;height:70%}
  .ab2{width:50%;height:54%;right:0;bottom:0}
  .ab3{width:30%;height:28%;top:1%;right:3%}
  .ab4{width:32%;height:30%;bottom:0;left:16%}
  .ab-badge{top:45%;left:57%;width:96px;height:96px}
  .ab-badge-n{font-size:29px}
  #exp>.rR{width:min(820px,100%)}
  .socials-shell{grid-template-columns:1fr;gap:18px}
  .socials-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  #testi{padding:52px 0 56px}
  .tours-content{min-height:84vh;padding:48px 0 32px}
  .tours-head,#testi .testi-head{padding:0 40px}
  .tours-outer{padding:0 40px 4px}
  .t-card{flex:0 0 340px;height:336px}
  .t-card:hover{flex:0 0 370px}
  .t-name{font-size:18px}
  .t-price{font-size:21px}
  .tours-incl{margin-top:18px;padding:14px 40px 24px}
  .tours-stage-word{font-size:28vw}
  #process{padding:0}
  .process-content{min-height:76vh;padding:52px 40px 68px}
  .process-grid{grid-template-columns:1fr}
  .p-step:first-child,.p-step:last-child{border-radius:28px}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .ctaband-btns{flex-direction:column}
  #booking{padding:20px}
  .booking-shell{width:min(980px,100%);height:min(860px,calc(100vh - 40px));height:min(860px,calc(100svh - 40px));height:min(860px,calc(100dvh - 40px));grid-template-columns:minmax(210px,240px) minmax(0,1fr);max-height:calc(100vh - 40px);max-height:calc(100svh - 40px);max-height:calc(100dvh - 40px)}
  .booking-side{padding:16px}
  .booking-story{padding:22px 20px}
  .booking-story-title,.booking-story-copy{max-width:none}
  .booking-form-scroll{padding:22px}
  .booking-form-card{max-width:520px;padding:22px}
  .booking-close{top:14px;right:14px;background:rgba(5,22,35,.22)}
  #nav{padding:18px 24px}
  .nav-pill{padding:7px 12px 7px 22px;max-width:980px}
  .nav-logo-pill img{width:72px;height:72px}
  .nav-logo-pill-text{font-size:22px}
  .nav-logo-pill-text span{font-size:10px}
  .nav-links-pill a{font-size:12px;padding:9px 16px}
  .nav-cta-pill{padding:12px 22px !important}
  .hero-curve-marquee{height:94px}
  footer{padding:70px 40px 30px}
}
@media(max-width:860px){
  body.nav-open{overflow:hidden}
  #nav{padding:12px 10px;align-items:flex-start;justify-content:center}
  .nav-pill{
    width:min(430px,calc(100% - 20px));
    max-width:none;
    padding:6px 56px 6px 12px;
    border-radius:24px;
    box-shadow:0 20px 54px rgba(5,22,35,.16),0 1px 0 rgba(255,255,255,.28) inset;
  }
  .nav-top-row{display:grid;grid-template-columns:minmax(0,1fr) auto;width:100%;min-width:0;align-items:center;gap:8px}
  .nav-logo-pill{gap:8px;min-width:0;max-width:100%;width:100%;transform:none;margin-right:0}
  .nav-logo-pill img{width:56px;height:56px}
  .nav-logo-pill-text{min-width:0;font-size:20px;line-height:.82;white-space:normal;overflow:hidden}
  .nav-logo-pill-text span{font-size:7px;letter-spacing:.14em;white-space:normal;overflow:hidden}
  .nav-burger{display:flex !important;position:absolute;top:50%;right:10px;z-index:3;transform:translateY(-50%);width:46px;height:38px;padding:0 11px;gap:3px;border-radius:14px;background:rgba(255,255,255,.86);border-color:rgba(14,58,82,.16);box-shadow:0 10px 22px rgba(5,22,35,.1)}
  .nav-burger:hover{transform:translateY(calc(-50% - 1px))}
  .nav-burger span{width:18px}
  .nav-burger span:nth-child(2){width:13px}
  .nav-links-pill{
    position:absolute;
    top:calc(100% + 10px);
    left:0;
    width:100%;
    margin-left:0;
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    padding:12px;
    border-radius:22px;
    background:rgba(6,31,44,.9);
    border:1px solid rgba(255,255,255,.12);
    backdrop-filter:blur(24px) saturate(180%);
    -webkit-backdrop-filter:blur(24px) saturate(180%);
    box-shadow:0 24px 60px rgba(0,0,0,.24);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .25s,transform .25s,visibility .25s;
  }
  #nav.scrolled .nav-links-pill{background:rgba(253,250,244,.97);border-color:rgba(14,58,82,.08)}
  #nav.nav-open .nav-links-pill{opacity:1;visibility:visible;pointer-events:auto;transform:none}
  .nav-links-pill a{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    min-height:50px;
    padding:0 16px;
    font-size:10px;
    letter-spacing:.17em;
    text-align:left;
    border-radius:18px;
    background:rgba(255,255,255,.06);
  }
  #nav.scrolled .nav-links-pill a{background:rgba(14,58,82,.04)}
  .nav-cta-pill{min-height:52px;padding:0 18px !important;justify-content:center}
  #hero{min-height:clamp(460px,100svh,620px)}
  #hero::before{content:'';display:block;position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,18,26,.12) 0%,rgba(4,18,26,.08) 30%,rgba(4,18,26,.48) 70%,rgba(4,18,26,.82) 100%);z-index:1}
  #hero::after{height:68px}
  .hero-curve-marquee{bottom:3px;height:82px}
  #about{gap:24px}
  .about-visual{height:440px;width:min(100%,440px);margin:0 auto}
  .socials-shell{padding:24px 22px;border-radius:28px}
  .tours-head{flex-direction:column;align-items:flex-start;gap:14px}
  .view-all-link{align-self:flex-start}
  .about-pillars{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-desc{max-width:none}
  .footer-bot{flex-direction:column;align-items:flex-start;gap:10px}
}
@media(max-width:720px){
  .ribbon-track{animation-duration:24s}
  .testi-track{animation-duration:34s}
  #booking{padding:12px}
  .travel-chat{padding:12px}
  #about,#exp,#ctaband{padding:24px 20px}
  #socials{padding:18px 20px 16px}
  #about{padding-bottom:16px}
  .about-visual{height:390px;width:min(100%,400px)}
  .ab1{width:70%;height:68%}
  .ab2{width:53%;height:46%;right:0}
  .ab3{width:34%;height:27%;top:0;right:1%}
  .ab4{width:30%;height:29%;bottom:1%;left:10%}
  .ab-badge{width:84px;height:84px;top:47%;left:52%}
  .ab-badge-n{font-size:24px}
  .ab-badge-s{font-size:8px}
  .about-primary-caption{font-size:18px;bottom:16px;left:16px}
  #exp>.rR{width:100%}
  .exp-mosaic{grid-template-columns:1fr;grid-template-rows:none;gap:10px}
  .em,.em:nth-child(1),.em:nth-child(2),.em:nth-child(3),.em:nth-child(4){grid-column:auto;grid-row:auto;min-height:180px}
  .exp-features{margin-top:32px}
  .exp-feat{gap:16px;padding-bottom:22px;margin-bottom:22px}
  #testi{padding:40px 0 48px;background-attachment:scroll}
  #process{padding:0}
  .process-pin{height:92vh;height:92dvh;height:92svh;margin-bottom:-92vh;margin-bottom:-92dvh;margin-bottom:-92svh}
  .process-content{min-height:auto;padding:48px 20px 52px}
  .process-content::before{font-size:38vw}
  .process-grid{margin-top:28px;gap:12px}
  .p-step,.p-step:hover{padding:30px 20px;transform:none;border-radius:24px}
  .p-step:first-child,.p-step:last-child{border-radius:24px}
  .p-num{width:66px;height:66px;font-size:28px;margin-bottom:18px}
  .p-title{font-size:20px}
  .tours-content{min-height:auto;padding:34px 0 24px}
  .tours-head,#testi .testi-head{padding:0 20px}
  .tours-head{margin-bottom:18px}
  .tours-outer{padding:0 20px 6px;scroll-snap-type:x mandatory;scroll-padding-left:20px}
  .tours-strip{gap:12px;padding-right:20px}
  .t-card,.t-card:hover{flex:0 0 min(84vw,304px);height:300px;border-radius:22px}
  .t-body{padding:18px 18px 18px}
  .t-name{font-size:18px;max-width:12ch}
  .t-meta{gap:8px}
  .t-price{font-size:21px}
  .t-num{font-size:52px;top:14px;right:16px}
  .tours-incl{margin-top:14px;padding:12px 24px 18px}
  .incl-strip{gap:14px;padding:12px 16px;border-radius:24px;display:flex;overflow:auto;white-space:nowrap;flex-wrap:nowrap;justify-content:flex-start;width:100%;scrollbar-width:none}
  .incl-strip::-webkit-scrollbar{display:none}
  .incl-item{font-size:10px;flex:0 0 auto}
  #hero{min-height:clamp(440px,100svh,600px)}
  #hero::after{height:54px}
  .socials-shell{padding:20px 18px;border-radius:24px;gap:16px}
  .socials-title{font-size:26px;margin-bottom:8px}
  .socials-text{font-size:13px;line-height:1.7}
  .socials-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .social-card{min-height:132px;padding:15px 14px;border-radius:18px}
  .social-card strong{font-size:12px}
  .social-card small{font-size:11px;line-height:1.55}
  .social-mark{width:38px;height:38px;border-radius:14px}
  .social-mark svg{width:18px;height:18px}
  .hero-curve-marquee{bottom:2px;height:66px}
  .tours-stage-word{font-size:34vw}
  .travel-chat-shell{width:min(100%,420px);max-height:calc(100vh - 24px);max-height:calc(100svh - 24px);max-height:calc(100dvh - 24px);border-radius:24px}
  .travel-chat-aside{padding:18px 16px 14px;gap:10px}
  .travel-chat-aside h3{font-size:22px}
  .travel-chat-panel{padding:14px 14px 16px}
  .travel-chat-compose{grid-template-columns:1fr}
  .travel-chat-send{width:100%;min-width:0;min-height:52px}
  .travel-chat-bubble{padding:14px 16px;font-size:13px;line-height:1.7}
  .travel-chat-mini{width:100%}
  .fc,.travel-chat-compose textarea,.asset-holder-input{font-size:16px}
  .booking-shell{grid-template-columns:1fr;height:calc(100vh - 24px);height:calc(100svh - 24px);height:calc(100dvh - 24px);max-height:calc(100vh - 24px);max-height:calc(100svh - 24px);max-height:calc(100dvh - 24px);border-radius:26px}
  .booking-side{align-items:stretch;padding:16px 16px 0}
  .booking-story{padding:20px;overflow:visible}
  .booking-nori-pop{padding:16px}
  .booking-nori-pop h4{font-size:24px;max-width:none}
  .booking-form-scroll{padding:18px}
  .booking-form-card{max-width:none}
  .booking-form-head{flex-direction:column}
  .booking-badge{min-width:0;max-width:220px}
  .frow{grid-template-columns:1fr}
  .booking-story-grid{gap:10px}
  .booking-close{width:42px;height:42px;font-size:24px}
  .testi-head{margin-bottom:28px}
  .testi-track{gap:16px}
  .tc{flex:0 0 84vw;padding:24px 20px;border-radius:20px}
  .tc-q{font-size:46px}
  .tc-text{font-size:13px;line-height:1.75;margin-bottom:22px}
  #ctaband{flex-direction:column;align-items:flex-start;gap:24px}
  .ctaband-title{font-size:clamp(28px,10vw,40px)}
  .ctaband-sub{font-size:14px;line-height:1.7;margin-top:10px}
  .ctaband-btns{width:100%;gap:12px}
  .ctaband-btns .btn-gold,.ctaband-btns .btn-ocean{width:100%;justify-content:center}
  footer{padding:48px 20px 22px}
  .footer-top{gap:24px;padding-bottom:28px}
  .footer-brand-name{font-size:18px}
  .footer-desc{font-size:12px;line-height:1.7;margin-bottom:20px}
  .fl-wa{left:16px;bottom:16px;padding:10px 14px;font-size:10px;border-radius:18px;gap:8px}
  .fl-book{right:12px;bottom:12px;width:92px;height:118px}
  .fl-book-beacon{width:88px;height:112px}
  .fl-book-rotor{top:28px}
  .fl-book-aura{width:54px;height:54px;top:28px}
  .fl-book-icon{width:52px;height:100px}
  .fl-book-brace{height:54px;bottom:8px}
}
@media(max-width:560px){
  .ribbon-track{animation-duration:18s}
  .testi-track{animation-duration:28s}
  .ribbon{padding:12px 0}
  .ribbon-item{padding:0 22px;font-size:10px;letter-spacing:.14em}
  #nav{padding:8px 8px}
  .nav-pill{width:calc(100% - 16px);max-width:none;padding:4px 48px 4px 8px;border-radius:18px}
  .nav-top-row{gap:4px}
  .nav-logo-pill{gap:7px;max-width:100%;width:100%;transform:none;transform-origin:left center;margin-right:0}
  .nav-logo-pill img{width:48px;height:48px}
  .nav-logo-pill-text{font-size:16px;line-height:.8}
  .nav-logo-pill-text span{font-size:6px;letter-spacing:.12em}
  .nav-burger{right:6px;width:42px;height:34px;border-radius:12px;padding:0 10px;gap:3px;background:rgba(255,255,255,.92)}
  .nav-burger:hover{transform:translateY(calc(-50% - 1px))}
  .nav-burger span{width:18px}
  .nav-burger span:nth-child(2){width:13px}
  .nav-links-pill{top:calc(100% + 8px);padding:10px;gap:8px;border-radius:18px}
  .nav-links-pill a{min-height:42px;padding:0 14px;font-size:9px;border-radius:14px}
  #hero{min-height:clamp(420px,100svh,540px)}
  #hero::after{height:46px}
  .hero-curve-marquee{height:56px}
  .pre-logo{font-size:40px}
  .pre-prog{width:180px;margin-top:32px}
  #about,#exp,#ctaband,.process-content{padding-left:18px;padding-right:18px}
  #socials{padding-left:18px;padding-right:18px}
  .about-visual{height:320px;width:min(100%,360px)}
  .ab3{width:34%;height:26%;top:2%;right:1%}
  .ab4{width:32%;height:26%;bottom:0;left:11%}
  .ab-badge{width:78px;height:78px}
  .ab-badge-n{font-size:22px}
  .about-primary-caption{font-size:17px}
  .about-pillars{margin-top:24px}
  .pillar{padding:16px;border-radius:18px}
  .pillar-icon{font-size:24px}
  .pillar-t{font-size:12px}
  .pillar-b{font-size:11px}
  .tours-head,#testi .testi-head,.tours-outer,.tours-incl{padding-left:16px;padding-right:16px}
  .tours-outer{scroll-padding-left:16px}
  .tours-strip{gap:10px;padding-right:16px}
  .t-card,.t-card:hover{flex:0 0 min(86vw,286px);height:290px}
  .t-body{padding:16px 16px 18px}
  .t-tag{font-size:7px;padding:5px 11px}
  .t-name{font-size:16px}
  .t-price{font-size:18px}
  .t-meta span,.t-price small{font-size:9px}
  .incl-strip{padding:12px 14px}
  .socials-shell{padding:18px 16px;border-radius:22px}
  .socials-grid{grid-template-columns:1fr}
  .social-card{min-height:0;padding:14px;border-radius:16px}
  .exp-mosaic{gap:8px}
  .em,.em:nth-child(1),.em:nth-child(2),.em:nth-child(3),.em:nth-child(4){min-height:164px}
  .exp-feat-num{font-size:36px;min-width:50px}
  .process-content{padding:44px 18px 48px}
  .p-step,.p-step:hover{padding:26px 18px}
  .p-title{font-size:18px}
  .booking-shell{height:calc(100vh - 16px);height:calc(100svh - 16px);height:calc(100dvh - 16px);max-height:calc(100vh - 16px);max-height:calc(100svh - 16px);max-height:calc(100dvh - 16px);border-radius:22px}
  .booking-side{padding:14px 14px 0}
  .booking-story{padding:18px}
  .booking-form-scroll{padding:16px}
  .booking-form-card{padding:18px}
  .booking-nori-pop{padding:15px}
  .booking-nori-btn{min-height:46px}
  .form-title{font-size:28px}
  .fc{padding:13px 14px}
  .btn-submit{min-height:54px}
  #testi{padding:36px 0 44px}
  .testi-head{margin-bottom:24px}
  .tc{flex:0 0 88vw;padding:22px 18px}
  .tc-q{font-size:40px;margin-bottom:10px}
  .tc-stars{font-size:12px;letter-spacing:2px}
  .tc-auth{gap:10px}
  .tc-av{width:42px;height:42px;font-size:16px}
  .ctaband-btns{gap:10px}
  .ctaband-btns .btn-gold,.ctaband-btns .btn-ocean{padding:14px 20px;font-size:11px}
  footer{padding:44px 18px 20px}
  .fl-wa{left:14px;bottom:14px;padding:10px 14px;font-size:10px}
  .fl-book{right:10px;bottom:10px;width:78px;height:102px}
  .fl-book-beacon{width:74px;height:96px}
  .fl-book-rotor{top:24px}
  .fl-book-aura{width:46px;height:46px;top:24px}
  .fl-book-icon{width:42px;height:84px}
  .fl-book-brace{height:48px;bottom:7px;width:4px}
}
@media(max-width:420px){
  .nav-pill{padding:4px 6px 4px 7px}
  .nav-logo-pill img{width:44px;height:44px}
  .nav-logo-pill-text{font-size:14px}
  .nav-logo-pill-text span{font-size:5px;letter-spacing:.1em}
  .nav-burger{right:5px;width:38px;height:32px;padding:0 9px;background:rgba(255,255,255,.95)}
  .nav-burger:hover{transform:translateY(calc(-50% - 1px))}
  .nav-burger span{width:16px}
  .nav-burger span:nth-child(2){width:11px}
  #hero{min-height:clamp(400px,100svh,500px)}
  #about,#exp,#ctaband,.process-content{padding-left:14px;padding-right:14px}
  #socials{padding-left:14px;padding-right:14px}
  .about-visual{height:300px}
  .socials-shell{padding:16px 14px}
  .tours-head,#testi .testi-head,.tours-outer,.tours-incl{padding-left:14px;padding-right:14px}
  .tours-outer{scroll-padding-left:14px}
  .tours-strip{padding-right:14px}
  #booking{padding:8px}
  .booking-side{padding:12px 12px 0}
  .booking-form-scroll{padding:12px}
  .booking-form-card{padding:16px}
  .booking-form-strip span{width:100%;justify-content:center}
  .booking-nori-pop h4{font-size:22px}
  .booking-nori-btn{font-size:9px;letter-spacing:.14em}
  .travel-chat-shell{width:min(100%,380px);border-radius:22px}
  .travel-chat-aside{padding:16px 14px 12px}
  .travel-chat-panel{padding:12px 12px 14px}
  .t-card,.t-card:hover{flex:0 0 min(88vw,272px);height:280px}
  .fl-book{right:8px;bottom:8px;width:72px;height:94px}
  .fl-book-beacon{width:68px;height:88px}
  .fl-book-rotor{top:22px}
  .fl-book-aura{width:42px;height:42px;top:22px}
  .fl-book-icon{width:38px;height:78px}
}
