/* ============================================================================
   PartyTraveling.com — template.css
   Dark / neon system ported from the Claude Design board.
   Base #0a0a0e · accent purple #9D6BFF · secondary cyan #21E6C8
   Fonts: Space Grotesk (display + numbers), Hanken Grotesk (body), Space Mono (labels/sources)
   ============================================================================ */

:root{
  --pt-bg:#0a0a0e;
  --pt-bg-2:#0d0d12;
  --pt-panel:#101015;
  --pt-panel-2:#13131a;
  --pt-panel-3:#15151c;
  --pt-line:#1f1f29;
  --pt-line-2:#2a2a33;
  --pt-purple:#9D6BFF;
  --pt-purple-deep:#6C2BD0;
  --pt-purple-soft:#C9B6FF;
  --pt-cyan:#21E6C8;
  --pt-ink:#F3F1F8;
  --pt-ink-2:#E4E2EC;
  --pt-mut:#C9C7D4;
  --pt-mut-2:#9794A6;
  --pt-mut-3:#6E6B7E;
  --pt-mut-4:#56535f;
  --pt-radius:16px;
  --pt-radius-sm:10px;
  --pt-maxw:1200px;
  --pt-display:'Space Grotesk',sans-serif;
  --pt-body:'Hanken Grotesk',sans-serif;
  --pt-mono:'Space Mono',monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
/* Custom dark scrollbar (replaces the default gray on the dark theme) */
html{scrollbar-color:var(--pt-purple) var(--pt-bg-2);scrollbar-width:thin}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--pt-bg-2)}
::-webkit-scrollbar-thumb{background:var(--pt-purple-deep);border-radius:8px;border:3px solid var(--pt-bg-2)}
::-webkit-scrollbar-thumb:hover{background:var(--pt-purple)}
::-webkit-scrollbar-corner{background:var(--pt-bg-2)}
body.pt-site{
  background:var(--pt-bg);
  color:var(--pt-mut);
  font-family:var(--pt-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--pt-purple);color:var(--pt-bg)}
img{max-width:100%;height:auto;display:block}
a{color:var(--pt-purple-soft);text-decoration:none}
a:hover{color:var(--pt-purple)}

.pt-container{max-width:var(--pt-maxw);margin:0 auto;padding:0 24px;width:100%}
.pt-skip-link{position:absolute;left:-9999px}
.pt-skip-link:focus{left:16px;top:16px;z-index:200;background:var(--pt-purple);color:#fff;padding:10px 16px;border-radius:8px}

/* grain texture used on hero blocks */
.pt-grain::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}

/* ── Header ─────────────────────────────────────────────────────────────── */
.pt-header{position:sticky;top:0;z-index:100;background:rgba(10,10,14,.72);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--pt-line)}
.pt-header.is-scrolled{background:rgba(10,10,14,.92);border-bottom-color:var(--pt-line-2)}
.pt-header__inner{max-width:var(--pt-maxw);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.pt-brand{display:flex;align-items:center;gap:11px}
.pt-brand__dot{width:9px;height:9px;border-radius:50%;background:var(--pt-purple);box-shadow:0 0 0 4px rgba(157,107,255,.18)}
.pt-brand__word{font-family:var(--pt-display);font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--pt-ink)}
.pt-brand__accent{color:var(--pt-purple)}
.pt-nav{display:flex;align-items:center;gap:26px}
.pt-nav a{font-size:14.5px;font-weight:600;color:var(--pt-mut)}
.pt-nav a:hover{color:var(--pt-ink)}
.pt-nav a.pt-nav__muted{color:var(--pt-mut-3)}
.pt-nav a.pt-nav__muted:hover{color:var(--pt-mut)}
.pt-nav a.pt-nav__random{background:var(--pt-purple);color:#0a0a0e;padding:7px 14px;border-radius:8px;font-weight:700;letter-spacing:.02em}
.pt-nav a.pt-nav__random:hover{background:#ad80ff;color:#0a0a0e}

/* ── Layout shells ──────────────────────────────────────────────────────── */
.pt-main{padding:0}
.pt-breadcrumbs{padding:18px 0 0;font-family:var(--pt-mono);font-size:12px;color:var(--pt-mut-3)}
.pt-breadcrumbs a{color:var(--pt-mut-2)}
.pt-grid{display:grid;grid-template-columns:1fr 320px;gap:40px}
.pt-content main{padding:0}

/* ── Typographic primitives ─────────────────────────────────────────────── */
.pt-eyebrow{font-family:var(--pt-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--pt-mut-3)}
h1,h2,h3,h4{font-family:var(--pt-display);color:var(--pt-ink);letter-spacing:-.02em;line-height:1.1;margin:0 0 .5em}
h1{font-size:clamp(34px,6vw,64px);font-weight:700}
h2{font-size:clamp(26px,4vw,40px);font-weight:700}
h3{font-size:22px;font-weight:700}
.pt-accent{color:var(--pt-purple)}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.pt-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--pt-body);font-weight:700;font-size:14.5px;
  padding:13px 22px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:transform .12s ease,background .12s ease}
