/* =========================================================
   HORIZON KYOTO — Premium travel experience
   Editorial luxury · pastel Japanese palette
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@300;400;500;600;700;800;900&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

:root{
  /* Ink */
  --ink:#262329;
  --ink-soft:#5d5862;
  --ink-faint:#8b8690;

  /* Paper / neutrals */
  --paper:#fbf8f3;
  --cream:#f5efe6;
  --cream-2:#ece3d6;
  --beige:#e3d6c3;

  /* Pastels from reference */
  --pink:#f4d4dd;
  --pink-soft:#f9e7ec;
  --pink-deep:#e6b6c4;
  --sky:#c3d8ee;
  --sky-deep:#9fbfe0;
  --gray-soft:#c4c6cb;

  /* Lines */
  --line:rgba(38,35,41,0.14);
  --line-2:rgba(38,35,41,0.08);
  --line-white:rgba(255,255,255,0.35);
  --line-white-2:rgba(255,255,255,0.16);

  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Archivo',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --maxw:1320px;
  --gut:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--pink-deep);color:#fff}

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--ink-faint);
}
.serif{font-family:var(--serif)}
.u-italic{font-style:italic}

.section{padding:clamp(72px,11vw,150px) var(--gut);position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;width:100%}

.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;flex-wrap:wrap;margin-bottom:clamp(40px,6vw,72px)}
.sec-head .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.sec-head .eyebrow::before{content:"";width:34px;height:1px;background:var(--ink-faint);display:inline-block}
.sec-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.4rem,5.4vw,4.4rem);
  line-height:.98;
  letter-spacing:-.01em;
}
.sec-title .lt{font-weight:400;font-style:italic;color:var(--ink-soft)}
.sec-lead{max-width:34ch;color:var(--ink-soft);font-size:1.02rem;line-height:1.7}

/* =========================================================
   PREMIUM PLACEHOLDER SYSTEM
   layered pastel gradients + grain + monospace caption
   ========================================================= */
.ph{position:relative;overflow:hidden;background:var(--cream);isolation:isolate}
.ph::after{ /* grain */
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  opacity:.5;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}
.ph .ph-img{position:absolute;inset:0;z-index:1;background-size:cover;background-position:center;transition:transform 1.4s var(--ease)}
/* real photography slots */
.ph.has-photo::after{opacity:.16}
.ph.has-photo .ph-cap{display:none}
.ph .ph-cap{
  position:absolute;left:0;bottom:0;z-index:3;
  font-family:ui-monospace,'SFMono-Regular',Menlo,monospace;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.82);padding:14px 16px;
  text-shadow:0 1px 10px rgba(0,0,0,.35);
}
.ph[data-dark] .ph-cap{color:rgba(255,255,255,.9)}

