/* ===========================================================
   Amit Jain · Travelogue — Editorial Luxe theme
   Self-contained: no external fonts, images, or scripts.
   =========================================================== */

:root{
  /* palette */
  --ivory:#F7F3EA;
  --ivory-2:#F1EADB;
  --paper:#FBF8F1;
  --emerald:#0E3B2E;
  --emerald-2:#12513C;
  --emerald-soft:#1C6047;
  --gold:#B08D3C;
  --gold-soft:#C9A961;
  --ink:#23231F;
  --muted:#6E6C61;
  --line:#DED5C2;
  --line-strong:#CDBFA6;
  --shadow:0 18px 40px -24px rgba(20,40,30,.45);
  --shadow-sm:0 8px 20px -16px rgba(20,40,30,.55);

  --serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif;
  --display:"Didot","Bodoni MT","Hoefler Text",Garamond,"Times New Roman",serif;
  --sans:"Optima","Gill Sans","Helvetica Neue",Arial,sans-serif;

  --maxw:1160px;
  --radius:14px;
  --radius-lg:20px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:
    radial-gradient(1200px 700px at 82% -8%, rgba(176,141,60,.10), transparent 60%),
    radial-gradient(1000px 600px at -6% 8%, rgba(14,59,46,.08), transparent 55%),
    var(--ivory);
  color:var(--ink);
  font-family:var(--serif);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;}

.skip-link{position:absolute;left:-999px;top:0;background:var(--emerald);color:var(--ivory);padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:100;}
.skip-link:focus{left:0;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(247,243,234,.86);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:.7rem 1.25rem;
  display:flex;align-items:center;gap:1.25rem;justify-content:space-between;
}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--emerald);flex:0 0 auto;}
.brand-mark{display:grid;place-items:center;color:var(--gold);}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-name{font-family:var(--display);font-size:1.28rem;letter-spacing:.14em;text-transform:uppercase;color:var(--emerald);}
.brand-sub{font-size:.7rem;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);margin-top:.28rem;}

.search{position:relative;flex:1 1 340px;max-width:420px;}
#searchInput{
  width:100%;font-family:var(--serif);font-size:.95rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:999px;
  padding:.62rem 1.05rem;outline:none;transition:border-color .2s,box-shadow .2s;
}
#searchInput::placeholder{color:#9a9789;font-style:italic;}
#searchInput:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,141,60,.16);}
.search-results{
  position:absolute;top:calc(100% + .5rem);left:0;right:0;z-index:60;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);max-height:min(64vh,460px);overflow:auto;padding:.35rem;
}
.sr-item{display:block;padding:.55rem .7rem;border-radius:10px;cursor:pointer;}
.sr-item:hover,.sr-item.active{background:var(--ivory-2);}
.sr-name{font-family:var(--display);font-size:1.02rem;color:var(--emerald);}
.sr-path{font-size:.76rem;color:var(--muted);letter-spacing:.02em;margin-top:.1rem;}
.sr-empty{padding:.9rem;color:var(--muted);font-style:italic;text-align:center;}

/* ---------- breadcrumb ---------- */
.breadcrumb{max-width:var(--maxw);margin:0 auto;padding:1rem 1.25rem .2rem;}
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:.15rem;font-size:.82rem;letter-spacing:.03em;}
.crumbs a,.crumbs span.current{padding:.12rem .1rem;}
.crumbs a{color:var(--muted);border-bottom:1px solid transparent;transition:color .18s,border-color .18s;}
.crumbs a:hover{color:var(--emerald);border-color:var(--gold);}
.crumb-sep{color:var(--gold);opacity:.7;padding:0 .3rem;}
.crumbs .current{color:var(--emerald);font-weight:600;}

/* ---------- layout ---------- */
.main{max-width:var(--maxw);margin:0 auto;padding:1rem 1.25rem 3rem;}
.view{animation:rise .5s cubic-bezier(.2,.7,.2,1) both;}
@keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.view{animation:none;}}

.eyebrow{font-family:var(--sans);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin:0 0 .6rem;}
.section-title{font-family:var(--display);font-weight:400;color:var(--emerald);line-height:1.05;margin:0;}