.pt-btn:hover{transform:translateY(-1px)}
.pt-btn--primary{background:var(--pt-purple);color:#0a0a0e}
.pt-btn--primary:hover{background:#ad80ff;color:#0a0a0e}
.pt-btn--ghost{background:transparent;border-color:var(--pt-line-2);color:var(--pt-ink)}
.pt-btn--ghost:hover{border-color:var(--pt-purple);color:#fff}
.pt-btn--cyan{background:var(--pt-cyan);color:#04201b}
.pt-btn--block{display:flex;width:100%;justify-content:center}

/* ── Tier badges (Claude Design "spotlight" set) ────────────────────────────
   Glassy dark pill + a 3-bar "laser" marker whose lit colours encode the tier:
   T1 = three purple bars (most prestigious) · T2 = two cyan + faint · T3 = one + faint. */
.pt-tier{display:inline-flex;align-items:center;gap:9px;font-family:var(--pt-mono);font-size:11px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:#F3F1F8;padding:7px 13px;border-radius:8px;
  background:rgba(10,10,14,.55);border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.pt-tier::before{content:"";flex:none;width:18px;height:11px;border-radius:1.5px;
  background:linear-gradient(90deg,var(--l1) 0 4px,transparent 4px 7px,var(--l2) 7px 11px,transparent 11px 14px,var(--l3) 14px 18px)}
.pt-tier--sm{font-size:9px;gap:6px;padding:4px 8px;border-radius:6px}
.pt-tier--sm::before{width:13px;height:8px;
  background:linear-gradient(90deg,var(--l1) 0 3px,transparent 3px 5px,var(--l2) 5px 8px,transparent 8px 10px,var(--l3) 10px 13px)}
.pt-tier--1{--l1:#9D6BFF;--l2:#9D6BFF;--l3:#9D6BFF;border-color:rgba(157,107,255,.55)}
.pt-tier--2{--l1:#21E6C8;--l2:#21E6C8;--l3:rgba(255,255,255,.22);border-color:rgba(33,230,200,.5)}
.pt-tier--3{--l1:#B49CFF;--l2:rgba(255,255,255,.22);--l3:rgba(255,255,255,.22);border-color:rgba(255,255,255,.2)}

/* ── Stat block (the trust signature) ───────────────────────────────────── */
.pt-stat{display:flex;flex-direction:column;gap:2px}
.pt-stat__num{font-family:var(--pt-display);font-weight:700;font-size:clamp(30px,4vw,44px);color:var(--pt-ink);letter-spacing:-.03em;line-height:1}
.pt-stat__num .pt-stat__unit{font-size:.5em;color:var(--pt-mut-2);font-weight:600;margin-left:.25em}
.pt-stat__label{font-size:13px;color:var(--pt-mut-2)}
.pt-stat__src{font-family:var(--pt-mono);font-size:10.5px;letter-spacing:.04em;color:var(--pt-mut-3);margin-top:6px}
.pt-stat__src::before{content:"◦ "}

/* ── Destination / tier hero ────────────────────────────────────────────── */
.pt-dhero{position:relative;border-radius:var(--pt-radius);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;margin:24px 0 0}
.pt-dhero__bg{position:absolute;inset:0;z-index:0}
.pt-dhero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,14,.15),rgba(10,10,14,.82))}
.pt-dhero__inner{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.pt-dhero__meta{max-width:62%}
.pt-dhero__country{font-family:var(--pt-mono);font-size:12px;letter-spacing:.1em;color:var(--pt-mut);text-transform:uppercase;margin-top:8px}
.pt-dhero__title{font-size:clamp(40px,7vw,76px);margin:8px 0 0;color:#fff}
.pt-dhero__statcard{background:rgba(13,13,18,.66);backdrop-filter:blur(8px);border:1px solid rgba(157,107,255,.3);border-radius:14px;padding:18px 22px}
.pt-photo-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--pt-mono);font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.55);text-transform:uppercase}
/* Real country flag, CLIPPED INTO A FIVE-POINTED STAR, pinned top-right.
   Unambiguous (a tricolour chevron read as France; a real flag does not) and
   distinctive via the star clip. Flag SVGs: images/flags/{iso}.svg (flag-icons). */
/* Real flag clipped into a 5-point star. The flag SVGs are 4:3; using a square
   box with object-fit:cover center-crops the sides so the star's wide points
   (2%/98% x) can land on cropped pixels. Fix: make the box itself 4:3 so cover
   shows the whole flag width, and the star polygon clips within it. */
.pt-flag{position:absolute;z-index:4;right:16px;top:14px;width:64px;height:48px;object-fit:cover;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.55));
  clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.pt-card__hero{position:relative}
.pt-flag--sm{width:48px;height:36px;right:12px;top:10px}

/* ── Cards & grids ──────────────────────────────────────────────────────── */
.pt-cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:26px 0}
.pt-cardgrid--2{grid-template-columns:repeat(2,1fr)}
.pt-card{position:relative;border-radius:var(--pt-radius);overflow:hidden;background:var(--pt-panel);border:1px solid var(--pt-line);display:flex;flex-direction:column;min-height:230px;transition:transform .14s ease,border-color .14s ease}
.pt-card:hover{transform:translateY(-3px);border-color:var(--pt-line-2)}
.pt-card__hero{position:relative;min-height:128px;padding:16px;display:flex;align-items:flex-start;justify-content:space-between}
.pt-card__hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,14,.1),rgba(10,10,14,.7))}
.pt-card__hero > *{position:relative;z-index:1}
.pt-card__body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:4px;flex:1}
.pt-card__name{font-family:var(--pt-display);font-weight:700;font-size:20px;color:#fff;margin:0}
.pt-card__sub{font-size:12.5px;color:var(--pt-mut-2)}
.pt-card__stat{margin-top:auto;padding-top:12px}
.pt-card__statnum{font-family:var(--pt-display);font-weight:700;font-size:26px;color:var(--pt-ink);letter-spacing:-.02em;line-height:1}
.pt-card__statlabel{font-size:11.5px;color:var(--pt-mut-2);margin-top:2px}
.pt-card__src{font-family:var(--pt-mono);font-size:10px;color:var(--pt-mut-3);margin-top:5px}
.pt-card__anchor{margin-top:auto;padding-top:12px;font-family:var(--pt-mono);font-size:11px;color:var(--pt-cyan);letter-spacing:.03em}

/* ── "By the numbers" festival strip ────────────────────────────────────── */
.pt-numbers{background:var(--pt-panel);border:1px solid var(--pt-line);border-radius:var(--pt-radius);padding:34px;margin:30px 0}
.pt-numbers__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:24px}
.pt-numbers__item{display:block;border-left:2px solid rgba(157,107,255,.4);padding-left:14px;text-decoration:none;transition:border-color .14s ease}
.pt-numbers__item:hover{border-left-color:var(--pt-cyan)}
.pt-numbers__item:hover .pt-numbers__num{color:var(--pt-cyan)}
.pt-numbers__num{font-family:var(--pt-display);font-weight:700;font-size:30px;color:#fff;letter-spacing:-.02em;line-height:1}
.pt-numbers__num.is-cyan{color:var(--pt-cyan)}
.pt-numbers__label{font-size:12px;color:var(--pt-mut-2);margin-top:4px}
.pt-numbers__src{font-family:var(--pt-mono);font-size:9.5px;color:var(--pt-mut-3);margin-top:4px}

/* ── Front-page sections ────────────────────────────────────────────────── */
.pt-fp-hero{position:relative;overflow:hidden;padding:88px 0 72px}
.pt-fp-hero__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(1100px 520px at 72% 18%,rgba(108,43,208,.42),transparent 60%),radial-gradient(700px 420px at 10% 90%,rgba(33,230,200,.12),transparent 60%)}
.pt-fp-hero__inner{position:relative;z-index:1;max-width:var(--pt-maxw);margin:0 auto;padding:0 24px}
.pt-fp-hero h1{max-width:14ch}
.pt-fp-hero__lede{font-size:18px;color:var(--pt-mut);max-width:54ch;margin:18px 0 28px}
.pt-fp-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.pt-section{padding:54px 0}
.pt-section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:6px}
.pt-section__head h2{margin-bottom:0}
.pt-section__link{font-family:var(--pt-mono);font-size:12px;color:var(--pt-mut-2)}
.pt-lede{color:var(--pt-mut-2);max-width:62ch;margin:0 0 8px}

