/* ============================================================
   CONTEMPORARY TRAVELS — brand.css
   Single source of truth. Matches production: Fraunces opsz 9,
   ink/paper/coral palette, • dot wordmark, globe motif.
   ============================================================ */

:root{
  --ink:#0A0A0A; --ink-soft:#14182a; --bg:#FAFAF7; --paper:#F5F1E8;
  --coral:#E8693E; --coral-deep:#cf5630; --gold:#C9A14B;
  --muted:#666666; --muted-light:#9a978f; --rule:#E6E3DC;
  --teal:#1a9b8e;
  --maxw:1180px;
  --ct-nav-h:73px;
  --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{padding-top:var(--ct-nav-h);font-family:'Instrument Sans',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
html{overflow-y:scroll}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--coral);color:var(--paper)}

/* ---- Wordmark ---- */
.logo{font-family:'Fraunces',serif;font-variation-settings:'opsz' 9;font-weight:500;letter-spacing:-.02em;
  white-space:nowrap;display:inline-flex;align-items:baseline;gap:.4rem}
.logo em{font-style:italic;font-weight:400;letter-spacing:-.01em}
.logo b{font-weight:500;letter-spacing:.15em;font-style:normal}
.logo i{font-style:normal;color:var(--coral);font-weight:600;font-size:1.05em;margin:0 .04em;
  text-shadow:0 0 12px rgba(232,105,62,.4)}

/* ---- Type helpers ---- */
.serif{font-family:'Fraunces',serif;font-variation-settings:'opsz' 9}
.serif-it{font-family:'Fraunces',serif;font-variation-settings:'opsz' 9;font-style:italic}
.inst-serif{font-family:'Instrument Serif',serif}
h1,h2,h3{font-family:'Fraunces',serif;font-variation-settings:'opsz' 9;font-weight:300;letter-spacing:-.02em;line-height:1.04}
.eyebrow{font-size:.78rem;letter-spacing:3px;text-transform:uppercase;color:var(--coral);font-weight:600}

/* ---- Nav ---- */
nav.top{position:fixed;top:0;left:0;right:0;width:100%;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:1.05rem 2rem;background:rgba(250,250,247,.82);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule)}
nav.top.on-dark{background:rgba(10,10,10,.6);border-bottom-color:rgba(245,241,232,.12)}
nav.top .logo{font-size:1.22rem;color:var(--ink)}
nav.top.on-dark .logo{color:var(--paper)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--ink);opacity:.8;transition:opacity .2s}
.nav-links a:hover{opacity:1}
nav.top.on-dark .nav-links a{color:var(--paper)}
.nav-cta{font-size:.9rem;font-weight:600;padding:.6rem 1.4rem;border:1px solid var(--ink);border-radius:100px;transition:all .2s}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
nav.top.on-dark .nav-cta{border-color:var(--coral);background:var(--coral);color:var(--paper)}
nav.top.on-dark .nav-cta:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.nav-toggle,.mobile-concierge-btn{display:none;background:none;border:1px solid transparent;cursor:pointer;font-size:1.5rem;color:inherit}
.mobile-concierge-btn{align-items:center;justify-content:center}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-weight:600;font-size:1rem;
  padding:.95rem 1.9rem;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:all .25s var(--ease)}
.btn-coral{background:var(--coral);color:var(--paper)}
.btn-coral:hover{background:var(--ink);transform:translateY(-2px)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:var(--coral)}
.btn-outline{border-color:currentColor}
.btn-outline:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-ghost-light{border:1px solid rgba(245,241,232,.3);color:var(--paper)}
.btn-ghost-light:hover{background:var(--paper);color:var(--ink)}

/* ---- Layout ---- */
.section{max-width:var(--maxw);margin:0 auto;padding:5rem 2rem}
.section-sm{padding:3.5rem 2rem}
.section-head{margin-bottom:3rem}
.section-head h2{font-size:clamp(2.1rem,5vw,3.4rem);margin:.6rem 0 .8rem}
.section-head .sub{color:var(--muted);font-size:1.08rem;max-width:56ch}
.lede{font-size:1.15rem;line-height:1.6;color:var(--muted)}

