/* ===========================================================
   eSIMMY — shared styles
   Palette:
   --ink:      #16242E  (deep travel-night navy)
   --paper:    #FBF6EE  (warm boarding-pass cream)
   --sun:      #F2A65A  (golden hour accent)
   --sky:      #6FA8A0  (calm teal, secondary accent)
   --line:     #D9CFBE  (hairline / divider on cream)
   --muted:    #6B7A85  (muted ink for captions)
   Type:
   --display:  "Fraunces", Georgia, serif   (editorial, warm serif)
   --body:     "Inter", system-ui, sans-serif
   --mono:     "IBM Plex Mono", monospace   (ticket / data details)
   Signature element: the "boarding pass" stub — a perforated ticket
   card with a torn edge, used for CTAs, pricing and post previews.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:#16242E;
  --paper:#FBF6EE;
  --sun:#F2A65A;
  --sky:#6FA8A0;
  --line:#D9CFBE;
  --muted:#6B7A85;
  --display: "Fraunces", Georgia, serif;
  --body: "Inter", system-ui, -apple-system, sans-serif;
  --mono: "IBM Plex Mono", monospace;
  --maxw: 1140px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }

a{ color:inherit; }

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px;
}

h1,h2,h3,h4{
  font-family:var(--display);
  line-height:1.1;
  margin:0 0 .5em;
  font-weight:600;
  letter-spacing:-.01em;
}

h1{ font-size:clamp(2.4rem,6vw,4.2rem); font-weight:700; }
h2{ font-size:clamp(1.8rem,4vw,2.6rem); }
h3{ font-size:1.35rem; }

p{ margin:0 0 1em; }

.eyebrow{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--sky);
  display:inline-block;
  margin-bottom:.9em;
}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0;
}
.logo{
  font-family:var(--display);
  font-weight:700;
  font-size:1.4rem;
  text-decoration:none;
  color:var(--ink);
  letter-spacing:-.02em;
}
.logo span{ color:var(--sun); }

.nav-links{
  display:flex; gap:28px; align-items:center;
  list-style:none; margin:0; padding:0;
}
.nav-links a{
  text-decoration:none;
  font-weight:500;
  font-size:.95rem;
  color:var(--ink);
  position:relative;
  padding-bottom:4px;
}
.nav-links a.active{ color:var(--sky); }
.nav-links a:hover{ color:var(--sky); }

.nav-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  background:var(--ink);
  color:var(--paper) !important;
  padding:10px 20px;
  border-radius:999px;
  font-weight:600;
  font-size:.9rem;
  text-decoration:none;
  white-space:nowrap;
  line-height:1;
}
.nav-cta:hover{ background:var(--sky); color:var(--ink) !important; }

/* Emoji glyphs render with extra internal padding (esp. right/bottom),
   which throws off visual centering in pill buttons. This tightens it. */
.emoji{
  display:inline-block;
  transform:translateY(-1px);
  margin-right:-4px;
}

.nav-toggle{
  display:none;
  background:none; border:none; cursor:pointer;
  font-family:var(--mono); font-size:.85rem;
  color:var(--ink); padding:8px;
}

@media (max-width: 820px){
  .nav-toggle{ display:block; }
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    background:var(--paper);
    border-bottom:1px solid var(--line);
    flex-direction:column; align-items:flex-start;
    padding:18px 24px; gap:16px;
    display:none;
  }
  .nav-links.open{ display:flex; }
  .nav-cta{ width:100%; text-align:center; }
}

/* ---------- Hero ---------- */
.hero{
  padding:80px 0 64px;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(900px 420px at 85% -10%, rgba(242,166,90,.18), transparent 60%),
    radial-gradient(700px 380px at -10% 110%, rgba(111,168,160,.18), transparent 60%);
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:56px;
  align-items:center;
}
@media (max-width: 900px){
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
}
.hero h1{ margin-bottom:.4em; }
.hero .lead{
  font-size:1.15rem;
  color:var(--muted);
  max-width:46ch;
}
.hero-actions{
  display:flex; gap:14px; flex-wrap:wrap; margin-top:28px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:.98rem;
  text-decoration:none;
  border:1px solid var(--ink);
  transition:transform .15s ease, background .15s ease, color .15s ease;
}
.btn-primary{
  background:var(--ink); color:var(--paper); border-color:var(--ink);
}
.btn-primary:hover{ background:var(--sun); color:var(--ink); border-color:var(--sun); transform:translateY(-2px); }
.btn-ghost{
  background:transparent; color:var(--ink); border-color:var(--ink);
}
.btn-ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-2px); }

