/* ============================================================
   Exclusive Trips Switzerland — core styles
   Palette: white + Swiss gold
   ============================================================ */
:root{
  --gold:#c8a45d;
  --gold-light:#e3ce96;
  --gold-dark:#a4823b;
  --ink:#1c1d22;
  --ink-soft:#54565e;
  --paper:#fdfcfa;
  --paper-2:#f6f2ea;
  --line:#e9e3d6;
  --shadow:0 24px 60px -28px rgba(40,34,18,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.06;letter-spacing:.2px}
h2{font-size:clamp(2.1rem,4.6vw,3.6rem)}
em{font-style:italic;color:var(--gold-dark)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(72px,11vw,150px) 0}

/* eyebrow / labels */
.eyebrow{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-dark);font-weight:600;margin-bottom:18px}
.eyebrow-light{color:var(--gold-light)}
.section-head{text-align:center;max-width:680px;margin:0 auto clamp(40px,6vw,72px)}
.section-sub{margin-top:16px;color:var(--ink-soft)}

/* buttons */
.btn{display:inline-block;padding:15px 34px;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;border-radius:2px;transition:all .4s var(--ease);cursor:pointer;border:1px solid transparent}
.btn-gold{background:linear-gradient(120deg,var(--gold-dark),var(--gold) 55%,var(--gold-light));color:#1c1605;box-shadow:0 14px 30px -14px rgba(168,130,59,.8)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 20px 38px -14px rgba(168,130,59,.95)}
.btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-block{width:100%;text-align:center}
.link-gold{color:var(--gold-dark);font-weight:600;letter-spacing:.04em;border-bottom:1px solid var(--gold-light);padding-bottom:2px;transition:.3s}
.link-gold:hover{color:var(--gold)}

/* ===== Loader ===== */
.loader{position:fixed;inset:0;background:var(--paper);z-index:2000;display:grid;place-items:center;transition:opacity .8s ease,visibility .8s}
.loader.done{opacity:0;visibility:hidden}
.loader-mark{text-align:center}
.loader-logo{width:96px;height:96px;object-fit:contain;margin:0 auto 18px;display:block;animation:loaderpulse 1.8s ease-in-out infinite}
@keyframes loaderpulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.06);opacity:1}}
.loader-sub{font-size:.62rem;letter-spacing:.4em;color:var(--ink-soft)}

/* ===== Navigation ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .5s,box-shadow .5s,padding .4s}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:22px 28px;display:flex;align-items:center;justify-content:space-between}
.nav.scrolled{background:rgba(253,252,250,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav.scrolled .nav-inner{padding:14px 28px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;transition:color .5s}
.nav.scrolled .brand{color:var(--ink)}
.brand-mark{display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--gold);color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:1.25rem;letter-spacing:.05em}
.brand-logo{width:46px;height:46px;object-fit:contain;display:block}
.brand-text{font-family:'Cormorant Garamond',serif;font-size:1.4rem;line-height:1;display:flex;flex-direction:column}
.brand-text small{font-family:'Jost';font-size:.52rem;letter-spacing:.34em;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:400;transition:color .3s;position:relative}
.nav.scrolled .nav-links a{color:var(--ink)}
.nav-links a:not(.nav-login)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-links a:not(.nav-login):hover::after{width:100%}
.nav-login{padding:9px 20px;border:1px solid var(--gold)!important;color:var(--gold)!important;border-radius:2px}
.nav-login:hover{background:var(--gold);color:#1c1605!important}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-burger span{width:26px;height:2px;background:#fff;transition:.3s}
.nav.scrolled .nav-burger span{background:var(--ink)}

/* ===== Hero ===== */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden;background:#11131a}
.hero-bg{position:absolute;inset:0;background-image:url('/assets/hero-matterhorn.jpg');background-size:cover;background-position:center;z-index:0;
  transform:scale(1.08);animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
/* scrim: dark on the left for text legibility, lighter on the right to show the peak */
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(12,14,20,.78) 0%,rgba(12,14,20,.5) 38%,rgba(12,14,20,.12) 70%,rgba(12,14,20,0) 100%),
    linear-gradient(180deg,rgba(12,14,20,.45) 0%,rgba(12,14,20,0) 28%,rgba(12,14,20,0) 70%,rgba(12,14,20,.55) 100%)}