/* ---- Globe motif (reusable SVG container) ---- */
.globe-bg{position:absolute;pointer-events:none;opacity:.5}

/* ---- Cards ---- */
.card{background:#fff;border:1px solid var(--rule);border-radius:14px;overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(10,10,10,.1)}
.card-photo{aspect-ratio:4/3;background:linear-gradient(135deg,#1a1a1a,#383838);position:relative;overflow:hidden}
.card-photo .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.28);font-size:.72rem;letter-spacing:2px}
.card-photo .tag{position:absolute;top:.9rem;left:.9rem;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--paper);background:rgba(10,10,10,.55);backdrop-filter:blur(6px);padding:.35rem .7rem;border-radius:100px}
.card-body{padding:1.5rem}
.card-body h3{font-weight:500;font-size:1.45rem;margin-bottom:.2rem}

/* ---- Footer ---- */
footer.ct{background:var(--ink);color:var(--muted-light);padding:4.5rem 2rem 2rem}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:2.5rem}
footer.ct .logo{font-size:1.3rem;color:var(--paper);margin-bottom:1rem}
footer.ct p.desc{font-size:.92rem;line-height:1.6;max-width:34ch}
footer.ct h5{font-family:'Instrument Serif',serif;font-style:italic;font-size:1.1rem;color:var(--paper);margin-bottom:1rem;font-weight:400}
footer.ct ul{list-style:none}
footer.ct li{margin-bottom:.55rem}
footer.ct a{font-size:.92rem;transition:color .2s}
footer.ct a:hover{color:var(--paper)}
.footer-mark{text-align:center;font-family:'Fraunces',serif;font-variation-settings:'opsz' 9;font-style:italic;
  font-size:2.8rem;color:var(--gold);opacity:.4;margin-top:3.5rem;letter-spacing:-.02em}
