/* ============ Twin Travel Craft — mockup ============ */
:root{
  --aqua:#2fb4e0;
  --aqua-dark:#1c8ec2;
  --navy:#123a52;
  --navy-deep:#0c2739;
  --gold:#e8a317;
  --gold-soft:#f2c14e;
  --brown:#5a3a22;
  --cream:#fbf6ea;
  --cream-2:#f4ecd9;
  --ink:#1f2a30;
  --muted:#5f6f77;
  --white:#ffffff;
  --radius:20px;
  --shadow:0 18px 50px -20px rgba(18,58,82,.35);
  --shadow-sm:0 8px 24px -12px rgba(18,58,82,.3);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Plus Jakarta Sans",system-ui,sans-serif;
  --wrap:1160px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(var(--wrap),92%);margin-inline:auto}
em{font-style:italic}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.95rem;
  padding:.85rem 1.6rem;border-radius:999px;border:0;cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  white-space:nowrap;
}
.btn--gold{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:#3a2508;box-shadow:0 10px 24px -10px rgba(232,163,23,.75)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(232,163,23,.85)}
.btn--ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.6)}
.btn--ghost:hover{background:rgba(255,255,255,.14)}
.btn--sm{padding:.55rem 1.1rem;font-size:.85rem;background:var(--navy);color:#fff}
.btn--sm:hover{background:var(--navy-deep)}
.btn--block{width:100%}

/* ---------- Section helpers ---------- */
.section-eyebrow{
  display:inline-block;font-weight:600;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--aqua-dark);margin-bottom:1rem;
}
.section-eyebrow--light{color:var(--gold-soft)}
.eyebrow{
  display:inline-block;font-weight:600;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.2rem;
  padding:.35rem .9rem;border:1px solid rgba(255,255,255,.35);border-radius:999px;
}
.section-title{
  font-family:var(--serif);font-weight:600;line-height:1.08;
  font-size:clamp(2rem,4.4vw,3.1rem);color:var(--navy);letter-spacing:-.01em;
}
.section-title em{color:var(--aqua-dark)}
.section-sub{margin-top:1rem;color:var(--muted);max-width:52ch;font-size:1.05rem}
.section-head{text-align:center;max-width:720px;margin:0 auto 3.2rem}
.section-head .section-sub{margin-inline:auto}
.section-head--light .section-title,.section-head--light .section-sub{color:#eaf6fb}

/* ---------- Nav ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;transition:background .3s,box-shadow .3s,padding .3s;padding:.6rem 0}
.nav__inner{display:flex;align-items:center;justify-content:space-between}
.nav.scrolled{background:rgba(251,246,234,.92);backdrop-filter:blur(12px);box-shadow:0 6px 20px -12px rgba(0,0,0,.3)}
.brand{display:flex;align-items:center;gap:.65rem}
.brand__logo{width:46px;height:46px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25))}
.brand__name{font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--white)}
.nav.scrolled .brand__name{color:var(--navy)}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{font-weight:500;font-size:.95rem;color:rgba(255,255,255,.9)}
.nav.scrolled .nav__links a{color:var(--navy)}
.nav__links a:hover{color:var(--gold-soft)}
.nav.scrolled .nav__links a:hover{color:var(--aqua-dark)}
.nav__cta{background:var(--gold);color:#3a2508!important;padding:.55rem 1.2rem;border-radius:999px;font-weight:600}
.nav__cta:hover{background:var(--gold-soft)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__toggle span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:.3s}
.nav.scrolled .nav__toggle span{background:var(--navy)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden;padding:7rem 0 4rem}
.hero__bg{position:absolute;inset:0;z-index:-2;
  background:
   radial-gradient(1100px 600px at 80% -10%,rgba(47,180,224,.55),transparent 60%),
   radial-gradient(900px 700px at 0% 110%,rgba(232,163,23,.28),transparent 55%),
   linear-gradient(155deg,var(--navy-deep),var(--navy) 55%,#0f4763);
}
.hero__bg::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.12) 1px,transparent 1px);
  background-size:26px 26px;mask-image:linear-gradient(#000,transparent 70%);opacity:.5}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(2.5rem,5.6vw,4.3rem);line-height:1.04;letter-spacing:-.015em}
.hero__title em{color:var(--gold-soft)}
.hero__lead{margin:1.6rem 0 2.2rem;font-size:1.15rem;color:rgba(255,255,255,.85);max-width:46ch}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{list-style:none;display:flex;gap:2.4rem;margin-top:2.8rem;flex-wrap:wrap}
.hero__stats strong{display:block;font-family:var(--serif);font-size:1.3rem;color:#fff}
.hero__stats span{font-size:.82rem;color:rgba(255,255,255,.65)}
.hero__badge{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem}
.hero__logo-glow{position:relative;width:min(340px,72vw);aspect-ratio:1;display:grid;place-items:center}
.hero__logo-glow::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle,rgba(47,180,224,.5),transparent 65%);filter:blur(18px);animation:pulse 5s ease-in-out infinite}
.hero__logo-glow img{position:relative;width:100%;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4));animation:float 6s ease-in-out infinite}
.hero__tag{font-family:var(--serif);font-style:italic;font-size:1.02rem;color:rgba(255,255,255,.9);max-width:32ch}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:1.4rem;animation:bob 2s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes pulse{0%,100%{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- Intro ---------- */
.intro{padding:6rem 0}
.intro__grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.intro__copy p{color:var(--muted);margin-top:1.1rem;font-size:1.05rem}
.intro__copy .section-title{margin-top:.4rem}
.intro__pills{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
.intro__pills span{background:var(--white);border:1px solid var(--cream-2);border-radius:999px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;box-shadow:var(--shadow-sm)}
.intro__media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.intro__media video{width:100%;height:100%;max-height:520px;object-fit:cover;display:block;background:var(--navy)}
.intro__media figcaption{position:absolute;left:0;right:0;bottom:0;padding:2.4rem 1.4rem 1.2rem;
  background:linear-gradient(transparent,rgba(12,39,57,.85));color:#fff;font-size:.95rem;font-style:italic}

/* ---------- Experiences ---------- */
.exp{padding:5rem 0 6rem;background:linear-gradient(var(--cream),var(--cream-2))}
.exp__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card__media{aspect-ratio:3/4;overflow:hidden;background:var(--cream-2)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:1.5rem 1.4rem 1.4rem;display:flex;flex-direction:column;flex:1}
.card__body h3{font-family:var(--serif);font-size:1.3rem;line-height:1.18;color:var(--navy);margin:.7rem 0 .5rem}
.card__body>p{color:var(--muted);font-size:.95rem}
.tag{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.35rem .75rem;border-radius:999px;color:#fff}
.tag--purple{background:#7a5bd6}.tag--navy{background:var(--navy)}.tag--teal{background:#159b8f}
.tag--green{background:#5c7d3a}.tag--gold{background:var(--gold);color:#3a2508}
.card__list{list-style:none;margin:1rem 0 1.3rem;display:grid;gap:.45rem}
.card__list li{position:relative;padding-left:1.4rem;font-size:.9rem;color:var(--ink)}
.card__list li::before{content:"✓";position:absolute;left:0;color:var(--aqua-dark);font-weight:700}
.card__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.8rem;
  padding-top:1rem;border-top:1px solid var(--cream-2)}
.price{font-family:var(--serif);font-weight:600;color:var(--navy);font-size:1.15rem;line-height:1.2}
.price small{font-family:var(--sans);font-weight:500;color:var(--muted);font-size:.72rem}
.card--cta{background:linear-gradient(150deg,var(--navy),var(--navy-deep));color:#fff;justify-content:center}
.card__cta-body{padding:2.5rem 1.8rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}
.card__cta-body h3{font-family:var(--serif);font-size:1.55rem;line-height:1.15}
.card__cta-body p{color:rgba(255,255,255,.8);font-size:.98rem}

/* ---------- Support ---------- */
.support{padding:6rem 0;background:
  radial-gradient(900px 500px at 100% 0%,rgba(47,180,224,.4),transparent 55%),
  linear-gradient(160deg,var(--navy),var(--navy-deep));color:#fff}
.support__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.feature{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  padding:1.8rem 1.6rem;transition:transform .3s,background .3s}
.feature:hover{transform:translateY(-5px);background:rgba(255,255,255,.1)}
.feature__ico{font-size:1.9rem;display:block;margin-bottom:.8rem}
.feature h4{font-family:var(--serif);font-weight:600;font-size:1.18rem;margin-bottom:.5rem}
.feature p{color:rgba(255,255,255,.75);font-size:.95rem}

/* ---------- Gallery ---------- */
.gallery{padding:6rem 0}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.shot{border:0;padding:0;background:none;cursor:pointer;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s,box-shadow .3s}
.shot img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .6s}
.shot:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.shot:hover img{transform:scale(1.06)}

/* ---------- Team ---------- */
.team{padding:2rem 0 6rem}
.team__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.8rem;max-width:860px;margin-inline:auto}
.member{background:var(--white);border-radius:var(--radius);padding:2rem 1.8rem;box-shadow:var(--shadow-sm);
  border-top:5px solid var(--gold);transition:transform .3s,box-shadow .3s}
.member:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.member__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}
.member__cn{font-family:var(--serif);font-size:1.6rem;color:var(--aqua-dark)}
.member__seat{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--muted);border:1px dashed var(--cream-2);
  padding:.25rem .6rem;border-radius:8px}
.member h3{font-family:var(--serif);font-size:1.5rem;color:var(--navy)}
.member__role{color:var(--gold);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}
.member__contact{list-style:none;display:grid;gap:.55rem}
.member__contact li{font-size:.92rem;color:var(--muted)}

/* ---------- Contact ---------- */
.contact{padding:6rem 0;background:
  radial-gradient(700px 400px at 0% 100%,rgba(232,163,23,.25),transparent 60%),
  linear-gradient(150deg,var(--navy-deep),var(--navy));color:#fff}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.contact__copy p{color:rgba(255,255,255,.82);margin:1rem 0 1.8rem;max-width:44ch}
.contact__list{list-style:none;display:grid;gap:1.1rem}
.contact__list li{display:flex;flex-direction:column;gap:.15rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.12)}
.contact__list span{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft)}
.contact__list a{font-size:1.05rem;font-weight:500}
.contact__list a:hover{color:var(--gold-soft)}
.contact__form{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:2rem;display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.85rem;font-weight:500;color:rgba(255,255,255,.85)}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:.95rem;padding:.8rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.95);color:var(--ink);resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--gold-soft)}
.form__note{background:rgba(232,163,23,.2);border:1px solid var(--gold-soft);border-radius:12px;padding:.8rem 1rem;font-size:.9rem}