.hero-content{position:relative;z-index:5;max-width:var(--maxw);margin:0 auto;padding:0 28px;width:100%}
.hero-eyebrow{color:var(--gold-light);font-size:.75rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;margin-bottom:22px}
.hero-title{font-size:clamp(3rem,8vw,6.4rem);color:#fff;text-shadow:0 4px 40px rgba(0,0,0,.5)}
.hero-title em{color:var(--gold-light)}
.hero-lead{max-width:520px;margin:26px 0 38px;font-size:1.08rem;color:rgba(255,255,255,.85);text-shadow:0 2px 18px rgba(0,0,0,.5)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:5;width:26px;height:42px;border:1px solid var(--gold-light);border-radius:14px;display:grid;justify-items:center;padding-top:8px}
.hero-scroll span{width:3px;height:8px;background:var(--gold-light);border-radius:2px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{opacity:0}}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ===== Intro ===== */
.intro{padding:clamp(72px,10vw,130px) 0;background:var(--paper)}
.intro-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.intro-text h2{margin:6px 0 22px}
.intro-text p{color:var(--ink-soft);max-width:480px;margin-bottom:26px}
.intro-stats{display:grid;grid-template-columns:1fr 1fr;gap:30px 24px}
.stat{padding:26px 24px;background:var(--paper-2);border:1px solid var(--line);border-radius:4px}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:2.8rem;color:var(--gold-dark);line-height:1}
.stat-suffix{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--gold)}
.stat-label{display:block;margin-top:8px;font-size:.78rem;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase}

/* ===== Experiences ===== */
.experiences{background:linear-gradient(180deg,var(--paper),var(--paper-2))}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.exp-card{position:relative;border-radius:6px;overflow:hidden;background:#fff;box-shadow:var(--shadow);transition:transform .55s var(--ease)}
.exp-card:hover{transform:translateY(-8px)}
.exp-media{height:260px;background-image:var(--img);background-size:cover;background-position:center;transition:transform 1s var(--ease)}
.exp-media::after{content:"";position:absolute;inset:0 0 auto;height:260px;background:linear-gradient(180deg,transparent 40%,rgba(20,18,10,.45))}
.exp-card:hover .exp-media{transform:scale(1.08)}
.exp-body{padding:26px 26px 30px}
.exp-tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-dark);font-weight:600}
.exp-body h3{font-size:1.55rem;margin:10px 0 10px}
.exp-body p{color:var(--ink-soft);font-size:.95rem}

/* ===== Events ===== */
.events{background:var(--ink);color:#fff}
.events .eyebrow{color:var(--gold)}
.events h2{color:#fff}
.events .section-sub{color:rgba(255,255,255,.62)}
.event-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.event{display:flex;gap:18px;align-items:center;padding:28px 24px;border:1px solid rgba(255,255,255,.12);border-radius:5px;transition:.45s var(--ease);background:rgba(255,255,255,.02)}
.event:hover{border-color:var(--gold);background:rgba(200,164,93,.08);transform:translateY(-6px)}
.event-month{font-family:'Cormorant Garamond',serif;font-size:1.6rem;color:var(--gold);min-width:48px}
.event h3{font-size:1.3rem;color:#fff}
.event p{font-size:.85rem;color:rgba(255,255,255,.6)}

/* ===== Destinations ===== */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:18px}
.dest{position:relative;border-radius:6px;overflow:hidden;background-image:var(--img);background-size:cover;background-position:center;cursor:pointer;box-shadow:var(--shadow)}
.dest::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.55));transition:.5s}
.dest::after{content:"";position:absolute;inset:0;background-size:cover;background-position:center;background-image:inherit;transform:scale(1);transition:transform 1.1s var(--ease);z-index:-1}
.dest:hover{filter:none}
.dest:hover::before{background:linear-gradient(180deg,rgba(168,130,59,.15),rgba(0,0,0,.65))}
.dest span{position:absolute;left:22px;bottom:20px;color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.7rem;z-index:2;transition:.4s}
.dest:hover span{transform:translateY(-4px);text-shadow:0 2px 12px rgba(0,0,0,.5)}
.dest:hover{transform:translateY(-5px);transition:transform .5s var(--ease)}
.d-tall{grid-row:span 2}
.d-wide{grid-column:span 2}