.footer-legal{text-align:center;font-size:.74rem;color:#555;margin-top:1.4rem;line-height:1.6}
.footer-bottom{max-width:var(--maxw);margin:1.8rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(245,241,232,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem}
.footer-bottom a{margin-right:1.4rem}

/* ---- Reveal on load ---- */
.reveal{opacity:0;transform:translateY(20px);animation:reveal .8s var(--ease) forwards}
@keyframes reveal{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.15s}.d3{animation-delay:.25s}.d4{animation-delay:.35s}.d5{animation-delay:.45s}

/* ---- Responsive ---- */
@media(max-width:900px){
  .footer-grid{grid-template-columns:1.4fr repeat(3,minmax(120px,1fr));gap:1.6rem}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.8rem}
  .footer-grid>div:first-child{grid-column:1/-1}
}
@media(max-width:760px){
  :root{--ct-nav-h:72px}
  nav.top{left:0;right:0;width:100%;min-height:72px;padding:.75rem 1rem;gap:.65rem}
  nav.top.on-dark{background:rgba(10,10,10,.6);border-bottom-color:rgba(245,241,232,.12)}
  nav.top .logo{font-size:1.06rem;line-height:1;max-width:calc(100vw - 132px);white-space:nowrap}
  nav.top .logo b{letter-spacing:.14em}
  .nav-links{position:fixed!important;inset:0!important;width:100%!important;max-width:none!important;z-index:300;display:flex!important;flex-direction:column;align-items:stretch;
    justify-content:flex-start;gap:.9rem;padding:5.1rem 1.35rem 2rem;background:var(--ink);overflow-y:auto;
    transform:translateX(100%);visibility:hidden;opacity:0;pointer-events:none;
    transition:transform .35s var(--ease),opacity .25s var(--ease),visibility .25s var(--ease);box-shadow:-20px 0 50px rgba(0,0,0,.4)}
  .nav-links.open{transform:translateX(0)!important;visibility:visible!important;opacity:1!important;pointer-events:auto!important}
  .nav-links a{color:var(--paper)!important;font-size:1.15rem;opacity:.95;padding:.45rem 0;min-height:48px;display:flex;align-items:center;border-bottom:1px solid rgba(245,241,232,.1)}
  .nav-links .concierge-btn{width:100%;justify-content:center;padding:.85rem 1.2rem;font-size:1rem;margin-top:.4rem}
  .nav-links .nav-cta{width:100%;text-align:center;padding:.95rem 1.2rem;font-size:1rem;background:var(--coral);color:var(--paper);border-color:var(--coral)}
  .mobile-concierge-btn,.nav-toggle{display:inline-flex;position:relative;z-index:101;width:48px;height:48px;min-width:48px;border-radius:12px;
    align-items:center;justify-content:center;background:var(--ink);color:var(--paper);box-shadow:0 12px 26px rgba(10,10,10,.18);
    font-size:1.2rem;line-height:1}
  .mobile-concierge-btn{margin-left:auto;color:var(--gold)}
  .nav-toggle{font-size:1.55rem}
  nav.top.on-dark .mobile-concierge-btn,nav.top.on-dark .nav-toggle{background:var(--ink);color:var(--paper)}
  nav.top.on-dark .mobile-concierge-btn{color:var(--gold)}
  .section{padding:3.5rem 1.4rem}
}
/* very narrow (fold folded / flip cover): keep nav drawer full-width, comfortable taps */
@media(max-width:380px){
  :root{--ct-nav-h:66px}
  .nav-links{width:100%;max-width:none;padding:4.8rem 1.2rem 2rem}
  nav.top{padding:.7rem .85rem;min-height:66px}
  nav.top .logo{font-size:.94rem;max-width:calc(100vw - 116px)}
  .mobile-concierge-btn,.nav-toggle{width:44px;height:44px;min-width:44px;border-radius:11px}
  .nav-toggle{font-size:1.45rem}
}
@media(max-width:560px){
  nav.top{padding:.95rem 1.25rem}
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   CONCIERGE AI — nav button + slide-in chat panel (global)
   ============================================================ */
.concierge-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;font-size:.9rem;font-weight:600;padding:.6rem 1.2rem;
  border:1px solid var(--coral);border-radius:100px;color:var(--coral);background:transparent;cursor:pointer;transition:all .2s;white-space:nowrap}
.concierge-btn .star{font-size:.9em}
.concierge-btn:hover,
.concierge-btn:active,
.concierge-btn:focus-visible{background:transparent;color:var(--coral);border-color:var(--coral);box-shadow:0 0 0 4px rgba(232,105,62,.16),0 0 28px rgba(232,105,62,.28);outline:none}
nav.top.on-dark .concierge-btn{border-color:var(--coral);color:var(--coral)}
nav.top.on-dark .concierge-btn:hover,
nav.top.on-dark .concierge-btn:active,
nav.top.on-dark .concierge-btn:focus-visible{background:transparent;color:var(--coral);border-color:var(--coral);box-shadow:0 0 0 4px rgba(232,105,62,.18),0 0 30px rgba(232,105,62,.32);outline:none}
nav.top .logo i,
nav.top .logo .logo-dot,
.logo i,
.logo .logo-dot,
nav.top .concierge-btn .star,
nav.top .mobile-concierge-btn,
.mobile-concierge-btn,
.concierge-btn .star{color:var(--coral)!important}
@media(min-width:761px){
  nav.top .concierge-btn{width:auto;height:auto;padding:.6rem 1.05rem;border-radius:999px;justify-content:center;align-items:center;gap:.45rem;font-size:.9rem;line-height:1;background:rgba(10,10,10,.04);border-color:rgba(10,10,10,.18)}
  nav.top .concierge-btn .star{display:block;font-size:.95rem;line-height:1;margin:0;transform:none}
  nav.top:not(.on-dark) .concierge-btn:hover,
  nav.top:not(.on-dark) .concierge-btn:active,
  nav.top:not(.on-dark) .concierge-btn:focus-visible{background:rgba(10,10,10,.04);border-color:var(--coral);color:var(--coral);box-shadow:0 0 0 4px rgba(232,105,62,.14),0 0 28px rgba(232,105,62,.28)}
  nav.top.on-dark .concierge-btn{background:rgba(245,241,232,.08);border-color:rgba(245,241,232,.24);color:var(--coral)}
  nav.top.on-dark .concierge-btn:hover,
  nav.top.on-dark .concierge-btn:active,
  nav.top.on-dark .concierge-btn:focus-visible{background:rgba(245,241,232,.08);border-color:var(--coral);color:var(--coral);box-shadow:0 0 0 4px rgba(232,105,62,.18),0 0 30px rgba(232,105,62,.32)}
}

nav.top:not(.on-dark) .mobile-concierge-btn,
nav.top:not(.on-dark) .nav-toggle{background:var(--ink);border-color:rgba(10,10,10,.2);color:var(--paper)}
nav.top.on-dark .mobile-concierge-btn,
nav.top.on-dark .nav-toggle{background:rgba(10,10,10,.78);border-color:rgba(245,241,232,.24);color:var(--paper)}

@media(min-width:761px){
  nav.top.country-top{display:flex;justify-content:center;padding-left:2rem;padding-right:2rem}
  nav.top.country-top .logo{position:absolute;left:2rem;top:50%;transform:translateY(-50%)}
  nav.top.country-top .nav-links{gap:2.3rem;justify-content:center}
  nav.top.country-top .nav-cta{position:absolute;right:2rem;top:50%;transform:translateY(-50%);background:var(--paper);color:var(--ink);border-color:var(--paper);padding:.78rem 1.25rem}
  nav.top.country-top .nav-cta::before{content:"✦";font-size:.78rem;color:var(--ink)}
}

/* Fixed-nav safety: body owns the offset, so hero media never bleeds under the nav. */
.c-hero,.cat-hero,.cr-hero,.pl-hero,.film-hero,.atlas-hero{scroll-margin-top:var(--ct-nav-h)}
.c-hero .tagline{display:block;margin-top:.8rem!important}
.ct-route-thread,
.ct-field-chip{display:none!important}

/* overlay + panel */
.cai-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,10,10,.55);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .3s}
.cai-overlay.open{opacity:1;visibility:visible}
.cai-panel{position:fixed;top:0;right:0;z-index:201;height:100dvh;width:440px;max-width:92vw;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s var(--ease);box-shadow:-20px 0 60px rgba(0,0,0,.4)}
.cai-panel.open{transform:translateX(0)}
.cai-top{display:flex;align-items:center;justify-content:space-between;padding:1.3rem 1.5rem;border-bottom:1px solid rgba(245,241,232,.1)}
.cai-top .cai-title{display:flex;align-items:center;gap:.5rem;font-size:.74rem;letter-spacing:2px;text-transform:uppercase;color:var(--coral);font-weight:600}
.cai-close{background:none;border:none;color:rgba(245,241,232,.6);font-size:1.4rem;cursor:pointer;line-height:1}
.cai-close:hover{color:var(--paper)}
.cai-intro{padding:1.5rem;border-bottom:1px solid rgba(245,241,232,.08)}
.cai-intro h3{font-family:'Fraunces',serif;font-variation-settings:'opsz' 9;font-weight:300;font-size:1.5rem;line-height:1.1;margin-bottom:.5rem}
.cai-intro h3 em{font-style:italic;color:var(--coral)}
.cai-intro p{font-size:.88rem;color:rgba(245,241,232,.6)}
.cai-thread{flex:1;overflow-y:auto;padding:1.2rem 1.5rem;display:flex;flex-direction:column;gap:.8rem}
.cai-suggest{display:flex;flex-direction:column;gap:.6rem}
.cai-chip{text-align:left;background:rgba(255,255,255,.05);border:1px solid rgba(245,241,232,.14);border-radius:12px;padding:.85rem 1rem;
  color:var(--paper);font:inherit;font-size:.92rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.6rem}