/* tier gateways */
.pt-gateways{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
.pt-gateway{position:relative;overflow:hidden;border-radius:var(--pt-radius);padding:30px;min-height:200px;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--pt-line)}
.pt-gateway--islands{background:linear-gradient(135deg,rgba(33,230,200,.18),#0f2f3a)}
.pt-gateway--cities{background:linear-gradient(135deg,rgba(123,92,255,.2),#23123f)}
.pt-gateway .pt-tier{margin-bottom:16px}
.pt-gateway h3{font-size:26px;margin-bottom:8px}
.pt-gateway p{color:var(--pt-mut);font-size:14px;margin:0}

/* trust band */
.pt-trust{background:linear-gradient(135deg,rgba(123,92,255,.1),var(--pt-panel));border:1px solid rgba(157,107,255,.22);border-radius:var(--pt-radius);padding:34px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;margin:30px 0}
.pt-trust__copy{max-width:52ch}
.pt-trust__copy h2{font-size:28px}
.pt-trust__stats{display:flex;gap:34px}
.pt-trust__stat .pt-trust__n{font-family:var(--pt-display);font-weight:700;font-size:40px;color:var(--pt-purple)}
.pt-trust__stat .pt-trust__l{font-family:var(--pt-mono);font-size:11px;color:var(--pt-mut-3);text-transform:uppercase;letter-spacing:.08em}

/* ── Destination article body ───────────────────────────────────────────── */
.pt-article{max-width:860px;margin:0 auto}
.pt-article h2{font-size:30px;margin-top:48px}
.pt-article h3{margin-top:30px}
.pt-article p{color:var(--pt-mut);margin:0 0 16px}
.pt-article ul{color:var(--pt-mut);padding-left:20px}
.pt-article li{margin-bottom:8px}
.pt-article strong{color:var(--pt-ink-2)}
.pt-lead-intro{font-size:19px;color:var(--pt-ink-2);line-height:1.6}

/* venue chips / party scene */
.pt-venues{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0}
.pt-venue{position:relative;background:var(--pt-panel);border:1px solid var(--pt-line);border-radius:12px;padding:16px;min-height:90px;display:flex;flex-direction:column;justify-content:flex-end;transition:border-color .14s ease,transform .14s ease;text-decoration:none}
.pt-venue:hover{border-color:var(--pt-purple);transform:translateY(-2px)}
.pt-venue__name{font-family:var(--pt-display);font-weight:700;color:#fff;font-size:16px}
.pt-venue__tag{font-family:var(--pt-mono);font-size:10px;color:var(--pt-cyan);letter-spacing:.06em;text-transform:uppercase}
.pt-venue__ta{font-family:var(--pt-mono);font-size:10px;color:var(--pt-mut-3);margin-top:6px;letter-spacing:.04em;opacity:0;transition:opacity .14s ease}
.pt-venue:hover .pt-venue__ta{opacity:1}

/* when to go bar */
.pt-season{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;margin:18px 0}
.pt-season__m{text-align:center;font-family:var(--pt-mono);font-size:10px;color:var(--pt-mut-3);padding:10px 0;border-radius:7px;background:var(--pt-panel-2);border:1px solid var(--pt-line)}
.pt-season__m.is-peak{background:var(--pt-purple);color:#0a0a0e;border-color:var(--pt-purple);font-weight:700}
.pt-season__m.is-shoulder{background:rgba(157,107,255,.22);color:var(--pt-purple-soft);border-color:rgba(157,107,255,.3)}

/* ── Stay22 / booking block (conversion unit) ───────────────────────────── */
.pt-stay{background:linear-gradient(135deg,rgba(123,92,255,.1),var(--pt-panel));border:1px solid rgba(157,107,255,.28);border-radius:var(--pt-radius);padding:30px;margin:34px 0}
.pt-stay__head{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:8px}
.pt-stay__head h2{margin:0;font-size:26px}
.pt-stay__sub{color:var(--pt-mut-2);font-size:14px;margin:0 0 18px}
.pt-stay__grid{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
.pt-stay__embed{min-height:300px;border-radius:12px;border:1px solid var(--pt-line);overflow:hidden;background:var(--pt-panel-2)}
.pt-stay__embed iframe{width:100%;height:100%;min-height:300px;border:0;display:block}
.pt-stay__list{display:flex;flex-direction:column;gap:12px}
.pt-stay__opt{display:flex;align-items:center;gap:14px;background:var(--pt-panel);border:1px solid var(--pt-line);border-radius:12px;padding:14px}
.pt-stay__opt:hover{border-color:var(--pt-purple)}
/* live Stay22 hotel cards (real image + name + rating + reviews), 4 per row */
.pt-hotels{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:20px}
.pt-hotel{display:flex;flex-direction:column;background:var(--pt-panel);border:1px solid var(--pt-line);border-radius:12px;overflow:hidden;text-decoration:none;transition:transform .14s ease,border-color .14s ease}
.pt-hotel:hover{transform:translateY(-3px);border-color:var(--pt-purple)}
.pt-hotel__photo{position:relative;aspect-ratio:16/10;background:var(--pt-panel-2);overflow:hidden}
.pt-hotel__img{width:100%;height:100%;object-fit:cover;display:block}
.pt-hotel__plabel{position:absolute;left:8px;top:8px;font-family:var(--pt-mono);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0a0a0e;background:var(--pt-purple);padding:2px 7px;border-radius:5px}
.pt-hotel__body{padding:12px 13px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.pt-hotel__name{font-family:var(--pt-display);font-weight:600;color:#fff;font-size:14px;line-height:1.25}
.pt-hotel__foot{margin-top:auto;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:11.5px;color:var(--pt-mut-2)}
.pt-hotel__rating{color:var(--pt-cyan);font-weight:700}
.pt-hotel__reviews{color:var(--pt-mut-3)}
.pt-hotel__view{margin-left:auto;color:var(--pt-purple-soft);font-weight:600}
@media (max-width:900px){.pt-hotels{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.pt-hotels{grid-template-columns:1fr}}
.pt-stay__optswatch{width:46px;height:46px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center}
.pt-stay__optswatch svg{width:22px;height:22px;opacity:.95}
.pt-stay__optname{font-family:var(--pt-display);font-weight:600;color:#fff;font-size:15px}
.pt-stay__optsub{font-size:12px;color:var(--pt-mut-2)}

/* getting there / OTA CTAs — whole card is the link; icon badge + accent + arrow CTA */
.pt-otas{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0}
.pt-ota{position:relative;background:var(--pt-panel);border:1px solid var(--pt-line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:8px;text-decoration:none;overflow:hidden;transition:transform .14s ease,border-color .14s ease,background .14s ease}
.pt-ota::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--pt-purple);opacity:.85}
.pt-ota:hover{transform:translateY(-3px);border-color:var(--pt-purple);background:#13131b}
.pt-ota__ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(157,107,255,.14);color:var(--pt-purple);margin-bottom:4px}
.pt-ota__ico svg{width:22px;height:22px}
.pt-ota__label{font-family:var(--pt-mono);font-size:10px;color:var(--pt-mut-3);letter-spacing:.12em;text-transform:uppercase}
.pt-ota__title{font-family:var(--pt-display);font-weight:600;color:#fff;font-size:16.5px;line-height:1.25}
.pt-ota__cta{margin-top:auto;padding-top:10px;font-family:var(--pt-body);font-weight:700;font-size:13.5px;color:var(--pt-purple-soft);transition:color .14s ease}
.pt-ota:hover .pt-ota__cta{color:var(--pt-purple)}
/* per-channel accent: flights purple, hotels cyan, experiences pink-safe (ink) */
.pt-ota--hotels::before{background:var(--pt-cyan)}
.pt-ota--hotels .pt-ota__ico{background:rgba(33,230,200,.14);color:var(--pt-cyan)}
.pt-ota--hotels .pt-ota__cta{color:var(--pt-cyan)}
.pt-ota--exp::before{background:#B49CFF}
.pt-ota--exp .pt-ota__ico{background:rgba(180,156,255,.16);color:#C9B6FF}
.pt-ota--photos::before{background:var(--pt-mut-2)}
.pt-ota--photos .pt-ota__ico{background:rgba(151,148,166,.14);color:var(--pt-mut)}
.pt-ota--photos .pt-ota__cta{color:var(--pt-mut)}

/* "See images of {dest}" link under the hero (Google Images) */
.pt-seeimages{display:inline-flex;align-items:center;gap:9px;margin:18px 0 0;font-weight:600;font-size:15px;color:var(--pt-purple-soft);border-bottom:1px solid rgba(157,107,255,.4);padding-bottom:3px;padding-left:9px}
.pt-seeimages:hover{color:var(--pt-purple);border-bottom-color:var(--pt-purple)}

/* ── Kayak AI planner ───────────────────────────────────────────────────── */
.pt-planner{background:linear-gradient(135deg,rgba(33,230,200,.08),var(--pt-panel));border:1px solid rgba(33,230,200,.25);border-radius:var(--pt-radius);padding:30px;margin:34px 0}
.pt-planner h2{margin:0 0 4px;font-size:24px}
.pt-planner__form{display:flex;flex-direction:column;gap:14px;margin:18px 0}
.pt-planner__row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.pt-planner__label{font-family:var(--pt-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--pt-mut-2);min-width:96px}
.pt-planner__opts{display:flex;flex-wrap:wrap;gap:8px}
.pt-planner__opt{font-family:var(--pt-body);font-size:13px;font-weight:600;color:var(--pt-mut);background:var(--pt-panel-2);border:1px solid var(--pt-line);border-radius:8px;padding:7px 13px;cursor:pointer;transition:all .12s ease}
.pt-planner__opt:hover{border-color:var(--pt-line-2);color:#fff}
.pt-planner__opt.active{background:var(--pt-cyan);border-color:var(--pt-cyan);color:#04201b}
.pt-planner__preview{width:100%;background:var(--pt-bg);border:1px solid var(--pt-line);border-radius:10px;color:var(--pt-mut);font-family:var(--pt-mono);font-size:12.5px;line-height:1.6;padding:14px;resize:vertical}
.pt-planner__actions{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.pt-planner__copy.copied{background:var(--pt-cyan);color:#04201b}

/* ── "Next / Surprise me" CTA ───────────────────────────────────────────── */
.pt-nextcta{border-top:1px solid var(--pt-line-2);margin-top:44px;padding-top:28px}
.pt-nextcta__kicker{font-family:var(--pt-display);font-weight:700;font-size:20px;color:var(--pt-ink);margin:0 0 14px}
.pt-nextcta__btns{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pt-nextcta__btns .pt-btn{width:100%;justify-content:center}
@media (max-width:560px){.pt-nextcta__btns{grid-template-columns:1fr}}

/* affiliate disclosure inline */
.pt-disclose{font-family:var(--pt-mono);font-size:11px;color:var(--pt-mut-3);border-top:1px solid var(--pt-line);padding-top:16px;margin-top:30px}

/* related */
.pt-related{margin-top:48px}

/* ── Footer (GOA skeleton, PT dark theme) ──────────────────────────────────
   Region nav row (full width) + 2-col inner grid: brand+nav left / legal right.
   Accent top border, divider above inner grid, single-column centred on mobile. */
.pt-footer{background:var(--pt-bg-2);color:var(--pt-mut-2);border-top:3px solid var(--pt-purple);margin-top:60px;padding:32px 0 20px}
.pt-footer__container{max-width:var(--pt-maxw);margin:0 auto;padding:0 24px}
/* region nav row (centered) */
.pt-footer-regions{line-height:1.7;font-size:13.5px;text-align:center}
.pt-footer-regions__label{font-family:var(--pt-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--pt-mut-3);margin-right:12px}
.pt-footer-regions a{color:var(--pt-mut)}
.pt-footer-regions a:hover{color:#fff}
.pt-footer-regions a + a{margin-left:12px;padding-left:12px;border-left:1px solid var(--pt-line-2)}
/* 2-col inner grid: legal (wide) left, brand (narrow) right */
.pt-footer__inner{display:grid;grid-template-columns:minmax(0,2fr) minmax(220px,1fr);gap:2.5rem;align-items:start;
  padding-top:2rem;margin-top:1.5rem;border-top:1px solid var(--pt-line);text-align:left}
.pt-footer__brand-col{display:flex;flex-direction:column;gap:.85rem;align-items:center;justify-content:center;text-align:center}
.pt-footer__brand{display:flex;align-items:center;gap:11px}
.pt-footer-nav{font-size:13.5px;margin:0}
.pt-footer-nav a{color:var(--pt-mut);padding-left:14px}
.pt-footer-nav a:first-child{padding-left:0}
.pt-footer-nav a:hover{color:#fff}
.pt-footer__legal{display:flex;flex-direction:column;justify-content:flex-start;gap:12px}
.pt-footer__disclaimer{font-size:12.5px;color:var(--pt-mut-3);line-height:1.7;margin:0;max-width:88ch}
.pt-footer__earn{font-size:12.5px;color:var(--pt-mut-3)}
.pt-footer__earn::before{content:" · "}
.pt-footer__earn a{color:var(--pt-purple);font-weight:600}
.pt-footer__earn a:hover{color:var(--pt-purple-soft)}
@media (max-width:700px){
  .pt-footer__inner{grid-template-columns:1fr;gap:1.5rem;padding-top:1.5rem;justify-items:center;text-align:center}
  .pt-footer__brand-col{align-items:center}
  .pt-footer-regions{text-align:center}
  .pt-footer__disclaimer{margin-left:auto;margin-right:auto}
}

/* ── Back to top ────────────────────────────────────────────────────────── */
.pt-backtop{position:fixed;right:22px;bottom:22px;width:44px;height:44px;border-radius:50%;border:1px solid var(--pt-line-2);background:var(--pt-purple);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:90;cursor:pointer}
.pt-backtop.is-visible{opacity:1;pointer-events:auto}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width:900px){
  .pt-grid{grid-template-columns:1fr}
  .pt-cardgrid,.pt-numbers__grid,.pt-venues,.pt-otas{grid-template-columns:repeat(2,1fr)}
  .pt-gateways{grid-template-columns:1fr}
  .pt-stay__grid{grid-template-columns:1fr}
  .pt-trust{flex-direction:column;align-items:flex-start}
}
@media (max-width:640px){
  .pt-nav{gap:14px;font-size:13px}
  .pt-nav a{font-size:13px}
  .pt-header__inner{flex-wrap:wrap;gap:12px}
  .pt-cardgrid,.pt-numbers__grid,.pt-venues,.pt-otas,.pt-season{grid-template-columns:repeat(2,1fr)}
  .pt-season{grid-template-columns:repeat(6,1fr)}
  .pt-dhero__meta{max-width:100%}
  .pt-fp-hero{padding:56px 0 48px}
  .pt-trust__stats{gap:22px}
}