/* ===== Portal CTA ===== */
.portal-cta{background:radial-gradient(120% 120% at 80% 0%,#26272e,#16171c);color:#fff;padding:clamp(72px,10vw,140px) 0;overflow:hidden}
.portal-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.portal-text h2{color:#fff;margin:6px 0 20px}
.portal-text p{color:rgba(255,255,255,.66);max-width:440px;margin-bottom:24px}
.portal-list{list-style:none;margin:0 0 32px}
.portal-list li{padding:9px 0 9px 28px;position:relative;color:rgba(255,255,255,.85)}
.portal-list li::before{content:"";position:absolute;left:0;top:16px;width:12px;height:12px;border:1px solid var(--gold);transform:rotate(45deg)}
.portal-mock{perspective:1400px}
.mock-window{background:#fff;color:var(--ink);border-radius:12px;box-shadow:0 40px 80px -30px rgba(0,0,0,.7);transform:rotateY(-12deg) rotateX(4deg);transition:transform .7s var(--ease);overflow:hidden}
.portal-mock:hover .mock-window{transform:rotateY(-4deg) rotateX(1deg)}
.mock-bar{display:flex;gap:7px;padding:14px 18px;background:var(--paper-2);border-bottom:1px solid var(--line)}
.mock-bar span{width:11px;height:11px;border-radius:50%;background:#d9d2c4}
.mock-bar span:first-child{background:var(--gold)}
.mock-body{padding:24px 26px 30px}
.mock-head{margin-bottom:20px}
.mock-head strong{font-family:'Cormorant Garamond',serif;font-size:1.5rem;display:block}
.mock-head em{font-size:.8rem;color:var(--gold-dark)}
.mock-item{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-top:1px solid var(--line);font-size:.92rem}
.mock-item b{color:var(--gold-dark);margin-right:6px}
.mock-item .dot{width:10px;height:10px;border-radius:50%;background:var(--gold);margin-top:7px;flex:none;box-shadow:0 0 0 4px rgba(200,164,93,.18)}
.mock-progress{height:5px;background:var(--paper-2);border-radius:4px;margin-top:18px;overflow:hidden}
.mock-progress i{display:block;height:100%;width:62%;background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));animation:fillbar 2.4s var(--ease) forwards}
@keyframes fillbar{from{width:0}}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-media{height:520px;border-radius:6px;background-image:var(--img);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.about-text h2{margin:6px 0 22px}
.about-text p{color:var(--ink-soft);margin-bottom:18px}
.about-sign{margin-top:14px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.3rem;color:var(--gold-dark)}
.about-text p strong{color:var(--ink);font-weight:600}
.guarantee-list{list-style:none;margin:8px 0 8px;columns:2;column-gap:24px}
.guarantee-list li{position:relative;padding:6px 0 6px 22px;font-size:.92rem;color:var(--ink-soft);break-inside:avoid}
.guarantee-list li::before{content:"";position:absolute;left:0;top:12px;width:9px;height:9px;border:1px solid var(--gold);transform:rotate(45deg)}

/* ===== Subpage hero ===== */
.page-hero{position:relative;height:54vh;min-height:380px;display:flex;align-items:flex-end;overflow:hidden;background:#11131a}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);animation:heroZoom 16s ease-out forwards}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,14,20,.5) 0%,rgba(12,14,20,.1) 40%,rgba(12,14,20,.78) 100%)}
.page-hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 28px 54px;width:100%}
.page-hero .eyebrow{color:var(--gold-light)}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.5)}
.page-hero p{color:rgba(255,255,255,.85);max-width:560px;margin-top:14px}
.page-intro{text-align:center;max-width:720px;margin:0 auto clamp(40px,6vw,64px)}
.page-intro p{color:var(--ink-soft)}

/* ===== Legal prose ===== */
.legal{max-width:820px;margin:0 auto;padding:clamp(60px,9vw,110px) 28px}
.legal h1{font-size:clamp(2.4rem,5vw,3.4rem);margin-bottom:8px}
.legal .lead{color:var(--ink-soft);margin-bottom:40px;max-width:640px}
.legal h2{font-size:1.7rem;margin:40px 0 14px;color:var(--ink)}
.legal p{color:var(--ink-soft);margin-bottom:14px}
.legal ul{list-style:none;margin:0 0 18px}
.legal li{position:relative;padding:8px 0 8px 24px;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.legal li::before{content:"";position:absolute;left:0;top:16px;width:8px;height:8px;border:1px solid var(--gold);transform:rotate(45deg)}
.legal-back{display:inline-block;margin-top:40px;color:var(--gold-dark);font-weight:600}

/* ===== Hotel collection ===== */
.hotel-toolbar{position:sticky;top:62px;z-index:40;background:rgba(253,252,250,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:18px 0}
.hotel-toolbar-inner{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hotel-search{flex:1;min-width:220px;position:relative}
.hotel-search input{width:100%;padding:13px 16px 13px 42px;border:1px solid var(--line);border-radius:3px;font-family:inherit;font-size:.95rem;background:#fff;transition:.3s}
.hotel-search input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,164,93,.14)}
.hotel-search::before{content:"⌕";position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gold-dark);font-size:1.2rem}
.hotel-select{padding:13px 16px;border:1px solid var(--line);border-radius:3px;font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);cursor:pointer;min-width:190px}
.hotel-select:focus{outline:none;border-color:var(--gold)}
.hotel-toggle{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--ink-soft);cursor:pointer;padding:8px 14px;border:1px solid var(--line);border-radius:24px;transition:.3s;user-select:none}
.hotel-toggle input{accent-color:var(--gold-dark)}
.hotel-toggle.on{border-color:var(--gold);background:rgba(200,164,93,.1);color:var(--gold-dark)}
.hotel-count{width:100%;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:4px}
.hotel-count b{color:var(--gold-dark)}

.hotel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.hotel-card{position:relative;border-radius:8px;overflow:hidden;background:#fff;box-shadow:var(--shadow);transition:transform .5s var(--ease),opacity .4s}
.hotel-card:hover{transform:translateY(-7px)}
.hotel-photo{height:210px;background-size:cover;background-position:center;position:relative;transition:transform 1s var(--ease)}
.hotel-card:hover .hotel-photo{transform:scale(1.07)}
.hotel-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,13,8,.34))}
.hotel-region-tag{position:absolute;left:14px;top:14px;z-index:2;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#1c1605;background:linear-gradient(120deg,var(--gold),var(--gold-light));padding:5px 12px;border-radius:20px}
.hotel-info{padding:20px 22px 24px}
.hotel-info h3{font-size:1.4rem;line-height:1.15}
.hotel-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;min-height:22px}
.hotel-badge{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-dark);border:1px solid var(--gold-light);padding:3px 10px;border-radius:14px}
.hotel-empty{text-align:center;padding:80px 20px;color:var(--ink-soft)}
.hotel-note{text-align:center;margin-top:48px;font-size:.85rem;color:var(--ink-soft)}