.cai-chip:hover{border-color:var(--coral);background:rgba(232,105,62,.1)}
.cai-chip .ar{color:var(--coral);margin-left:auto}
.cai-msg{max-width:88%;padding:.8rem 1rem;border-radius:14px;font-size:.92rem;line-height:1.5}
.cai-msg.user{align-self:flex-end;background:var(--coral);color:var(--paper);border-bottom-right-radius:4px}
.cai-msg.bot{align-self:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(245,241,232,.1);border-bottom-left-radius:4px}
.cai-msg.bot .typing{display:inline-flex;gap:.25rem}
.cai-msg.bot .typing span{width:6px;height:6px;border-radius:50%;background:var(--coral);opacity:.5;animation:caiblink 1.2s infinite}
.cai-msg.bot .typing span:nth-child(2){animation-delay:.2s}.cai-msg.bot .typing span:nth-child(3){animation-delay:.4s}
@keyframes caiblink{0%,60%,100%{opacity:.3}30%{opacity:1}}
.cai-input{padding:1rem 1.5rem 1.3rem;border-top:1px solid rgba(245,241,232,.1)}
.cai-input-box{display:flex;gap:.5rem;background:rgba(255,255,255,.08);border:1px solid rgba(245,241,232,.2);border-radius:100px;padding:.4rem .4rem .4rem 1.2rem;align-items:center}
.cai-input-box input{flex:1;background:none;border:none;color:var(--paper);font:inherit;font-size:.95rem;outline:none}
.cai-input-box input::placeholder{color:rgba(245,241,232,.45)}
.cai-send{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--coral);border:none;color:var(--paper);font-size:1rem;cursor:pointer;transition:background .2s}
.cai-send:hover{background:var(--paper);color:var(--coral)}
.cai-foot{text-align:center;font-size:.72rem;color:rgba(245,241,232,.4);margin-top:.7rem}
.cai-foot a{color:var(--coral)}
@media(max-width:560px){.cai-panel{width:100vw}}