/* ---------- Footer ---------- */
.footer{background:#081d2b;color:rgba(255,255,255,.75);padding:3rem 0 2.2rem;text-align:center}
.footer__inner{display:flex;flex-direction:column;align-items:center;gap:1rem}
.footer__brand{display:flex;align-items:center;gap:.8rem}
.footer__brand img{width:48px;height:48px;object-fit:contain}
.footer__brand strong{display:block;font-family:var(--serif);font-size:1.2rem;color:#fff}
.footer__brand span{font-size:.82rem}
.footer__tag{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:1.05rem}
.footer__copy{font-size:.82rem;color:rgba(255,255,255,.5)}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,29,43,.92);display:grid;place-items:center;padding:2rem;backdrop-filter:blur(6px)}
.lightbox[hidden]{display:none}
.lightbox img{max-width:min(560px,92vw);max-height:90vh;border-radius:14px;box-shadow:0 30px 80px -20px #000}
.lightbox__close{position:absolute;top:1.2rem;right:1.6rem;font-size:2.4rem;color:#fff;background:none;border:0;cursor:pointer;line-height:1}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .hero__inner,.intro__grid,.contact__grid{grid-template-columns:1fr;gap:2.4rem}
  .hero__badge{order:-1}
  .hero__logo-glow{width:min(240px,60vw)}
  .exp__grid,.support__grid,.gallery__grid{grid-template-columns:repeat(2,1fr)}
  .team__grid{grid-template-columns:1fr}
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(300px,80vw);background:var(--navy-deep);
    flex-direction:column;justify-content:center;gap:1.8rem;transform:translateX(100%);transition:transform .35s;padding:2rem}
  .nav__links.open{transform:none}
  .nav__links a{color:#fff!important;font-size:1.1rem}
  .nav__toggle{display:flex}
  .nav.scrolled .nav__toggle span{background:var(--navy)}
}
@media(max-width:600px){
  .exp__grid,.support__grid,.gallery__grid{grid-template-columns:1fr}
  .hero{padding-top:6rem}
  .hero__stats{gap:1.4rem}
  .intro,.exp,.support,.gallery,.contact{padding:4rem 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
}