/* ---------- hero (home) ---------- */
.hero{
  position:relative;text-align:center;padding:2.6rem 1rem 2.2rem;margin-bottom:1.4rem;
}
.hero .kicker{font-family:var(--sans);letter-spacing:.5em;text-transform:uppercase;font-size:.72rem;color:var(--gold);}
.hero h1{
  font-family:var(--display);font-weight:400;color:var(--emerald);
  font-size:clamp(2.6rem,6vw,4.6rem);line-height:.98;margin:.7rem 0 .2rem;letter-spacing:.01em;
}
.hero .sub{font-style:italic;color:var(--muted);font-size:clamp(1rem,2.2vw,1.28rem);max-width:44ch;margin:.5rem auto 0;}
.hero-rule{width:118px;height:2px;margin:1.5rem auto .2rem;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.hero-stats{display:flex;gap:1.6rem;justify-content:center;flex-wrap:wrap;margin-top:1.3rem;color:var(--emerald);}
.hstat{display:flex;flex-direction:column;align-items:center;line-height:1;}
.hstat b{font-family:var(--display);font-size:1.7rem;font-weight:400;}
.hstat span{font-family:var(--sans);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:.4rem;}

/* ---------- grids ---------- */
.grid{display:grid;gap:1.15rem;}
.grid.continents{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));}
.grid.countries,.grid.cities{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));}

/* ---------- cards ---------- */
.card{
  position:relative;display:flex;flex-direction:column;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s,border-color .3s;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold-soft);}