/* global back-to-top button */
.ct-top-bouncer{position:fixed;right:1rem;bottom:1rem;z-index:180;width:46px;height:46px;border-radius:999px;border:1px solid rgba(245,241,232,.22);background:var(--ink);color:var(--paper);box-shadow:0 14px 34px rgba(10,10,10,.24);display:grid;place-items:center;font-size:1rem;line-height:1;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .22s var(--ease),transform .22s var(--ease);cursor:pointer}
.ct-top-bouncer.show{opacity:1;pointer-events:auto;transform:translateY(0);animation:ctTopBounce 1.35s var(--ease) infinite}
@keyframes ctTopBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media(max-width:760px){.ct-top-bouncer{width:42px;height:42px;right:.85rem;bottom:.85rem}}

/* cinematic immersion layer: reused by category and country pages */
.ct-cinema-scan{position:absolute;inset:0;z-index:2;pointer-events:none;background:
  linear-gradient(90deg,rgba(245,241,232,.06) 1px,transparent 1px) 0 0/96px 100%,
  linear-gradient(0deg,rgba(245,241,232,.035) 1px,transparent 1px) 0 0/100% 96px;
  mix-blend-mode:screen;opacity:.22}
.ct-cinema-vignette{position:absolute;inset:0;z-index:2;pointer-events:none;background:
  radial-gradient(circle at 50% 38%,transparent 0 36%,rgba(10,10,10,.22) 68%,rgba(10,10,10,.56) 100%);
  opacity:.72}
.ct-parallax-media{will-change:transform;transform:translate3d(0,var(--ct-parallax,0px),0) scale(var(--ct-scale,1.03));transition:transform .08s linear}
.ct-reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.ct-reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .ct-parallax-media{transform:none!important;transition:none}
  .ct-reveal{opacity:1;transform:none;transition:none}
}