/* photo themes — pastel duotone landscapes */
.t-fuji   .ph-img{background-image:linear-gradient(180deg,#cfe0f1 0%,#bcd0ea 30%,#e9c6d2 62%,#f0d3d9 100%)}
.t-pagoda .ph-img{background-image:linear-gradient(165deg,#bcd2ec 0%,#cdb6c8 48%,#caa39c 78%,#e7cdc9 100%)}
.t-blossom .ph-img{background-image:linear-gradient(170deg,#f6dde6 0%,#f0c9d6 45%,#dfb6c6 80%,#cdd9ec 100%)}
.t-tokyo  .ph-img{background-image:linear-gradient(180deg,#aeb9d6 0%,#c4b3c9 40%,#e8c0c4 72%,#f1d6d2 100%)}
.t-osaka  .ph-img{background-image:linear-gradient(160deg,#9fb6d6 0%,#b9a7c2 45%,#c99aa0 80%,#e7c6c3 100%)}
.t-hakone .ph-img{background-image:linear-gradient(180deg,#cadcec 0%,#b8c9d8 38%,#cfd2c6 70%,#e6e0ce 100%)}
.t-temple .ph-img{background-image:linear-gradient(160deg,#d9c3b0 0%,#caa28f 42%,#b07d6d 78%,#7e5b54 100%)}
.t-food   .ph-img{background-image:linear-gradient(165deg,#ecd6c2 0%,#e0b79c 45%,#cf9a86 80%,#a9756a 100%)}
.t-cere   .ph-img{background-image:linear-gradient(170deg,#efe2d4 0%,#e6cdbf 45%,#d2b2a8 80%,#b58f86 100%)}
.t-onsen  .ph-img{background-image:linear-gradient(175deg,#cfe2e0 0%,#bcd4d4 40%,#dad0c2 72%,#ece0cf 100%)}
.t-culture .ph-img{background-image:linear-gradient(165deg,#dcd0e0 0%,#c9b6cf 45%,#c69aa4 80%,#e3c5c3 100%)}
.t-ryokan .ph-img{background-image:linear-gradient(165deg,#e7dccb 0%,#d6c2ab 46%,#bfa07f 82%,#8d7256 100%)}
.t-hotel  .ph-img{background-image:linear-gradient(180deg,#c6d3e4 0%,#bcc2d2 42%,#cfc4c2 74%,#e6ddd2 100%)}
.t-villa  .ph-img{background-image:linear-gradient(160deg,#dfe6dc 0%,#c8d2c2 45%,#cabfa9 80%,#b7a98c 100%)}
.t-resort .ph-img{background-image:linear-gradient(175deg,#bfdbe2 0%,#a9c9d6 42%,#c5cdc2 74%,#e4dccb 100%)}
.t-avatar .ph-img{background-image:linear-gradient(145deg,#dfcad2 0%,#c9aab6 55%,#a98a9a 100%)}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:1.15em 2.1em;border-radius:999px;
  transition:all .5s var(--ease);position:relative;overflow:hidden;
}
.btn .arr{transition:transform .5s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--ink);color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--pink-deep);color:#fff}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.link-arrow{
  display:inline-flex;align-items:center;gap:.6em;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--ink);
  padding-bottom:5px;border-bottom:1px solid var(--line);transition:.4s var(--ease);
}
.link-arrow .arr{transition:transform .45s var(--ease)}
.link-arrow:hover{border-color:var(--ink)}
.link-arrow:hover .arr{transform:translateX(5px)}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px var(--gut);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
  color:#fff;
}
.nav::after{content:"";position:absolute;left:var(--gut);right:var(--gut);bottom:0;height:1px;background:var(--line-white-2);transition:opacity .4s}
.nav.solid{background:rgba(251,248,243,.92);backdrop-filter:blur(14px);color:var(--ink);padding-top:15px;padding-bottom:15px;box-shadow:0 1px 0 var(--line-2)}
.nav.solid::after{background:var(--line-2)}
.nav.hide{transform:translateY(-104%)}

.brand{display:flex;align-items:baseline;gap:.55em;font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.02em;line-height:1}
.brand .mk{font-size:.62rem;font-family:var(--sans);letter-spacing:.34em;text-transform:uppercase;font-weight:600;opacity:.8;transform:translateY(-2px)}

.nav-links{display:flex;align-items:center;gap:clamp(20px,2.4vw,42px)}
.nav-links a{
  position:relative;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:6px 0;opacity:.9;transition:opacity .3s;
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:currentColor;transition:right .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-links a.active::after,.nav-links a:hover::after{right:0}

.nav-right{display:flex;align-items:center;gap:18px}
.socials{display:flex;align-items:center;gap:14px}
.socials a{width:34px;height:34px;display:grid;place-items:center;border:1px solid currentColor;border-radius:50%;opacity:.7;transition:.35s var(--ease)}
.socials a:hover{opacity:1;background:currentColor}
.socials a:hover svg{stroke:var(--paper)}
.nav.solid .socials a:hover svg{stroke:var(--paper)}
.socials svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.6}

.burger{display:none;flex-direction:column;gap:5px;width:30px;height:24px;justify-content:center}
.burger span{height:1.6px;background:currentColor;transition:.4s var(--ease);transform-origin:center}
.burger.x span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* mobile menu sheet */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gut);
  transform:translateY(-100%);transition:transform .6s var(--ease),visibility .6s;
  visibility:hidden;pointer-events:none;overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0);visibility:visible;pointer-events:auto}
.mobile-menu a{font-family:var(--serif);font-size:clamp(2rem,9vw,3.4rem);font-weight:500;padding:.18em 0;border-bottom:1px solid var(--line-white-2);transition:padding-left .4s var(--ease)}
.mobile-menu a:hover{padding-left:18px}
.mm-foot{margin-top:48px;display:flex;gap:24px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6)}

/* =========================================================
   HERO  (faithful to reference)
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:-6% 0 0 0;z-index:0;height:112%}
.hero-bg .ph-img{transition:none}
.hero-bg::before{ /* legibility wash */
  content:"";position:absolute;inset:0;z-index:3;
  background:
    linear-gradient(180deg,rgba(30,28,40,.34) 0%,rgba(30,28,40,0) 26%),
    linear-gradient(90deg,rgba(30,28,40,.30) 0%,rgba(30,28,40,0) 55%),
    linear-gradient(0deg,rgba(30,28,40,.40) 0%,rgba(30,28,40,0) 42%);
}
.hero-inner{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;padding:clamp(96px,12vh,140px) var(--gut) clamp(28px,4vh,46px)}
.hero-stage{flex:1;display:flex;flex-direction:column;justify-content:flex-end;max-width:var(--maxw);margin:0 auto;width:100%}

.hero-eyebrow{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.4vw,2.4rem);font-weight:400;color:rgba(255,255,255,.92);margin-bottom:-.08em;text-shadow:0 2px 24px rgba(0,0,0,.25)}
.hero-title{
  font-family:var(--sans);font-weight:800;
  font-size:clamp(3.4rem,12.2vw,10.5rem);
  line-height:.86;letter-spacing:-.03em;text-transform:uppercase;
  text-shadow:0 6px 60px rgba(0,0,0,.22);
}
.hero-sub{max-width:46ch;margin-top:26px;font-size:1.05rem;line-height:1.7;color:rgba(255,255,255,.9);text-shadow:0 1px 16px rgba(0,0,0,.3)}
.hero-cta{margin-top:30px;display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.hero-scroll{display:inline-flex;align-items:center;gap:12px;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8)}
.hero-scroll .dot{width:34px;height:1px;background:rgba(255,255,255,.6);position:relative;overflow:hidden}
.hero-scroll .dot::after{content:"";position:absolute;inset:0;background:#fff;animation:slide 2.4s var(--ease) infinite}
@keyframes slide{0%{transform:translateX(-100%)}55%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* hero bottom info blocks */
.hero-blocks{
  position:relative;z-index:5;max-width:var(--maxw);margin:clamp(34px,5vh,58px) auto 0;width:100%;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line-white);
}
.hblock{padding:24px 30px 4px;border-left:1px solid var(--line-white)}
.hblock:first-child{border-left:none;padding-left:0}
.hblock h3{font-family:var(--serif);font-size:1.28rem;font-weight:600;letter-spacing:.01em;margin-bottom:10px;display:flex;align-items:center;gap:12px}
.hblock h3 .ix{font-family:var(--sans);font-size:.66rem;letter-spacing:.16em;font-weight:700;opacity:.7}
.hblock p{font-size:.9rem;line-height:1.6;color:rgba(255,255,255,.82);max-width:36ch}

/* hero vertical pagination */
.hero-pager{position:absolute;right:clamp(14px,3vw,46px);top:50%;transform:translateY(-50%);z-index:6;display:flex;flex-direction:column;align-items:center;gap:0}
.hero-pager .pg-line{width:1px;height:54px;background:rgba(255,255,255,.4);margin:8px 0}
.hero-pager button{font-size:.72rem;letter-spacing:.12em;font-weight:600;color:rgba(255,255,255,.55);padding:7px 4px;transition:.35s var(--ease);font-variant-numeric:tabular-nums}
.hero-pager button.on{color:#fff;font-size:.95rem}
.hero-pager button:hover{color:#fff}

/* =========================================================
   DESTINATIONS
   ========================================================= */
.dest-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.6vw,34px)}
.dest{position:relative;cursor:pointer}
.dest .frame{position:relative;height:clamp(360px,42vw,560px);border-radius:2px}
.dest:nth-child(odd){margin-top:0}
.dest.tall .frame{height:clamp(420px,50vw,660px)}
.dest .frame .ph-img{transform:scale(1.02)}
.dest:hover .frame .ph-img{transform:scale(1.08)}
.dest .frame::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(0deg,rgba(28,24,32,.55) 0%,rgba(28,24,32,0) 52%);pointer-events:none}
.dest .meta{position:absolute;z-index:4;left:0;right:0;bottom:0;padding:30px clamp(22px,3vw,38px);color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:18px}
.dest .meta .no{font-size:.68rem;letter-spacing:.2em;font-weight:600;opacity:.8;margin-bottom:10px;display:block}
.dest .meta h3{font-family:var(--serif);font-size:clamp(1.8rem,3.2vw,2.8rem);font-weight:500;line-height:1;margin-bottom:8px}
.dest .meta p{font-size:.9rem;color:rgba(255,255,255,.85);max-width:34ch;line-height:1.55}
.dest .disc{flex-shrink:0;width:54px;height:54px;border:1px solid var(--line-white);border-radius:50%;display:grid;place-items:center;transition:.45s var(--ease)}
.dest:hover .disc{background:#fff;color:var(--ink);transform:rotate(-45deg)}
.dest .disc svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5}

/* =========================================================
   SUR MESURE (editorial asymmetric)
   ========================================================= */
.bespoke{background:var(--cream)}
.bespoke-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,90px);align-items:center}
.bespoke-media{position:relative}
.bespoke-media .big{height:clamp(440px,52vw,640px);border-radius:2px}
.bespoke-media .small{position:absolute;right:-34px;bottom:-44px;width:46%;height:46%;border-radius:2px;box-shadow:0 30px 70px -28px rgba(40,30,30,.5);border:8px solid var(--cream)}
.bespoke-media .badge{position:absolute;left:-26px;top:34px;background:var(--paper);padding:18px 22px;box-shadow:0 24px 50px -24px rgba(40,30,30,.35);max-width:200px}
.bespoke-media .badge .n{font-family:var(--serif);font-size:2.6rem;line-height:.9;font-weight:500}
.bespoke-media .badge span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}

.feature-list{margin-top:38px;display:flex;flex-direction:column}
.feature{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:24px 0;border-top:1px solid var(--line);align-items:start}
.feature:last-child{border-bottom:1px solid var(--line)}
.feature .fno{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:var(--ink-faint);padding-top:3px}
.feature h4{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin-bottom:6px}
.feature p{color:var(--ink-soft);font-size:.96rem;max-width:46ch}

/* =========================================================
   EXPÉRIENCES (immersive gallery)
   ========================================================= */
.exp-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(180px,17vw,220px);gap:clamp(14px,1.6vw,22px)}
.exp{position:relative;overflow:hidden;border-radius:2px;cursor:pointer}
.exp .ph-img{transform:scale(1.03)}
.exp:hover .ph-img{transform:scale(1.1)}
.exp::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(0deg,rgba(26,22,28,.6),rgba(26,22,28,0) 58%);transition:opacity .5s}
.exp .lbl{position:absolute;z-index:4;left:0;bottom:0;padding:24px clamp(18px,2vw,30px);color:#fff}
.exp .lbl .e-ix{font-size:.66rem;letter-spacing:.2em;font-weight:600;opacity:.8}
.exp .lbl h3{font-family:var(--serif);font-size:clamp(1.4rem,2.2vw,2rem);font-weight:500;margin-top:6px;line-height:1.05}
.exp .lbl p{font-size:.86rem;color:rgba(255,255,255,.82);margin-top:8px;max-width:40ch;opacity:0;max-height:0;transition:opacity .5s var(--ease),max-height .5s var(--ease)}
.exp:hover .lbl p{opacity:1;max-height:80px}
.e1{grid-column:span 7;grid-row:span 2}
.e2{grid-column:span 5;grid-row:span 1}
.e3{grid-column:span 5;grid-row:span 1}
.e4{grid-column:span 4;grid-row:span 2}
.e5{grid-column:span 8;grid-row:span 1}

/* =========================================================
   HÉBERGEMENTS
   ========================================================= */
.stay{background:var(--ink);color:var(--paper)}
.stay .eyebrow{color:rgba(255,255,255,.5)}
.stay .sec-head .eyebrow::before{background:rgba(255,255,255,.4)}
.stay .sec-lead{color:rgba(255,255,255,.62)}
.stay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.8vw,26px)}
.stay-card{display:flex;flex-direction:column;cursor:pointer}
.stay-card .frame{height:clamp(300px,30vw,400px);border-radius:2px;margin-bottom:22px}
.stay-card .frame .ph-img{transform:scale(1.03)}
.stay-card:hover .frame .ph-img{transform:scale(1.09)}
.stay-card .tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--pink-deep);margin-bottom:10px}
.stay-card h3{font-family:var(--serif);font-size:1.7rem;font-weight:500;margin-bottom:8px;line-height:1.05}
.stay-card p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.6}
.stay-card .price{margin-top:16px;padding-top:16px;border-top:1px solid var(--line-white-2);font-size:.84rem;color:rgba(255,255,255,.78);display:flex;justify-content:space-between;align-items:center}
.stay-card .price b{font-family:var(--serif);font-size:1.25rem;font-weight:500}

/* =========================================================
   TÉMOIGNAGES
   ========================================================= */
.testi{background:linear-gradient(180deg,var(--pink-soft),var(--paper))}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.tcard{
  background:rgba(255,255,255,.6);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.7);border-radius:4px;padding:clamp(28px,3vw,40px);
  box-shadow:0 20px 50px -30px rgba(80,50,60,.35);
  transition:transform .55s var(--ease),box-shadow .55s var(--ease);
  display:flex;flex-direction:column;
}
.tcard:hover{transform:translateY(-8px);box-shadow:0 36px 70px -30px rgba(80,50,60,.42)}
.tcard .stars{display:flex;gap:3px;color:var(--pink-deep);margin-bottom:20px}
.tcard .stars svg{width:16px;height:16px;fill:currentColor}
.tcard blockquote{font-family:var(--serif);font-size:1.32rem;line-height:1.45;font-weight:500;color:var(--ink);flex:1}
.tcard .who{display:flex;align-items:center;gap:14px;margin-top:28px;padding-top:22px;border-top:1px solid var(--line)}
.tcard .who .av{width:48px;height:48px;border-radius:50%;flex-shrink:0}
.tcard .who .n{font-weight:600;font-size:.96rem}
.tcard .who .d{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-top:3px}

/* =========================================================
   NEWSLETTER
   ========================================================= */
.news{position:relative;overflow:hidden;text-align:center;color:#fff}
.news .ph{position:absolute;inset:0;z-index:0}
.news .ph::before{content:"";position:absolute;inset:0;z-index:3;background:linear-gradient(0deg,rgba(28,24,32,.6),rgba(28,24,32,.45))}
.news-inner{position:relative;z-index:5;max-width:660px;margin:0 auto}
.news h2{font-family:var(--serif);font-size:clamp(2.4rem,5.6vw,4.2rem);font-weight:500;line-height:1.02;margin-bottom:22px}
.news p{color:rgba(255,255,255,.85);font-size:1.05rem;line-height:1.7;max-width:46ch;margin:0 auto 38px}
.news-form{display:flex;gap:10px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border:1px solid var(--line-white);padding:8px;border-radius:999px;max-width:520px;margin:0 auto}
.news-form input{flex:1;background:none;border:none;outline:none;color:#fff;padding:0 22px;font-size:.95rem;font-family:inherit}
.news-form input::placeholder{color:rgba(255,255,255,.6)}
.news-form button{white-space:nowrap}
.news-note{margin-top:18px;font-size:.78rem;letter-spacing:.04em;color:rgba(255,255,255,.6)}
.news-note.ok{color:#d6f3df}
.news-note.err{color:#ffd6dc}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--paper);padding:clamp(72px,9vw,110px) var(--gut) 40px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:clamp(30px,4vw,64px);padding-bottom:64px;border-bottom:1px solid var(--line)}
.foot-brand .brand{color:var(--ink);font-size:1.9rem;margin-bottom:20px}
.foot-brand p{color:var(--ink-soft);max-width:38ch;font-size:.95rem;line-height:1.7;margin-bottom:26px}
.foot-col h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--ink-faint);margin-bottom:22px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.foot-col a{font-size:.95rem;color:var(--ink-soft);transition:.3s;position:relative;display:inline-block}
.foot-col a:hover{color:var(--ink);transform:translateX(4px)}
.foot-social{display:flex;gap:12px}
.foot-social a{width:40px;height:40px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:.35s var(--ease)}
.foot-social a:hover{background:var(--ink);border-color:var(--ink)}
.foot-social a:hover svg{stroke:var(--paper)}
.foot-social svg{width:15px;height:15px;stroke:var(--ink);fill:none;stroke-width:1.6}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding-top:30px;font-size:.82rem;color:var(--ink-faint)}
.foot-bot .links{display:flex;gap:26px;flex-wrap:wrap}
.foot-bot a:hover{color:var(--ink)}

/* =========================================================
   REVEAL ANIMATIONS
   Base state is ALWAYS visible; animation only enhances.
   (Hidden states are scoped to .in / [data-ready] so content
    never gets stuck invisible if the render context can't tick.)
   ========================================================= */
@media (prefers-reduced-motion: no-preference){
  .reveal.in{animation:rise 1.1s var(--ease) both}
  .reveal.in[data-d="1"]{animation-delay:.1s}
  .reveal.in[data-d="2"]{animation-delay:.2s}
  .reveal.in[data-d="3"]{animation-delay:.3s}
  .reveal.in[data-d="4"]{animation-delay:.4s}
}
@keyframes rise{from{opacity:0;transform:translateY(38px)}to{opacity:1;transform:none}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .nav-links{display:none}
  .burger{display:flex}
  .socials{display:none}
  .exp-grid{grid-template-columns:repeat(8,1fr)}
  .e1{grid-column:span 8;grid-row:span 2}
  .e2,.e3{grid-column:span 4}
  .e4{grid-column:span 4;grid-row:span 2}
  .e5{grid-column:span 4}
  .stay-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:760px){
  :root{--gut:22px}
  .hero-blocks{grid-template-columns:1fr;border-top:none}
  .hblock{border-left:none;border-top:1px solid var(--line-white);padding:18px 0 6px}
  .hblock:first-child{padding-top:18px}
  .hero-pager{display:none}
  .hero-sub{display:none}
  .dest-grid{grid-template-columns:1fr}
  .bespoke-grid{grid-template-columns:1fr}
  .bespoke-media{margin-bottom:60px}
  .bespoke-media .small{right:0;width:50%}
  .exp-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:200px}
  .e1,.e2,.e3,.e4,.e5{grid-column:span 4;grid-row:span 1}
  .e1{grid-row:span 2}
  .stay-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .news-form{flex-direction:column;border-radius:18px;padding:14px}
  .news-form input{padding:14px 18px;text-align:center}
  .news-form .btn{justify-content:center}
  .foot-top{grid-template-columns:1fr}
}