/* ===== Section footer (CTA buttons) ===== */
.section-foot{text-align:center;margin-top:clamp(36px,5vw,56px)}
.btn-dark-outline{border-color:var(--gold);color:var(--gold-dark)}
.btn-dark-outline:hover{background:var(--gold);color:#1c1605}

/* ===== Hotels teaser ===== */
.hotels-teaser{background:radial-gradient(120% 120% at 15% 0%,#26272e,#15161b);color:#fff;padding:clamp(72px,10vw,140px) 0;overflow:hidden}
.hotels-teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.ht-text h2{color:#fff;margin:6px 0 20px}
.ht-text p{color:rgba(255,255,255,.7);max-width:460px;margin-bottom:28px}
.ht-collage{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ht-tile{aspect-ratio:1;background-size:cover;background-position:center;border-radius:8px;box-shadow:0 24px 50px -24px rgba(0,0,0,.6);transition:transform .5s var(--ease)}
.ht-tile:nth-child(1){transform:translateY(-14px)}
.ht-tile:nth-child(4){transform:translateY(-14px)}
.ht-collage:hover .ht-tile{transform:translateY(0)}

/* ===== Events (cards) ===== */
.event-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.event-card{position:relative;border-radius:6px;overflow:hidden;background:#fff;box-shadow:var(--shadow);transition:transform .55s var(--ease)}
.event-card:hover{transform:translateY(-8px)}
.event-media{height:190px;background-image:var(--img);background-size:cover;background-position:center;transition:transform 1s var(--ease)}
.event-card:hover .event-media{transform:scale(1.08)}
.event-body{padding:22px 22px 26px}
.event-when{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);font-weight:600}
.event-body h3{font-size:1.4rem;margin:8px 0 8px}
.event-body p{color:var(--ink-soft);font-size:.9rem}

/* ===== Itineraries ===== */
.itineraries{background:linear-gradient(180deg,var(--paper-2),var(--paper))}
.itin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.itin-card{position:relative;height:380px;border-radius:8px;overflow:hidden;box-shadow:var(--shadow);display:flex;align-items:flex-end}
.itin-media{position:absolute;inset:0;background-image:var(--img);background-size:cover;background-position:center;transition:transform 1.1s var(--ease)}
.itin-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(15,13,8,.82))}
.itin-card:hover .itin-media{transform:scale(1.08)}
.itin-body{position:relative;z-index:2;padding:28px;color:#fff}
.itin-days{display:inline-block;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#1c1605;background:linear-gradient(120deg,var(--gold),var(--gold-light));padding:5px 12px;border-radius:20px;margin-bottom:12px}
.itin-body h3{font-size:1.7rem;color:#fff}
.itin-body p{color:rgba(255,255,255,.82);font-size:.92rem;margin-top:6px}

/* ===== Contact ===== */
.contact{background:linear-gradient(180deg,var(--paper-2),var(--paper))}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
.contact-text h2{margin:6px 0 18px}
.contact-text p{color:var(--ink-soft);max-width:400px}
.contact-info{margin-top:34px;display:grid;gap:18px}
.contact-info p{display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:14px}
.contact-info span{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:4px}
.contact-info a{color:var(--ink)}
.contact-form{background:#fff;padding:38px;border-radius:8px;box-shadow:var(--shadow);border:1px solid var(--line)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.field input,.field textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:3px;font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--paper);transition:.3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(200,164,93,.14)}
.form-note{margin-top:14px;font-size:.85rem;text-align:center;min-height:20px}
.form-note.ok{color:var(--gold-dark)}
.form-note.err{color:#b4452f}

/* ===== Footer ===== */
.footer{background:var(--ink);color:#fff;padding:70px 0 0}
.footer-inner{display:grid;grid-template-columns:1.2fr 2fr;gap:50px;padding-bottom:50px}
.footer-brand .brand-mark{margin-bottom:16px}
.footer-logo{width:64px;height:64px;object-fit:contain;margin-bottom:16px;display:block}
.footer-brand p{font-family:'Cormorant Garamond',serif;font-size:1.5rem}
.footer-brand small{color:rgba(255,255,255,.5)}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.footer-cols h4{font-family:'Jost';font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-cols a{display:block;color:rgba(255,255,255,.7);font-size:.9rem;padding:5px 0;transition:.3s}
.footer-cols a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;padding-bottom:24px;border-top:1px solid rgba(255,255,255,.1);font-size:.78rem;color:rgba(255,255,255,.5)}

/* ===== Responsive ===== */
/* nav collapses to a drawer before it can overflow */
@media(max-width:900px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:78%;max-width:340px;background:var(--paper);flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;padding:0 36px;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:var(--shadow);z-index:5}
  .nav-links.open{transform:none}
  .nav-links a{color:var(--ink)!important;font-size:1rem}
  .nav-login{align-self:flex-start}
  .nav-burger{display:flex}
  .nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-burger.open span:nth-child(2){opacity:0}
  .nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media(max-width:920px){
  .intro-grid,.portal-grid,.about-grid,.contact-grid,.hotels-teaser-grid{grid-template-columns:1fr;gap:40px}
  .exp-grid{grid-template-columns:1fr 1fr}
  .event-grid{grid-template-columns:1fr 1fr}
  .itin-grid{grid-template-columns:1fr 1fr}
  .dest-grid{grid-template-columns:1fr 1fr;grid-auto-rows:190px}
  .d-wide{grid-column:span 2}
  .about-media{height:380px;order:-1}
}
@media(max-width:680px){
  .exp-grid{grid-template-columns:1fr}
  .event-grid{grid-template-columns:1fr}
  .itin-grid{grid-template-columns:1fr}
  .guarantee-list{columns:1}
  .intro-stats{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .hero{min-height:90vh}
}
@media(prefers-reduced-motion:reduce){
  .hero-bg{animation:none;transform:none}
  .reveal{opacity:1;transform:none}
}