/* ---------- Boarding pass / ticket — signature element ---------- */
.ticket{
  background:var(--ink);
  color:var(--paper);
  border-radius:18px;
  position:relative;
  overflow:hidden;
  box-shadow:0 24px 60px -24px rgba(22,36,46,.55);
}
.ticket-body{ padding:32px 32px 28px; }
.ticket-stub{
  border-top:1px dashed rgba(251,246,238,.35);
  padding:20px 32px 26px;
  display:flex; justify-content:space-between; align-items:center;
  gap:16px;
  font-family:var(--mono);
  font-size:.82rem;
  color:rgba(251,246,238,.75);
}
.ticket::before, .ticket::after{
  content:""; position:absolute;
  width:28px; height:28px; border-radius:50%;
  background:var(--paper);
}
.ticket::before{ left:-14px; top:calc(100% - 76px); }
.ticket::after{ right:-14px; top:calc(100% - 76px); }
.ticket-route{
  font-family:var(--mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.78rem;
  color:var(--sun);
  margin-bottom:10px;
}
.ticket h2, .ticket h3{ color:var(--paper); }
.ticket .price{
  font-family:var(--display);
  font-size:2.6rem;
  font-weight:700;
  color:var(--sun);
}
.ticket .per-day{
  font-family:var(--mono);
  font-size:.85rem;
  color:rgba(251,246,238,.7);
}

/* ---------- Sections ---------- */
section{ padding:72px 0; }
.section-alt{ background:#F4EDDF; }
.section-ink{ background:var(--ink); color:var(--paper); }
.section-ink .eyebrow{ color:var(--sun); }
.section-ink h2{ color:var(--paper); }
.section-ink .muted{ color:rgba(251,246,238,.7); }

.muted{ color:var(--muted); }

.center{ text-align:center; }
.section-head{ max-width:62ch; margin-bottom:48px; }
.section-head.center{ margin-left:auto; margin-right:auto; }

/* ---------- Grids / cards ---------- */
.grid{ display:grid; gap:28px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width: 900px){
  .grid-3, .grid-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 640px){
  .grid-2, .grid-3, .grid-4{ grid-template-columns:1fr; }
}

.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:16px;
  padding:28px;
}
.card .num{
  font-family:var(--mono);
  color:var(--sky);
  font-size:.8rem;
  letter-spacing:.12em;
  display:block;
  margin-bottom:.6em;
}

/* ---------- Comparison table ---------- */
.table-wrap{ overflow-x:auto; }
table{
  width:100%;
  border-collapse:collapse;
  background:var(--paper);
  border-radius:14px;
  overflow:hidden;
  font-size:.95rem;
}
th, td{
  text-align:left;
  padding:14px 18px;
  border-bottom:1px solid var(--line);
}
th{
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.75rem;
  color:var(--muted);
  background:#F4EDDF;
}
tr:last-child td{ border-bottom:none; }

/* ---------- Quote / pull ---------- */
.pull{
  font-family:var(--display);
  font-size:clamp(1.3rem,3vw,1.9rem);
  font-weight:500;
  line-height:1.35;
  border-left:3px solid var(--sun);
  padding-left:24px;
  margin:0;
}

/* ---------- Country chips ---------- */
.chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.chip{
  font-family:var(--mono);
  font-size:.78rem;
  padding:6px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  background:var(--paper);
  color:var(--ink);
}

/* ---------- FAQ ---------- */
.faq-item{
  border-bottom:1px solid var(--line);
  padding:20px 0;
}
.faq-item summary{
  cursor:pointer;
  font-family:var(--display);
  font-size:1.1rem;
  font-weight:600;
  list-style:none;
  display:flex; justify-content:space-between; align-items:center;
  gap:16px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:"+";
  font-family:var(--mono);
  color:var(--sun);
  font-size:1.4rem;
  flex-shrink:0;
}
.faq-item[open] summary::after{ content:"–"; }
.faq-item p{ margin-top:12px; color:var(--muted); }

/* ---------- Blog ---------- */
.post-meta{
  font-family:var(--mono);
  font-size:.8rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.08em;
}
.post-card{
  display:block; text-decoration:none; color:var(--ink);
}
.post-card .card{ height:100%; transition:transform .15s ease, border-color .15s; }
.post-card:hover .card{ transform:translateY(-4px); border-color:var(--sky); }

article.post h2{ margin-top:1.4em; }
article.post .pull{ margin:2em 0; }

/* ---------- Footer ---------- */
.site-footer{
  background:var(--ink); color:var(--paper);
  padding:56px 0 28px;
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px;
  border-bottom:1px solid rgba(251,246,238,.15);
  padding-bottom:36px; margin-bottom:24px;
}
@media (max-width: 760px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 480px){
  .footer-grid{ grid-template-columns:1fr; }
}
.footer-grid h4{ color:var(--sun); font-family:var(--mono); font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500; }
.footer-grid a{ display:block; text-decoration:none; color:rgba(251,246,238,.8); margin-bottom:8px; font-size:.95rem; }
.footer-grid a:hover{ color:var(--sun); }
.footer-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:.82rem; color:rgba(251,246,238,.55);
  font-family:var(--mono);
}

/* ---------- Misc ---------- */
.divider{ height:1px; background:var(--line); margin:0; border:none; }
.tag{
  font-family:var(--mono); font-size:.75rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--sky);
}