.card:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
.card-art{height:132px;position:relative;overflow:hidden;}
.card-art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.28));}
.card-art .glyph{position:absolute;right:.7rem;bottom:.5rem;font-size:2.1rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));z-index:1;}
.card-body{padding:1rem 1.1rem 1.15rem;display:flex;flex-direction:column;gap:.28rem;flex:1;}
.card-kicker{font-family:var(--sans);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.card-title{font-family:var(--display);font-size:1.42rem;color:var(--emerald);line-height:1.05;}
.card-tag{color:var(--muted);font-style:italic;font-size:.94rem;}
.card-meta{margin-top:.55rem;font-family:var(--sans);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#948f80;display:flex;gap:.9rem;}
.card-meta .flag{font-style:normal;font-size:1rem;}

/* continent gradient art */
.art-africa{background:linear-gradient(135deg,#C56A2E,#8A3B12 55%,#3C2A12);}
.art-asia{background:linear-gradient(135deg,#B0324B,#5E1836 55%,#241033);}
.art-europe{background:linear-gradient(135deg,#2E6E63,#123F3C 55%,#0B2A2C);}
.art-north-america{background:linear-gradient(135deg,#3E7CA6,#20507B 52%,#152C46);}
.art-south-america{background:linear-gradient(135deg,#3F9A5B,#1C6B3C 55%,#123C2C);}
.art-oceania{background:linear-gradient(135deg,#1FA0A6,#106E86 52%,#0C3A55);}
.art-antarctica{background:linear-gradient(135deg,#9FC7D8,#5E93B4 50%,#2E4E6E);}
.art-generic{background:linear-gradient(135deg,#4C6B5E,#25463B 60%,#152A24);}
.card-art .texture{position:absolute;inset:0;opacity:.5;
  background:
    radial-gradient(120px 60px at 20% 120%, rgba(255,255,255,.16), transparent 70%),
    radial-gradient(140px 80px at 90% -10%, rgba(255,255,255,.14), transparent 70%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.05) 0 2px, transparent 2px 22px);
}

/* ---------- page headers ---------- */
.page-head{padding:1.2rem 0 1.4rem;border-bottom:1px solid var(--line);margin-bottom:1.6rem;}
.page-head h2{font-family:var(--display);font-weight:400;color:var(--emerald);font-size:clamp(2rem,5vw,3.2rem);line-height:1.02;margin:.3rem 0 .35rem;}
.page-head .lead{color:var(--muted);font-style:italic;font-size:1.08rem;max-width:60ch;}
.page-head .flag-lg{font-size:2rem;vertical-align:middle;margin-right:.5rem;}

/* ---------- journal (handwritten) ---------- */
.journal{
  position:relative;background:
    linear-gradient(var(--paper),var(--paper)) padding-box,
    linear-gradient(180deg,var(--gold-soft),transparent) border-box;
  border-left:3px solid var(--gold);
  border-radius:0 12px 12px 0;
  padding:1.1rem 1.3rem 1.15rem 1.4rem;margin:0 0 1.8rem;
  box-shadow:var(--shadow-sm);
}
.journal::before{
  content:"From Amit’s journal";
  display:block;font-family:var(--sans);font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.5rem;
}
.journal p{margin:0;font-style:italic;font-size:1.1rem;line-height:1.7;color:#33352d;}
.journal.city{margin-top:.2rem;}

/* ---------- places ---------- */
.places{display:grid;gap:1.05rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));}
.place{
  display:flex;flex-direction:column;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius);padding:1.15rem 1.2rem 1.25rem;
  box-shadow:var(--shadow-sm);transition:transform .28s,box-shadow .28s,border-color .28s;
  cursor:pointer;
}
.place:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-soft);}
.place:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
.place-top{display:flex;justify-content:space-between;align-items:baseline;gap:.8rem;}
.place-name{font-family:var(--display);font-size:1.34rem;color:var(--emerald);line-height:1.08;}
.place-type{font-family:var(--sans);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);white-space:nowrap;}
.place-desc{color:#3a3c33;margin:.5rem 0 .3rem;font-size:.98rem;}
.place-why{color:var(--muted);font-size:.92rem;}
.place-why b{color:var(--emerald-soft);font-weight:600;font-style:normal;}

/* best-time badge */
.besttime{display:inline-flex;align-items:center;gap:.45rem;margin:.7rem 0 .55rem;
  font-family:var(--sans);font-size:.72rem;letter-spacing:.06em;color:var(--emerald);
  background:var(--ivory-2);border:1px solid var(--line);border-radius:999px;padding:.28rem .7rem;}
.besttime .dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--gold);}
.besttime b{font-weight:700;letter-spacing:.02em;}

/* seasonality strip */
.season{margin-top:.35rem;}
.season-row{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;}
.season-cell{position:relative;height:22px;border-radius:4px;background:var(--ivory-2);border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--sans);font-size:.56rem;letter-spacing:.02em;color:#a7a294;transition:transform .15s;}
.season-cell.on{background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-color:var(--gold);color:#3a2c0c;font-weight:700;}
.season-cell.on::after{content:"";position:absolute;inset:0;border-radius:4px;box-shadow:0 4px 10px -6px rgba(176,141,60,.9);}
.place:hover .season-cell.on{transform:translateY(-1px);}
.season-legend{display:flex;gap:1rem;margin-top:.5rem;font-family:var(--sans);font-size:.62rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;}
.season-legend .sw{display:inline-block;width:.7rem;height:.7rem;border-radius:3px;vertical-align:-1px;margin-right:.3rem;}
.sw.on{background:linear-gradient(180deg,var(--gold-soft),var(--gold));}
.sw.off{background:var(--ivory-2);border:1px solid var(--line);}

/* ---------- place detail ---------- */
.detail{max-width:820px;}
.detail-hero{border-radius:var(--radius-lg);overflow:hidden;position:relative;height:190px;margin-bottom:1.4rem;box-shadow:var(--shadow);}
.detail-hero .texture{opacity:.55;}
.detail-hero .glyph{position:absolute;left:1.2rem;bottom:.9rem;font-size:2.6rem;filter:drop-shadow(0 3px 8px rgba(0,0,0,.4));}
.detail h2{font-family:var(--display);font-weight:400;color:var(--emerald);font-size:clamp(2rem,5vw,3rem);margin:.2rem 0 .1rem;}
.detail .type{font-family:var(--sans);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.detail .big-desc{font-size:1.16rem;color:#33352d;margin:.9rem 0 1.4rem;}
.panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.2rem;box-shadow:var(--shadow-sm);}
.panel h3{font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin:0 0 .7rem;}
.panel .when{font-family:var(--display);font-size:1.5rem;color:var(--emerald);margin-bottom:.6rem;}
.panel .why-full{color:#3a3c33;font-size:1.02rem;}
.detail .season-row{grid-template-columns:repeat(12,1fr);gap:5px;}
.detail .season-cell{height:34px;font-size:.66rem;}

/* ---------- back link ---------- */
.backlink{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;transition:color .18s;}
.backlink:hover{color:var(--emerald);}
.backlink .arw{color:var(--gold);}

/* ---------- footer ---------- */
.site-footer{max-width:var(--maxw);margin:0 auto;padding:2.4rem 1.25rem 3rem;text-align:center;}
.footer-rule{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);margin-bottom:1.4rem;}
.footer-line{font-family:var(--display);font-size:1.15rem;color:var(--emerald);margin:0 0 .5rem;}
.footer-fine{font-size:.78rem;color:var(--muted);max-width:60ch;margin:0 auto;}
.footer-credit{margin:1rem auto 0;font-family:var(--sans);font-size:.74rem;letter-spacing:.06em;color:var(--muted);}
.footer-credit a{color:var(--emerald-soft);border-bottom:1px solid var(--gold);}
.footer-credit a:hover{color:var(--emerald);}

/* ---------- utilities ---------- */
.count-pill{font-family:var(--sans);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.mt{margin-top:2rem;}

/* ---------- resources & live data ---------- */
.resources{margin-top:1rem;}
.res-groups{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));}
.res-group h4{font-family:var(--sans);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0 0 .55rem;display:flex;align-items:center;gap:.4rem;}
.res-list{display:flex;flex-wrap:wrap;gap:.4rem;}
.chip{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.76rem;
  background:var(--ivory-2);border:1px solid var(--line);border-radius:999px;padding:.32rem .72rem;color:var(--emerald);
  transition:border-color .18s,background .18s,transform .18s;cursor:pointer;}
.chip:hover{border-color:var(--gold);background:#fff;transform:translateY(-1px);}
.chip:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.chip .ic{width:.9rem;height:.9rem;display:inline-block;color:var(--gold);}
.chip.rss{background:#fff4e6;border-color:#e7c893;color:#8a5a12;}
.chip.rss .ic{color:#d98a1f;}
.chip .copy{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border-left:1px solid var(--line);padding-left:.4rem;margin-left:.1rem;}
.chip.copied{border-color:var(--emerald-soft);background:#eef6f0;}
.res-note{font-size:.74rem;color:var(--muted);margin-top:.7rem;font-style:italic;}

/* plan-with-google box */
.gbox{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.15rem 1.25rem 1.25rem;margin-top:2rem;box-shadow:var(--shadow-sm);overflow:hidden;}
.gbox::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;
  background:linear-gradient(90deg,#4285F4 0 25%,#DB4437 25% 50%,#F4B400 50% 75%,#0F9D58 75% 100%);opacity:.85;}
.gbox h4{font-family:var(--sans);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--emerald);margin:.2rem 0 .2rem;}
.gbox .gsub{font-size:.8rem;color:var(--muted);font-style:italic;margin:0 0 .8rem;}
.g-list{display:flex;flex-wrap:wrap;gap:.5rem;}
.g-chip{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.82rem;
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:.5rem .85rem;color:var(--ink);
  transition:border-color .18s,box-shadow .18s,transform .18s;}
.g-chip:hover{border-color:var(--gold);box-shadow:var(--shadow-sm);transform:translateY(-1px);}
.g-chip:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.g-chip .gi{font-size:1.05rem;line-height:1;}
.g-chip b{font-weight:600;color:var(--emerald);}

/* live panels */
.live-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.live{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;box-shadow:var(--shadow-sm);}
.live h4{font-family:var(--sans);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0 0 .5rem;}
.live .big{font-family:var(--display);font-size:1.6rem;color:var(--emerald);line-height:1.1;}
.live .muted{color:var(--muted);font-size:.86rem;}
.live .wx-row{display:flex;align-items:center;gap:.6rem;}
.live .wx-emoji{font-size:1.7rem;}
.live .facts{display:grid;grid-template-columns:auto 1fr;gap:.2rem .8rem;font-size:.9rem;}
.live .facts dt{color:var(--muted);font-family:var(--sans);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;align-self:center;}
.live .facts dd{margin:0;color:var(--ink);}
.live .wiki-extract{font-size:.96rem;color:#3a3c33;}
.live .loading{color:var(--muted);font-style:italic;font-size:.9rem;}
.live .err{color:#9a6a2a;font-size:.82rem;font-style:italic;}
.live-src{font-size:.68rem;color:#a29c8c;margin-top:.5rem;font-family:var(--sans);letter-spacing:.04em;}
.near{list-style:none;margin:.2rem 0 0;padding:0;}
.near li{margin:0;}
.near-item{display:flex;justify-content:space-between;gap:.6rem;padding:.18rem 0;border-bottom:1px dotted var(--line);}
.near-item:hover .near-name{color:var(--emerald);}
.near-name{font-size:.84rem;color:var(--ink);}
.near-dist{font-size:.74rem;color:var(--muted);white-space:nowrap;}
.near-title{font-family:var(--sans);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:.45rem 0 .1rem;}
.prof-label{font-family:var(--sans);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:.5rem 0 .12rem;}
.prof-ul{list-style:none;margin:.25rem 0 0;padding:0;}
.prof-ul li{position:relative;padding:.16rem 0 .16rem .85rem;font-size:.86rem;color:var(--ink);border-bottom:1px dotted var(--line);}
.prof-ul li:before{content:"›";position:absolute;left:0;color:var(--gold);}

/* Fable "why go" hook */
.hook{font-family:var(--display);font-size:clamp(1.15rem,2.4vw,1.6rem);line-height:1.4;color:var(--emerald-soft);
  font-style:italic;max-width:60ch;margin:.2rem 0 1.2rem;padding-left:1rem;border-left:3px solid var(--gold);}

/* Ask the travelogue (AI) */
.askbox{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.15rem 1.25rem 1.25rem;box-shadow:var(--shadow-sm);}
.ask-row{display:flex;gap:.5rem;margin:.2rem 0 .3rem;flex-wrap:wrap;}
.ask-input{flex:1 1 260px;font-family:var(--serif);font-size:.98rem;color:var(--ink);background:var(--ivory);
  border:1px solid var(--line);border-radius:999px;padding:.6rem 1rem;outline:none;transition:border-color .2s,box-shadow .2s;}
.ask-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,141,60,.16);}
.ask-input::placeholder{color:#9a9789;font-style:italic;}
.ask-btn{font-family:var(--sans);font-size:.82rem;letter-spacing:.08em;color:var(--ivory);background:var(--emerald);
  border:1px solid var(--emerald);border-radius:999px;padding:.6rem 1.4rem;cursor:pointer;transition:background .2s,transform .15s;}
.ask-btn:hover{background:var(--emerald-2);transform:translateY(-1px);}
.ask-btn:disabled{opacity:.55;cursor:default;transform:none;}
.ask-out{margin-top:.4rem;}
.ask-answer{background:var(--ivory-2);border:1px solid var(--line);border-radius:12px;padding:.8rem 1rem;color:#33352d;font-size:1rem;line-height:1.6;white-space:pre-wrap;}

@media (max-width:640px){
  body{font-size:16px;}
  .header-inner{flex-wrap:wrap;gap:.7rem;}
  .search{flex-basis:100%;max-width:none;order:3;}
  .places{grid-template-columns:1fr;}
  .hero{padding-top:1.6rem;}
  .res-groups,.live-grid{grid-template-columns:1fr;}
}

/* ---- Host invitation: landing headline card + page ---- */
.invite-card{display:flex;gap:1.1rem;align-items:stretch;margin:1.6rem 0 2rem;border-radius:16px;overflow:hidden;
  text-decoration:none;color:var(--ivory);background:linear-gradient(120deg,var(--emerald) 0%,var(--emerald-2) 55%,var(--emerald-soft) 100%);
  border:1px solid rgba(176,141,60,.5);box-shadow:0 10px 30px rgba(14,59,46,.22);position:relative;transition:transform .18s ease,box-shadow .18s ease;}
.invite-card:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(14,59,46,.3);}
.invite-badge{flex:0 0 auto;display:grid;place-items:center;padding:0 1.15rem;font-family:var(--sans);font-size:.66rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--emerald);background:linear-gradient(180deg,var(--gold-soft),var(--gold));writing-mode:vertical-rl;transform:rotate(180deg);font-weight:700;}
.invite-body{padding:1.2rem 1.4rem 1.25rem 0;}
.invite-kicker{font-family:var(--sans);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.4rem;}
.invite-title{font-family:var(--display);font-weight:400;font-size:1.5rem;line-height:1.15;color:var(--ivory);margin:0 0 .5rem;}
.invite-sub{color:rgba(247,243,234,.86);font-size:.96rem;line-height:1.5;margin:0 0 .7rem;max-width:60ch;}
.invite-go{font-family:var(--sans);font-size:.8rem;letter-spacing:.06em;color:var(--gold-soft);font-weight:600;}
@media(max-width:640px){.invite-title{font-size:1.24rem;}.invite-badge{writing-mode:horizontal-tb;transform:none;padding:.4rem 1rem;}.invite-card{flex-direction:column;}}

.invite-view .invite-block{margin:1.15rem 0;padding-left:1rem;border-left:2px solid var(--gold);}
.invite-view .invite-block h3{font-family:var(--display);font-weight:400;color:var(--emerald);font-size:1.18rem;margin:0 0 .3rem;}
.invite-view .invite-block p{color:var(--ink);line-height:1.6;margin:0;max-width:70ch;}
.invite-contact{margin-top:1.8rem;padding-top:1.2rem;border-top:1px solid var(--line);}
.invite-contact h3{font-family:var(--display);font-weight:400;color:var(--emerald);font-size:1.18rem;margin:0 0 .7rem;}
.invite-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;}
.invite-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 1.05rem;border-radius:999px;text-decoration:none;
  font-family:var(--sans);font-size:.9rem;font-weight:600;border:1px solid var(--gold);color:var(--emerald);background:transparent;transition:background .15s,color .15s;}
.invite-btn:hover{background:var(--gold);color:#fff;}
.invite-btn.primary{background:var(--emerald);color:var(--ivory);border-color:var(--emerald);}
.invite-btn.primary:hover{background:var(--emerald-soft);}
.invite-btn.ghost{border-color:var(--line);color:var(--muted);}
.invite-btn.ghost:hover{color:var(--emerald);border-color:var(--gold);background:transparent;}
.invite-btn .bi{display:inline-flex;}
.invite-fine{margin-top:.8rem;color:var(--muted);font-size:.82rem;}

/* ---- per-card Ask AI chip + things-to-do ---- */
.live-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;}
.live-head h4{margin:0;}
.ask-chip{flex:0 0 auto;font-family:var(--sans);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);background:transparent;border:1px solid var(--line);border-radius:999px;padding:.16rem .5rem;cursor:pointer;transition:all .15s;}
.ask-chip:hover{color:#fff;background:var(--gold);border-color:var(--gold);}
.panel.todo{margin-top:1rem;}
.panel.todo .prof-ul li{font-size:.95rem;padding:.28rem 0 .28rem .95rem;}

/* ---- floating share button ---- */
.share-fab{position:fixed;right:1.1rem;bottom:1.1rem;z-index:70;width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;cursor:pointer;color:var(--ivory);border:1px solid var(--gold-soft);
  background:linear-gradient(145deg,var(--emerald-soft),var(--emerald));box-shadow:0 10px 26px rgba(14,59,46,.4);
  transition:transform .15s ease,box-shadow .15s ease;}
.share-fab:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 16px 34px rgba(14,59,46,.5);}
.share-fab:active{transform:scale(.96);}
.share-menu{position:fixed;right:1.1rem;bottom:4.6rem;z-index:71;min-width:180px;padding:.35rem;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);}
.share-head{font-family:var(--sans);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);padding:.45rem .6rem .3rem;}
.share-item{display:block;width:100%;text-align:left;padding:.5rem .6rem;border-radius:9px;background:transparent;border:0;
  font-family:var(--serif);font-size:.95rem;color:var(--ink);cursor:pointer;}
.share-item:hover{background:var(--ivory-2);color:var(--emerald);}
@media(max-width:520px){.share-fab{width:48px;height:48px;right:.8rem;bottom:.8rem;}.share-menu{right:.8rem;bottom:4rem;}}

/* ---- Accessibility: WCAG-AA contrast for small text on light backgrounds ---- */
:root{ --gold-ink:#7a5f1f; }
.eyebrow,.hero .kicker,.card-kicker,.brand-sub,.live h4,.prof-label,.near-title,.place-type,.type{ color:var(--gold-ink); }
.ask-chip{ color:var(--gold-ink); border-color:var(--gold-ink); }
.live-src{ color:#6b675c; }
.card-meta,.card-meta span{ color:#5f5c54; }
.crumbs a{ color:#5f5c54; }
.sr-path{ color:#5f5c54; }
.hstat span{ color:#5f5c54; }
.footer-fine{ color:#5f5c54; }
/* keep gold light where it sits on the dark emerald (high contrast already) */
.invite-kicker,.invite-go,.brand-mark,.footer-credit a{ color:var(--gold-soft); }
