/* =================================================================
   MONTENEGRO — One Week on the Adriatic
   Shared stylesheet. Three switchable visual treatments:
   [data-treatment="editorial" | "coastal" | "nocturne"]
   ================================================================= */

/* ---------- Design tokens (brief palette) ---------- */
:root{
  --navy:#1B3A5C;
  --teal:#1A7A8A;
  --gold:#C9922A;
  --mist:#E8F4F8;

  /* themed (overridden per treatment) */
  --bg:#FBF8F1;
  --bg-alt:#F2ECE0;
  --surface:#FFFFFF;
  --ink:#22303B;          /* body text */
  --head:#1B3A5C;         /* headings */
  --accent:#1A7A8A;
  --accent-2:#C9922A;
  --line:#E2D8C6;
  --muted:#7C8A93;
  --hero-tint: rgba(16,34,52,.42);
  --hero-grad: linear-gradient(180deg, rgba(16,34,52,.10) 0%, rgba(16,34,52,.0) 32%, rgba(16,34,52,.62) 100%);

  --font-display:'Playfair Display', Georgia, serif;
  --font-body:'Inter', system-ui, sans-serif;
  --radius:4px;
  --maxw:1200px;
  --pad: clamp(20px, 5vw, 64px);
  --label-spacing:.22em;
  --label-transform:uppercase;
  --shadow: 0 24px 60px -28px rgba(16,34,52,.40);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ===== Treatment: EDITORIAL (default, the brief) ===== */
[data-treatment="editorial"]{
  --bg:#FBF8F1; --bg-alt:#F3EDE0; --surface:#FFFFFF;
  --ink:#2B3640; --head:#1B3A5C; --accent:#1A7A8A; --accent-2:#C9922A;
  --line:#E5DBC9; --muted:#8A8170;
  --font-display:'Playfair Display', Georgia, serif;
}

/* ===== Treatment: COASTAL (contemporary, teal-forward) ===== */
[data-treatment="coastal"]{
  --bg:#FFFFFF; --bg-alt:#EAF3F5; --surface:#F4FAFB;
  --ink:#173640; --head:#0E2C38; --accent:#0E8FA3; --accent-2:#0E2C38;
  --line:#D2E5E9; --muted:#6E8A92;
  --font-display:'Space Grotesk', system-ui, sans-serif;
  --radius:0px;
  --label-spacing:.28em;
  --hero-tint: rgba(11,40,52,.34);
  --hero-grad: linear-gradient(180deg, rgba(11,40,52,.18) 0%, rgba(11,40,52,0) 38%, rgba(11,40,52,.66) 100%);
}

/* ===== Treatment: NOCTURNE (dark luxury) ===== */
[data-treatment="nocturne"]{
  --bg:#0E2031; --bg-alt:#142B40; --surface:#16314A;
  --ink:#DCE5EC; --head:#F4EFE4; --accent:#46B3C4; --accent-2:#D7A646;
  --line:#28455F; --muted:#8AA0B2;
  --font-display:'Playfair Display', Georgia, serif;
  --hero-tint: rgba(6,16,26,.50);
  --hero-grad: linear-gradient(180deg, rgba(6,16,26,.20) 0%, rgba(6,16,26,0) 30%, rgba(6,16,26,.80) 100%);
  --shadow: 0 24px 60px -26px rgba(0,0,0,.6);
}

/* ---------- Base ---------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.75;
  -webkit-font-smoothing:antialiased; letter-spacing:.005em;
  transition: background .5s var(--ease), color .5s var(--ease);
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--head); font-weight:600; line-height:1.08; margin:0; }
p{ margin:0 0 1.1em; text-wrap:pretty; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.wrap-wide{ max-width:1400px; margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }

/* small caps label */
.label{
  font-family:var(--font-body); font-weight:600; font-size:12.5px;
  letter-spacing:var(--label-spacing); text-transform:var(--label-transform);
  color:var(--accent); display:inline-flex; align-items:center; gap:.6em;
}
.label::before{ content:""; width:26px; height:1.5px; background:var(--accent-2); display:inline-block; }
.label.no-rule::before{ display:none; }

/* ---------- Header / nav ---------- */
.site-head{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--pad);
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:blur(12px) saturate(1.1);
  border-bottom:1px solid transparent;
  transition: padding .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease);
}
.site-head.scrolled{
  padding:11px var(--pad);
  background:color-mix(in srgb, var(--bg) 92%, transparent);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:30px; height:30px; flex:none; border-radius:50%;
  background:
    radial-gradient(circle at 50% 120%, var(--accent-2) 0 32%, transparent 33%),
    conic-gradient(from 210deg, var(--navy), var(--teal) 60%, var(--navy));
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--bg) 60%, transparent);
}
.brand-name{ font-family:var(--font-display); font-weight:600; font-size:19px; color:var(--head); line-height:1; display:flex; flex-direction:column; gap:3px; }
.brand-sub{ font-family:var(--font-body); font-weight:500; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.nav{ display:flex; align-items:center; gap:clamp(10px,1.6vw,26px); flex-wrap:wrap; justify-content:flex-end; }
.nav-link{
  position:relative; font-size:14px; font-weight:500; color:var(--ink);
  padding:4px 0; letter-spacing:.01em; white-space:nowrap; transition:color .25s;
}
.nav-link::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1.5px; background:var(--accent); transition:right .3s var(--ease); }
.nav-link:not(.nav-soon):hover{ color:var(--accent); }
.nav-link:not(.nav-soon):hover::after{ right:0; }
.nav-link.is-active{ color:var(--accent); }
.nav-link.is-active::after{ right:0; background:var(--accent-2); }
.nav-soon{ color:var(--muted); opacity:.5; cursor:default; }
.nav-toggle{ display:none; background:none; border:0; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
.nav-toggle span{ width:24px; height:2px; background:var(--head); display:block; }

/* language switch */
.lang-switch{ display:inline-flex; align-items:center; gap:5px; font-size:12.5px; font-weight:600; letter-spacing:.06em; color:var(--muted); border:1.5px solid var(--line); border-radius:999px; padding:6px 13px; margin-left:6px; transition:.25s var(--ease); }
.lang-switch:hover{ border-color:var(--accent); color:var(--accent); }
.lang-switch .on{ color:var(--accent); }
.lang-switch .sep{ opacity:.5; font-weight:400; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:#fff; overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.06); animation: heroZoom 18s var(--ease) forwards; }
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero::after{ content:""; position:absolute; inset:0; background:var(--hero-grad); }
.hero-inner{ position:relative; z-index:2; width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad) clamp(48px,7vw,96px); }
.hero .label{ color:#fff; }
.hero .label::before{ background:var(--gold); }
.hero h1{
  color:#fff; font-size:clamp(48px,8.5vw,118px); line-height:.96; letter-spacing:-.01em;
  margin:.28em 0 .2em; max-width:14ch;
}
.hero-tag{ font-size:clamp(17px,2vw,23px); max-width:46ch; color:rgba(255,255,255,.92); margin-bottom:2em; font-weight:400; }
.hero-stats{ display:flex; flex-wrap:wrap; gap:clamp(20px,4vw,56px); border-top:1px solid rgba(255,255,255,.28); padding-top:24px; }
.hero-stat .n{ font-family:var(--font-display); font-size:clamp(26px,3.4vw,42px); line-height:1; }
.hero-stat .n.txt{ font-size:clamp(20px,2.4vw,30px); white-space:nowrap; }
.hero-stat .k{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.78); margin-top:8px; }
.scrolldown{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3; color:#fff; font-size:11px; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:8px; opacity:.85; }
.scrolldown span{ width:1px; height:34px; background:linear-gradient(#fff, transparent); animation: scrollPulse 2s infinite; }
@keyframes scrollPulse{ 0%,100%{ opacity:.3; } 50%{ opacity:1; } }

/* coastal hero type tweak */
[data-treatment="coastal"] .hero h1{ font-weight:600; letter-spacing:-.02em; text-transform:none; }

/* ---------- Section scaffolding ---------- */
.section{ padding:clamp(64px,10vw,140px) 0; }
.section.alt{ background:var(--bg-alt); }
.sec-head{ max-width:62ch; margin-bottom:clamp(40px,6vw,72px); }
.sec-head h2{ font-size:clamp(32px,4.6vw,60px); margin:.34em 0 .4em; }
.sec-head .lead{ font-size:clamp(18px,2vw,22px); color:var(--ink); }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head.center .label{ justify-content:center; }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.fade{ transform:none; }

/* ---------- Pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.pillar{ background:var(--surface); padding:clamp(24px,2.4vw,38px); display:flex; flex-direction:column; gap:14px; min-height:280px; transition:background .4s; }
.pillar:hover{ background:color-mix(in srgb, var(--accent) 7%, var(--surface)); }
.pillar .pn{ font-family:var(--font-display); font-size:46px; color:var(--accent-2); line-height:1; }
.pillar h3{ font-size:22px; }
.pillar p{ font-size:15px; color:var(--muted); margin:0; }

/* ---------- Split feature ---------- */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(32px,5vw,80px); align-items:center; }
.split.flip .split-media{ order:2; }
.split-media{ position:relative; aspect-ratio:4/3.2; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); }
.split-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.split-media:hover img{ transform:scale(1.04); }
.split-media .tag{ position:absolute; left:0; bottom:0; background:var(--surface); color:var(--head); font-size:12px; letter-spacing:.12em; text-transform:uppercase; padding:10px 16px; border-top-right-radius:var(--radius); }
.split-body h2{ font-size:clamp(28px,3.6vw,46px); margin:.3em 0 .55em; }
.split-body .meta{ display:flex; gap:28px; flex-wrap:wrap; margin-top:22px; border-top:1px solid var(--line); padding-top:18px; }
.split-body .meta .k{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.split-body .meta .v{ font-family:var(--font-display); font-size:22px; color:var(--head); }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:14px; letter-spacing:.02em; padding:13px 24px; border-radius:999px; border:1.5px solid var(--head); color:var(--head); transition:.3s var(--ease); }
.btn:hover{ background:var(--head); color:var(--bg); gap:14px; }
.btn.solid{ background:var(--accent); border-color:var(--accent); color:#fff; }
.btn.solid:hover{ background:var(--head); border-color:var(--head); }
.btn .arr{ transition:transform .3s var(--ease); }
.btn:hover .arr{ transform:translateX(3px); }

/* ---------- Timeline strip (day teasers) ---------- */
.timeline{ display:grid; grid-template-columns:repeat(7,1fr); gap:14px; }
.tl-day{ position:relative; display:flex; flex-direction:column; gap:0; text-align:left; }
.tl-day .dnum{ font-family:var(--font-display); font-size:15px; color:var(--accent); letter-spacing:.1em; }
.tl-day .bar{ height:3px; background:var(--line); margin:12px 0 14px; position:relative; overflow:hidden; }
.tl-day .bar::after{ content:""; position:absolute; inset:0; width:0; background:var(--accent-2); transition:width 1s var(--ease); }
.tl-day.in .bar::after{ width:100%; }
.tl-day h4{ font-size:16px; margin-bottom:6px; }
.tl-day p{ font-size:13px; color:var(--muted); margin:0; }

/* ---------- Cards grid ---------- */
.cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:clamp(18px,2vw,28px); }
.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.card .ph{ aspect-ratio:16/10; overflow:hidden; }
.card .ph img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.card:hover .ph img{ transform:scale(1.05); }
.card-body{ padding:22px 22px 26px; display:flex; flex-direction:column; gap:10px; flex:1; }
.card-body h3{ font-size:21px; }
.card-body p{ font-size:14px; color:var(--muted); margin:0; }
.card-foot{ margin-top:auto; padding-top:14px; display:flex; justify-content:space-between; align-items:center; font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); border-top:1px solid var(--line); }

/* ---------- Day accordion ---------- */
.day{ border-bottom:1px solid var(--line); }
details.day > summary.day-row{ list-style:none; }
details.day > summary.day-row::-webkit-details-marker{ display:none; }
.day-row{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(18px,3vw,46px); align-items:center; padding:clamp(22px,3vw,38px) 0; cursor:pointer; }
.day-num{ font-family:var(--font-display); font-size:clamp(34px,5vw,64px); color:var(--accent-2); line-height:.9; min-width:1.6em; }
.day-titles .label{ margin-bottom:8px; }
.day-titles h3{ font-size:clamp(22px,3vw,34px); }
.day-titles .sub{ color:var(--muted); font-size:15px; margin-top:6px; }
.day-toggle{ width:46px; height:46px; border-radius:50%; border:1.5px solid var(--line); flex:none; position:relative; transition:.3s; }
.day-toggle::before,.day-toggle::after{ content:""; position:absolute; background:var(--head); left:50%; top:50%; transform:translate(-50%,-50%); }
.day-toggle::before{ width:15px; height:1.5px; }
.day-toggle::after{ width:1.5px; height:15px; transition:transform .3s var(--ease); }
details.day[open] .day-toggle{ background:var(--accent); border-color:var(--accent); }
details.day[open] .day-toggle::before,details.day[open] .day-toggle::after{ background:#fff; }
details.day[open] .day-toggle::after{ transform:translate(-50%,-50%) scaleY(0); }
@keyframes dayIn{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
details.day[open] .day-content{ animation:dayIn .5s var(--ease); }
.day-content{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(24px,4vw,56px); padding:0 0 clamp(34px,4vw,52px); }
.day-slots{ display:flex; flex-direction:column; gap:22px; }
.slot{ display:grid; grid-template-columns:96px 1fr; gap:20px; }
.slot .when{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); padding-top:4px; }
.slot .what{ font-size:15.5px; }
.slot .what ul{ margin:.5em 0 0; padding-left:1.1em; }
.slot .what li{ margin-bottom:.3em; color:var(--ink); }
.day-aside{ display:flex; flex-direction:column; gap:18px; }
.day-aside .ph{ aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.day-aside .ph img{ width:100%; height:100%; object-fit:cover; }
.cost-chip{ background:var(--bg-alt); border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px; }
.cost-chip .k{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.cost-chip .v{ font-size:14px; color:var(--head); }

/* ---------- Stat band ---------- */
.band{ background:var(--head); color:#fff; }
[data-treatment="nocturne"] .band{ background:var(--surface); }
.band .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; padding-top:clamp(48px,6vw,80px); padding-bottom:clamp(48px,6vw,80px); }
.band .bn{ font-family:var(--font-display); font-size:clamp(32px,4vw,52px); color:#fff; line-height:1; }
[data-treatment="nocturne"] .band .bn{ color:var(--head); }
.band .bk{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.72); margin-top:10px; }
[data-treatment="nocturne"] .band .bk{ color:var(--muted); }
.band .bd{ font-size:13px; color:rgba(255,255,255,.6); margin-top:8px; }
[data-treatment="nocturne"] .band .bd{ color:var(--muted); }

/* ---------- Full-bleed quote ---------- */
.bleed{ position:relative; min-height:64vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.bleed-bg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.bleed::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(16,34,52,.72), rgba(16,34,52,.28)); }
.bleed-inner{ position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.bleed blockquote{ margin:0; font-family:var(--font-display); font-size:clamp(26px,4vw,52px); line-height:1.18; max-width:18ch; }
.bleed cite{ display:block; font-family:var(--font-body); font-style:normal; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-top:26px; }

/* ---------- Stay (accommodation) cards ---------- */
.stay-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,3vw,40px); }
.stay{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; }
.stay .ph{ aspect-ratio:16/11; overflow:hidden; position:relative; }
.stay .ph img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.stay:hover .ph img{ transform:scale(1.05); }
.stay .nights{ position:absolute; top:14px; left:14px; background:var(--bg); color:var(--head); font-size:11px; letter-spacing:.14em; text-transform:uppercase; padding:7px 12px; border-radius:999px; }
.stay-body{ padding:clamp(22px,2.4vw,34px); display:flex; flex-direction:column; gap:16px; flex:1; }
.stay-body h3{ font-size:clamp(24px,2.6vw,32px); }
.stay-body .where{ color:var(--muted); font-size:14px; margin-top:-8px; }
.feature-list{ display:grid; grid-template-columns:1fr 1fr; gap:14px 22px; border-top:1px solid var(--line); padding-top:18px; }
.feature-list .k{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.feature-list .v{ font-size:14.5px; color:var(--ink); }
.stay-foot{ margin-top:auto; display:flex; align-items:flex-end; justify-content:space-between; gap:16px; padding-top:18px; border-top:1px solid var(--line); }
.stay-foot .price .k{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.stay-foot .price .v{ font-family:var(--font-display); font-size:26px; color:var(--head); }
.stay-foot .price .v small{ font-size:13px; color:var(--muted); font-family:var(--font-body); }

/* ---------- Misc ---------- */
.kicker-img{ width:100%; aspect-ratio:21/8; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow); }
.two-col-text{ columns:2; column-gap:clamp(28px,4vw,60px); }
.note{ background:var(--bg-alt); border-left:3px solid var(--accent-2); padding:18px 22px; border-radius:0 var(--radius) var(--radius) 0; font-size:15px; }

/* ---------- Footer ---------- */
.site-foot{ background:var(--head); color:#fff; padding:clamp(56px,8vw,110px) 0 48px; margin-top:0; }
[data-treatment="nocturne"] .site-foot{ background:var(--bg-alt); }
.foot-inner{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); display:grid; grid-template-columns:1.4fr 1fr; gap:40px; }
.foot-title{ font-family:var(--font-display); font-size:clamp(30px,4vw,52px); color:#fff; }
[data-treatment="nocturne"] .foot-title{ color:var(--head); }
.foot-tag{ font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-top:14px; }
.foot-nav{ display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.foot-nav a, .foot-soon{ font-size:15px; color:rgba(255,255,255,.82); }
[data-treatment="nocturne"] .foot-nav a, [data-treatment="nocturne"] .foot-soon{ color:var(--ink); }
.foot-nav a:hover{ color:var(--gold); }
.foot-soon{ opacity:.45; }
.foot-meta{ grid-column:1/-1; display:flex; flex-wrap:wrap; gap:8px 28px; border-top:1px solid rgba(255,255,255,.2); margin-top:40px; padding-top:24px; font-size:12px; letter-spacing:.06em; color:rgba(255,255,255,.6); }
[data-treatment="nocturne"] .foot-meta{ color:var(--muted); border-color:var(--line); }

/* ---------- Treatment switcher ---------- */
.treatment-switch{
  position:fixed; right:18px; bottom:18px; z-index:80;
  background:color-mix(in srgb, var(--surface) 88%, transparent);
  border:1px solid var(--line); border-radius:14px; padding:11px 13px;
  box-shadow:0 16px 40px -16px rgba(16,34,52,.45); backdrop-filter:blur(10px);
  display:flex; flex-direction:column; gap:8px; max-width:min(86vw,250px);
}
.tsw-label{ font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.tsw-opts{ display:flex; gap:5px; background:var(--bg-alt); padding:4px; border-radius:9px; }
.tsw-opt{ flex:1; font-family:var(--font-body); font-size:12px; font-weight:600; color:var(--ink); background:none; border:0; padding:7px 9px; border-radius:6px; cursor:pointer; transition:.25s; white-space:nowrap; }
.tsw-opt:hover{ color:var(--accent); }
.tsw-opt[aria-pressed="true"]{ background:var(--accent); color:#fff; box-shadow:0 4px 12px -4px var(--accent); }

/* ---------- Calendar / week planner ---------- */
.cal-legend{ display:flex; flex-wrap:wrap; gap:12px 22px; margin-bottom:30px; }
.cal-legend .lg{ display:inline-flex; align-items:center; gap:9px; font-size:13px; color:var(--ink); }
.cal-legend .sw{ width:14px; height:14px; border-radius:4px; flex:none; }
:root{
  --cat-travel:#5B6B7A; --cat-culture:#1A7A8A; --cat-cycle:#C9922A;
  --cat-water:#2E7CB5; --cat-nature:#5B8C5A; --cat-dining:#A1524A;
}
.sw.travel,.evt[data-cat="travel"]::before{ background:var(--cat-travel); }
.sw.culture,.evt[data-cat="culture"]::before{ background:var(--cat-culture); }
.sw.cycle,.evt[data-cat="cycle"]::before{ background:var(--cat-cycle); }
.sw.water,.evt[data-cat="water"]::before{ background:var(--cat-water); }
.sw.nature,.evt[data-cat="nature"]::before{ background:var(--cat-nature); }
.sw.dining,.evt[data-cat="dining"]::before{ background:var(--cat-dining); }

.cal{ display:grid; grid-template-columns:repeat(7,1fr); gap:14px; }
.cal-col{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.cal-col-head{ padding:16px 16px 14px; border-bottom:1px solid var(--line); background:var(--bg-alt); }
.cal-col-head .cd-day{ font-family:var(--font-body); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.cal-col-head .cd-date{ font-family:var(--font-display); font-size:30px; color:var(--head); line-height:1; margin:4px 0 6px; }
.cal-col-head .cd-loc{ font-size:12px; color:var(--muted); line-height:1.3; }
.cal-events{ display:flex; flex-direction:column; gap:1px; background:var(--line); flex:1; }
.evt{ position:relative; background:var(--surface); padding:13px 14px 13px 22px; display:flex; flex-direction:column; gap:3px; transition:background .2s; }
.evt::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; }
.evt:hover{ background:var(--bg-alt); }
.evt .et{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.evt .en{ font-size:14px; font-weight:600; color:var(--head); line-height:1.25; }
.evt .em{ font-size:12px; color:var(--muted); }
.evt a.lk{ font-size:14px; }
.cal-col-foot{ padding:11px 14px; border-top:1px solid var(--line); background:var(--bg-alt); display:flex; align-items:center; gap:8px; font-size:11px; color:var(--muted); }
.cal-col-foot .bed{ width:8px; height:8px; border-radius:50%; background:var(--navy); flex:none; }
.cal-col-foot .ride-badge{ margin-left:auto; font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--cat-cycle); border:1px solid color-mix(in srgb,var(--cat-cycle) 50%,transparent); border-radius:999px; padding:2px 8px; }

/* totals strip */
.cal-totals{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-top:30px; }
.cal-totals .ct{ background:var(--surface); padding:24px; }
.cal-totals .ct .v{ font-family:var(--font-display); font-size:34px; color:var(--head); line-height:1; }
.cal-totals .ct .k{ font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

/* ---------- Data tables ---------- */
.dtable{ width:100%; border-collapse:collapse; font-size:15px; }
.dtable th, .dtable td{ text-align:left; padding:14px 16px; border-bottom:1px solid var(--line); vertical-align:top; }
.dtable thead th{ font-family:var(--font-body); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#fff; background:var(--head); border-bottom:0; }
[data-treatment="nocturne"] .dtable thead th{ color:var(--head); background:var(--accent-2); }
.dtable tbody tr:nth-child(even){ background:var(--bg-alt); }
.dtable td.num{ font-family:var(--font-display); color:var(--head); white-space:nowrap; }
.dtable .rname{ font-weight:600; color:var(--head); }
.dtable tfoot td{ font-family:var(--font-display); font-size:17px; color:var(--head); border-top:2px solid var(--head); border-bottom:0; background:var(--bg-alt); }
.table-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); }

/* ---------- Native accordion (logistics / packing) ---------- */
.acc{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--surface); }
.acc details{ border-bottom:1px solid var(--line); }
.acc details:last-child{ border-bottom:0; }
.acc summary{ list-style:none; cursor:pointer; padding:20px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px; font-family:var(--font-display); font-size:20px; color:var(--head); transition:background .25s; }
.acc summary::-webkit-details-marker{ display:none; }
.acc summary:hover{ background:var(--bg-alt); }
.acc summary .plus{ width:34px; height:34px; flex:none; border-radius:50%; border:1.5px solid var(--line); position:relative; transition:.3s; }
.acc summary .plus::before, .acc summary .plus::after{ content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); background:var(--head); }
.acc summary .plus::before{ width:12px; height:1.5px; }
.acc summary .plus::after{ width:1.5px; height:12px; transition:transform .3s var(--ease); }
.acc details[open] summary .plus{ background:var(--accent); border-color:var(--accent); }
.acc details[open] summary .plus::before, .acc details[open] summary .plus::after{ background:#fff; }
.acc details[open] summary .plus::after{ transform:translate(-50%,-50%) scaleY(0); }
.acc .acc-body{ padding:0 24px 24px; font-size:15px; }
.acc .acc-body p:last-child{ margin-bottom:0; }
.acc .kv{ display:grid; grid-template-columns:160px 1fr; gap:10px 22px; }
.acc .kv dt{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); padding-top:2px; }
.acc .kv dd{ margin:0; }

/* ---------- Elevation profile (cycling) ---------- */
.routecard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; }
.routecard .rc-head{ padding:24px 26px 18px; }
.routecard .rc-head h3{ font-size:24px; margin:.3em 0 .1em; }
.routecard .rc-head .rc-from{ font-size:13px; color:var(--muted); letter-spacing:.04em; }
.rc-stats{ display:flex; gap:26px; flex-wrap:wrap; padding:0 26px 18px; }
.rc-stats .s .k{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.rc-stats .s .v{ font-family:var(--font-display); font-size:22px; color:var(--head); }
.elev{ width:100%; height:120px; display:block; background:var(--bg-alt); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.elev .area{ fill:color-mix(in srgb, var(--accent) 16%, transparent); }
.elev .line{ fill:none; stroke:var(--accent); stroke-width:2.5; }
.elev .grid{ stroke:var(--line); stroke-width:1; }
.elev text{ fill:var(--muted); font-size:11px; font-family:var(--font-body); }
.rc-body{ padding:20px 26px 24px; font-size:14.5px; color:var(--ink); flex:1; }
.rc-body .diff{ display:inline-flex; align-items:center; gap:8px; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-2); margin-bottom:12px; }
.dots{ display:inline-flex; gap:4px; }
.dots i{ width:8px; height:8px; border-radius:50%; background:var(--line); }
.dots i.on{ background:var(--accent-2); }

/* ---------- Dish menu (food) ---------- */
.menu{ display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(32px,5vw,72px); }
.dish{ display:grid; grid-template-columns:auto 1fr; gap:4px 0; padding:20px 0; border-bottom:1px solid var(--line); }
.dish .dn{ font-family:var(--font-display); font-size:21px; color:var(--head); grid-column:1; }
.dish .dd-dot{ grid-column:2; border-bottom:1px dotted var(--line); margin:0 12px 7px; align-self:end; }
.dish .dx{ grid-column:1/-1; font-size:14.5px; color:var(--muted); margin:0; }
.wine-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px; }
.wine{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; }
.wine h4{ font-size:20px; display:flex; align-items:baseline; gap:10px; }
.wine .tag{ font-family:var(--font-body); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.wine p{ font-size:14px; color:var(--muted); margin:.6em 0 0; }

/* ---------- Stylized map (route) ---------- */
.mapwrap{ position:relative; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--bg-alt); box-shadow:var(--shadow); }
.mapwrap svg{ display:block; width:100%; height:auto; }
.map-water{ fill:color-mix(in srgb, var(--teal) 18%, var(--bg)); }
[data-treatment="nocturne"] .map-water{ fill:color-mix(in srgb, var(--teal) 30%, var(--bg)); }
.map-land{ fill:var(--bg-alt); }
.map-coast{ fill:none; stroke:color-mix(in srgb, var(--teal) 55%, var(--bg)); stroke-width:1.5; }
.map-lake{ fill:color-mix(in srgb, var(--teal) 26%, var(--bg)); stroke:color-mix(in srgb, var(--teal) 55%, var(--bg)); stroke-width:1.2; }
.map-route{ fill:none; stroke-width:3; stroke-linecap:round; stroke-dasharray:2 9; opacity:.9; }
.map-route.r-bay{ stroke:var(--accent); }
.map-route.r-lov{ stroke:var(--accent-2); }
.map-route.r-coast{ stroke:#5B8C5A; }
.pin{ cursor:default; }
.pin circle{ stroke:var(--bg); stroke-width:2; transition:r .2s; }
.pin.stay circle{ fill:var(--navy); }
.pin.culture circle{ fill:var(--teal); }
.pin.food circle{ fill:var(--gold); }
.pin text{ font-family:var(--font-body); font-size:13px; font-weight:600; fill:var(--head); paint-order:stroke; stroke:var(--bg); stroke-width:3px; }
.pin:hover circle{ r:9; }
.map-legend{ display:flex; flex-wrap:wrap; gap:18px 28px; margin-top:22px; }
.map-legend .lg{ display:inline-flex; align-items:center; gap:9px; font-size:13px; color:var(--ink); }
.map-legend .sw{ width:14px; height:14px; border-radius:50%; }
.map-legend .sw.line{ width:22px; height:3px; border-radius:2px; }

/* ---------- Links, booking, route maps ---------- */
a.lk{ color:var(--accent); border-bottom:1px solid color-mix(in srgb, var(--accent) 45%, transparent); transition:border-color .25s, color .25s; }
a.lk:hover{ color:var(--head); border-bottom-color:var(--head); }
a.lk .ext{ font-size:.78em; opacity:.7; }
.reserve-tag{ display:inline-block; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-2); border:1px solid color-mix(in srgb, var(--accent-2) 55%, transparent); border-radius:999px; padding:3px 9px; white-space:nowrap; }

.routemap{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-bottom:26px; }
.routemap .rm-head{ display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:8px 18px; padding:20px 24px 14px; }
.routemap .rm-head h3{ font-size:23px; }
.routemap .rm-head .rm-meta{ font-size:13px; color:var(--muted); letter-spacing:.03em; }
.map-embed{ width:100%; height:360px; border:0; display:block; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--bg-alt); }
.rm-foot{ padding:16px 24px 22px; display:flex; flex-wrap:wrap; align-items:center; gap:14px 22px; }
.wp-chips{ display:flex; flex-wrap:wrap; gap:7px; flex:1; min-width:200px; }
.wp{ font-size:12px; color:var(--ink); background:var(--bg-alt); border:1px solid var(--line); border-radius:999px; padding:5px 11px; }
.wp.start{ border-color:var(--accent); color:var(--accent); }

.book-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.book{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:22px; display:flex; flex-direction:column; gap:10px; }
.book .bk-when{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-2); }
.book h3{ font-size:20px; }
.book p{ font-size:14px; color:var(--muted); margin:0; flex:1; }
.book .bk-links{ display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.bk-btn{ font-size:13px; font-weight:600; color:var(--accent); border:1.5px solid color-mix(in srgb,var(--accent) 40%,transparent); border-radius:999px; padding:7px 14px; transition:.25s; }
.bk-btn:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .day-content{ grid-template-columns:1fr; }
  .day-aside{ flex-direction:row; }
  .day-aside .ph{ flex:1.4; }
}
@media (max-width:900px){
  .pillars{ grid-template-columns:1fr 1fr; }
  .timeline{ grid-template-columns:repeat(2,1fr); gap:26px 18px; }
  .split{ grid-template-columns:1fr; gap:28px; }
  .split.flip .split-media{ order:0; }
  .stay-grid{ grid-template-columns:1fr; }
  .band .wrap{ grid-template-columns:1fr 1fr; gap:34px 24px; }
  .foot-inner{ grid-template-columns:1fr; }
  .two-col-text{ columns:1; }
}
@media (max-width:760px){
  body{ font-size:16px; }
  .nav{ position:fixed; inset:64px 0 auto 0; flex-direction:column; align-items:flex-start;
    background:var(--bg); border-bottom:1px solid var(--line); padding:18px var(--pad);
    gap:6px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:.3s var(--ease); }
  .nav-open .nav{ transform:none; opacity:1; pointer-events:auto; }
  .nav-toggle{ display:flex; }
  .nav-link{ font-size:17px; padding:8px 0; }
  .day-aside{ flex-direction:column; }
  .slot{ grid-template-columns:1fr; gap:6px; }
  .slot .when{ padding-top:0; }
}
@media (max-width:900px){
  .menu{ grid-template-columns:1fr; }
  .cal-totals{ grid-template-columns:1fr 1fr; }
}
@media (max-width:1180px) and (min-width:701px){
  .cal-scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; margin:0 calc(-1*var(--pad)); padding:4px var(--pad) 14px; }
  .cal{ grid-template-columns:repeat(7,minmax(210px,1fr)); width:max-content; min-width:100%; }
}
@media (max-width:700px){
  .cal{ grid-template-columns:1fr; }
}
@media (max-width:540px){
  .pillars{ grid-template-columns:1fr; }
  .timeline{ grid-template-columns:1fr; }
  .band .wrap{ grid-template-columns:1fr; }
  .hero-stats{ gap:18px 32px; }
  .treatment-switch{ right:10px; bottom:10px; padding:9px 10px; }
  .acc .kv{ grid-template-columns:1fr; gap:2px 0; }
  .acc summary{ font-size:18px; padding:16px 18px; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  .reveal{ opacity:1; transform:none; }
}
