@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&family=Instrument+Serif:ital@0;1&family=Caveat:wght@500;700&display=swap');

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}

:root{
  --bg:#FFFDF7;
  --ink:#111;
  --pop:#FF3366;
  --yellow:#FFE14D;
  --blue:#3D5AFE;
  --green:#00C853;
  --orange:#FF6D00;
  --purple:#AA00FF;
  --grotesk:'Space Grotesk',sans-serif;
  --serif:'Instrument Serif',serif;
  --hand:'Caveat',cursive;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--grotesk);overflow-x:hidden;padding-bottom:70px}
::selection{background:var(--yellow)}

/* ===== MARQUEE TOP ===== */
.marquee{
  background:var(--ink);color:var(--bg);
  padding:8px 0;overflow:hidden;white-space:nowrap;
  font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
}
.marquee-track{display:inline-flex;animation:scroll 20s linear infinite}
.marquee-track span{padding:0 24px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== HERO ===== */
.hero{
  padding:24px 20px 28px;
  position:relative;
  min-height:70vh;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--yellow);color:var(--ink);
  padding:6px 14px;border-radius:100px;
  font-size:12px;font-weight:700;
  width:fit-content;
  transform:rotate(-2deg);
  margin-bottom:16px;
}

.hero-title{
  font-family:var(--grotesk);font-weight:700;
  font-size:clamp(64px,20vw,140px);
  line-height:.85;letter-spacing:-4px;
  position:relative;
}
.hero-title .outline{
  -webkit-text-stroke:2.5px var(--ink);
  color:transparent;
}
.hero-title .pop{color:var(--pop)}
.hero-title .scribble{
  font-family:var(--hand);font-weight:700;
  font-size:.35em;color:var(--pop);
  position:absolute;right:0;top:-8px;
  transform:rotate(6deg);
  letter-spacing:0;
  white-space:nowrap;
}
@media(max-width:500px){
  .hero-title .scribble{
    position:static !important;
    display:block !important;
    transform:rotate(2deg) !important;
    font-size:14px !important;
    margin-top:6px;
    white-space:nowrap;
  }
}

.hero-copy{
  font-size:17px;line-height:1.55;
  margin-top:20px;max-width:340px;
}
.hero-copy .highlight{
  background:var(--yellow);
  padding:0 4px;margin:0 -2px;
  display:inline;
  text-decoration:none;
}

.hero-cta{
  margin-top:24px;display:flex;gap:10px;flex-wrap:wrap;
}
.btn{
  font-family:var(--grotesk);font-weight:700;font-size:15px;
  padding:14px 28px;border-radius:100px;
  border:2.5px solid var(--ink);cursor:pointer;
  transition:transform .1s,box-shadow .1s;
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
}
.btn:active{transform:scale(.95)}
.btn-primary{background:var(--ink);color:var(--bg);box-shadow:4px 4px 0 var(--pop)}
.btn-primary:hover{box-shadow:6px 6px 0 var(--pop)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:4px 4px 0 var(--yellow)}
.btn-ghost:hover{box-shadow:6px 6px 0 var(--yellow)}

/* Floating stickers */
.sticker{
  position:absolute;font-size:32px;
  animation:float 4s ease-in-out infinite;
  pointer-events:none;opacity:.8;
}
.sticker:nth-child(1){top:15%;right:12%;animation-delay:0s}
.sticker:nth-child(2){top:45%;right:5%;animation-delay:-1.5s;font-size:28px}
.sticker:nth-child(3){bottom:15%;right:20%;animation-delay:-3s;font-size:36px}
.sticker:nth-child(4){top:8%;left:75%;animation-delay:-0.5s;font-size:24px}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(5deg)}}

/* ===== ASK SECTION ===== */
.ask-section{padding:20px 20px 0}
.ask-header{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}
.ask-title{font-family:var(--grotesk);font-weight:700;font-size:24px;letter-spacing:-0.5px}
.ask-hand{font-family:var(--hand);font-size:18px;color:var(--pop);transform:rotate(-2deg);display:inline-block}

.ask-box{
  display:flex;gap:8px;
  border:2.5px solid var(--ink);border-radius:16px;
  padding:4px 4px 4px 16px;
  transition:box-shadow .15s;
}
.ask-box:focus-within{box-shadow:4px 4px 0 var(--yellow)}
.ask-input{
  flex:1;border:none;outline:none;background:none;
  font-family:var(--grotesk);font-size:16px;
  color:var(--ink);padding:10px 0;
}
.ask-input::placeholder{color:rgba(17,17,17,.3);font-style:italic}
.ask-btn{
  background:var(--ink);color:var(--bg);
  border:none;width:44px;height:44px;border-radius:12px;
  font-size:20px;cursor:pointer;flex-shrink:0;
  transition:transform .1s;
}
.ask-btn:active{transform:scale(.9)}
.ask-btn:disabled{opacity:.4}

.ask-box{margin-top:12px}
.ask-suggestions{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;
}
.ask-chip{
  font-family:var(--grotesk);font-size:12px;font-weight:600;
  padding:6px 14px;border-radius:100px;
  border:1.5px solid rgba(17,17,17,.12);
  background:none;cursor:pointer;color:var(--ink);
  transition:all .15s;
}
.ask-chip:active{transform:scale(.95);background:var(--yellow);border-color:var(--yellow)}

.ask-response{
  margin-top:16px;display:none;
  padding:16px 18px;
  background:var(--ink);color:var(--bg);
  border-radius:16px;border:2.5px solid var(--ink);
  font-size:15px;line-height:1.6;
  position:relative;
  box-shadow:4px 4px 0 var(--pop);
  max-height:60vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.ask-response.show{display:block}
.ask-response.show~.ask-box{margin-top:12px}
.ask-response.show~.ask-box .ask-input::placeholder{content:'"tell me more..."'}

.chat-user{
  background:rgba(255,255,255,.1);
  padding:8px 14px;border-radius:12px 12px 4px 12px;
  margin-bottom:10px;font-size:13px;
  color:rgba(255,255,255,.5);
  width:fit-content;max-width:80%;
  margin-left:auto;
}
.chat-wud{margin-bottom:12px}
.chat-wud:last-child{margin-bottom:0}

.place-link{
  color:var(--yellow);text-decoration:none;
  font-weight:700;
  border-bottom:2px solid rgba(255,225,77,.3);
  transition:border-color .15s;
}
.place-link:hover{border-color:var(--yellow)}
.ask-response .thinking{
  display:inline-flex;gap:4px;align-items:center;
}
.ask-response .thinking span{
  width:6px;height:6px;border-radius:50%;background:var(--pop);
  animation:bounce .6s ease-in-out infinite;
}
.ask-response .thinking span:nth-child(2){animation-delay:.1s}
.ask-response .thinking span:nth-child(3){animation-delay:.2s}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.ask-divider{
  text-align:center;padding:20px 0 8px;
  font-size:13px;color:rgba(17,17,17,.3);
  font-weight:600;
}

/* ===== VIBES SECTION ===== */
.vibes{
  padding:0 20px 20px;
}
.vibes-header{
  display:flex;align-items:baseline;gap:12px;
  margin-bottom:16px;
}
.vibes-header h2{
  font-family:var(--grotesk);font-weight:700;
  font-size:28px;letter-spacing:-1px;
}
.vibes-header .hand-note{
  font-family:var(--hand);font-size:18px;color:var(--pop);
  transform:rotate(-3deg);display:inline-block;
}

.vibes-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.vibe{
  padding:16px;border-radius:16px;
  border:2.5px solid var(--ink);
  cursor:pointer;position:relative;
  transition:transform .1s,box-shadow .1s;
  overflow:hidden;
}
.vibe:active{transform:scale(.96)}
.vibe:hover{box-shadow:4px 4px 0 var(--ink)}
.vibe-emoji{font-size:28px;margin-bottom:6px;display:block}
.vibe-name{font-weight:700;font-size:15px;line-height:1.2}
.vibe-quip{font-size:11px;opacity:.5;margin-top:2px;line-height:1.3}
.vibe-count{
  position:absolute;top:12px;right:12px;
  font-size:11px;font-weight:700;
  background:var(--ink);color:var(--bg);
  width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* Vibe colors */
.vibe[data-v="coffee"]{background:#F5E6D0}
.vibe[data-v="breakfast"]{background:#FFE8CC}
.vibe[data-v="casual"]{background:#FFD6CC}
.vibe[data-v="dinner"]{background:#F5D0E8}
.vibe[data-v="drinks"]{background:#E8D0FF}
.vibe[data-v="fitness"]{background:#CCF5DD}
.vibe[data-v="outdoors"]{background:#CCF0F5}
.vibe[data-v="culture"]{background:#FFD6D6}
.vibe[data-v="wellness"]{background:#D6F5DD}
.vibe[data-v="workspaces"]{background:#E0E0E8}
.vibe[data-v="tidal"]{background:#CCEFF5}

/* ===== SURPRISE ===== */
.surprise-strip{
  margin:0 20px 20px;padding:18px 24px;
  background:var(--pop);color:#fff;
  border-radius:16px;border:2.5px solid var(--ink);
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:transform .1s;
  box-shadow:4px 4px 0 var(--ink);
  position:relative;overflow:hidden;
}
.surprise-strip:active{transform:scale(.97);box-shadow:2px 2px 0 var(--ink)}
.surprise-title{font-weight:700;font-size:18px}
.surprise-sub{font-size:12px;opacity:.7;margin-top:2px}
.surprise-dice{font-size:28px;animation:shake 2s ease-in-out infinite}
@keyframes shake{0%,100%{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}

/* ===== RESULTS ===== */
.results{padding:0 20px 32px}
.results-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0 16px;
  position:sticky;top:0;background:var(--bg);z-index:10;
}
.results-title{
  font-weight:700;font-size:24px;letter-spacing:-0.5px;
  display:flex;align-items:center;gap:10px;
}
.results-back{
  background:none;border:2px solid rgba(17,17,17,.15);
  width:36px;height:36px;border-radius:50%;
  font-size:18px;cursor:pointer;display:flex;
  align-items:center;justify-content:center;
  transition:all .15s;
}
.results-back:active{background:var(--ink);color:var(--bg);border-color:var(--ink)}

.card{
  border:2.5px solid var(--ink);
  border-radius:16px;padding:16px 18px;
  margin-bottom:10px;cursor:pointer;
  transition:transform .1s,box-shadow .1s;
  position:relative;
  background:var(--bg);
}
.card:active{transform:scale(.98)}
.card:hover{box-shadow:4px 4px 0 var(--ink)}
.card.expanded{box-shadow:4px 4px 0 var(--ink)}

.card-img{
  margin:-16px -18px 12px;border-radius:13px 13px 0 0;overflow:hidden;
  max-height:200px;
}
.card-img img{width:100%;height:200px;object-fit:cover;display:block}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-place{
  font-family:var(--serif);font-style:italic;
  font-size:22px;line-height:1.1;letter-spacing:-0.3px;
}
.card-color{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
  margin-top:8px;
}

.card-by{
  font-size:12px;color:rgba(17,17,17,.4);
  margin-top:4px;font-weight:500;
}
.card-by strong{color:var(--ink);font-weight:600}
.card-by-link{color:var(--ink);font-weight:600;text-decoration:none;border-bottom:1.5px solid rgba(17,17,17,.2);transition:border-color .15s}
.card-by-link:active{border-color:var(--pop)}

.card-detail{
  max-height:0;overflow:hidden;
  transition:max-height .3s cubic-bezier(.4,0,.2,1);
}
.card.expanded .card-detail{max-height:800px}

.card-notes{
  font-family:var(--hand);font-size:20px;
  color:var(--pop);line-height:1.4;
  margin:12px 0 10px;
  padding-left:12px;
  border-left:3px solid var(--pop);
}

.card-links{display:flex;gap:8px;flex-wrap:wrap}
.card-links a{
  font-size:11px;font-weight:700;
  background:var(--ink);color:var(--bg);
  padding:6px 14px;border-radius:100px;
  text-decoration:none;transition:opacity .15s;
}
.card-links a:active{opacity:.7}

/* Featured card — 2+ recommenders, uses category colour */
.card.featured{
  color:#fff;
  box-shadow:6px 6px 0 var(--ink);
}
.card.featured .card-place{color:#fff}
.card.featured .card-by{color:rgba(255,255,255,.5)}
.card.featured .card-by strong{color:#fff}
.card.featured .card-by-link{color:#fff;border-bottom-color:rgba(255,255,255,.3)}
.card.featured .card-by-link:active{border-color:#fff}
.card.featured .card-notes{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.card.featured .card-links a{background:#fff;color:var(--ink)}
.card.featured .card-color{display:none}

/* ===== CREW SECTION ===== */
.crew{padding:32px 20px;background:var(--ink);color:var(--bg)}
.crew h2{
  font-family:var(--grotesk);font-weight:700;
  font-size:28px;letter-spacing:-1px;
  margin-bottom:4px;
}
.crew-sub{font-family:var(--hand);font-size:20px;color:var(--pop);margin-bottom:20px}
.crew-grid{display:flex;flex-wrap:wrap;gap:10px}
.crew-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:100px;
  border:2px solid rgba(255,255,255,.15);
  cursor:pointer;transition:all .15s;
  font-size:14px;font-weight:600;
}
.crew-chip:hover{border-color:var(--pop);background:rgba(255,51,102,.1)}
.crew-chip:active{transform:scale(.95)}
.crew-chip .chip-avatar{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;
}
.crew-chip .chip-count{font-size:11px;opacity:.4}

/* ===== OVERLAY ===== */
.overlay{
  position:fixed;inset:0;z-index:200;
  display:flex;flex-direction:column;justify-content:flex-start;align-items:center;
  padding:80px 32px 40px;text-align:center;
  opacity:0;pointer-events:none;transition:opacity .15s;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.overlay.show{opacity:1;pointer-events:auto}
.overlay-bg{position:absolute;inset:0;background:var(--ink)}
.overlay-content{position:relative;z-index:1;color:var(--bg);max-width:500px;width:100%}
.overlay-eyebrow{
  font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--pop);margin-bottom:16px;
}
.overlay-place{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(36px,10vw,64px);letter-spacing:-2px;line-height:.95;
}
.overlay-notes{
  font-family:var(--hand);font-size:24px;
  color:var(--yellow);line-height:1.4;
  margin-top:20px;
}
.overlay-by{font-size:12px;opacity:.3;letter-spacing:2px;text-transform:uppercase;margin-top:24px}
.overlay-links{margin-top:16px;display:flex;gap:10px;justify-content:center}
.overlay-links a{
  font-size:12px;font-weight:700;color:var(--bg);
  padding:10px 24px;border-radius:100px;
  border:2px solid rgba(255,255,255,.2);
  text-decoration:none;transition:all .15s;
}
.overlay-links a:hover{background:rgba(255,255,255,.1)}
.overlay-close{
  position:absolute;top:20px;right:20px;z-index:2;
  background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.4);
  color:#fff;width:48px;height:48px;border-radius:50%;
  font-size:22px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  transition:all .15s;
}
.overlay-close:active{background:var(--pop);border-color:var(--pop);transform:scale(.9)}
.overlay-another{
  margin-top:24px;
  font-family:var(--grotesk);font-weight:700;font-size:14px;
  padding:12px 28px;border-radius:100px;
  background:var(--pop);color:#fff;
  border:none;cursor:pointer;
  transition:transform .1s;
}
.overlay-another:active{transform:scale(.95)}

/* ===== IG PHOTO GRID ===== */
.ol-ig-grid{margin-top:24px;width:100%}
.card-ig-grid{margin-top:14px}
.ig-profile{display:flex;align-items:center;gap:10px;margin-bottom:10px;text-decoration:none;color:inherit}
.ig-profile-pic{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;background:rgba(128,128,128,.15)}
.ig-profile-pic img{width:100%;height:100%;object-fit:cover;display:block}
.ig-profile-info{flex:1;min-width:0}
.ig-profile-name{font-size:13px;font-weight:700;line-height:1.3;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.ig-verified{color:#0095f6;font-size:13px;line-height:1}
.ig-profile-stats{font-size:11px;opacity:.5;margin-top:2px;letter-spacing:.3px}
.ig-profile-arrow{font-size:14px;opacity:.3;flex-shrink:0}
.ig-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;border-radius:10px;overflow:hidden}
.ig-imgs a{display:block;aspect-ratio:1;overflow:hidden}
.ig-imgs img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}
.ig-imgs a:active img{transform:scale(.96)}
.ig-loading{font-size:12px;opacity:.5;padding:12px 0;text-align:center;letter-spacing:1px}

/* ===== FOOTER ===== */
.footer{
  padding:40px 20px;text-align:center;
  border-top:2.5px solid var(--ink);
}
.footer-title{
  font-family:var(--grotesk);font-weight:700;
  font-size:clamp(48px,15vw,100px);
  letter-spacing:-3px;line-height:.85;
  opacity:.06;
}
.footer p{font-size:12px;opacity:.3;margin-top:8px;letter-spacing:1px}

/* ===== SCREENS ===== */
.screen{display:none}
.screen.active{display:block}

/* ===== HOME PREVIEW ===== */
.home-preview{padding:0 20px 20px}
.home-preview-header{
  display:flex;align-items:baseline;gap:10px;margin-bottom:14px;
}
.home-preview-header h2{
  font-family:var(--grotesk);font-weight:700;font-size:24px;letter-spacing:-0.5px;
}
.home-preview-grid{
  display:flex;flex-direction:column;gap:10px;
}
.preview-card{
  border:2.5px solid var(--ink);border-radius:16px;
  padding:14px 16px;cursor:pointer;
  transition:transform .1s,box-shadow .1s;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.preview-card:active{transform:scale(.98)}
.preview-card:hover{box-shadow:4px 4px 0 var(--ink)}
.preview-card-left{display:flex;flex-direction:column;gap:2px}
.preview-card-place{font-family:var(--serif);font-style:italic;font-size:20px;line-height:1.1}
.preview-card-meta{font-size:11px;color:rgba(17,17,17,.4);font-weight:500}
.preview-card-meta strong{color:var(--ink)}
.preview-card-cat{
  font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;color:#fff;flex-shrink:0;white-space:nowrap;
}

.home-stats{
  display:flex;align-items:center;justify-content:center;gap:16px;
  padding:24px 20px 32px;
}
.stat{font-size:14px;font-weight:600;text-align:center}
.stat-num{font-size:28px;font-weight:700;font-family:var(--grotesk);letter-spacing:-1px;display:block}
.stat-dot{font-size:20px;opacity:.15}

/* ===== BROWSE ALL ===== */
.all-spots-btn{
  margin:0 20px 20px;padding:16px 24px;
  background:var(--ink);color:var(--bg);
  border-radius:16px;border:none;
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:transform .1s;
  font-family:var(--grotesk);font-size:16px;font-weight:700;
  width:calc(100% - 40px);
  box-shadow:4px 4px 0 var(--yellow);
}
.all-spots-btn:active{transform:scale(.97);box-shadow:2px 2px 0 var(--yellow)}
.all-spots-btn span{font-size:20px}

/* ===== CARD REVIEW ===== */
.card-review{margin-top:14px;padding-top:12px;border-top:1.5px solid rgba(17,17,17,.08)}
.card.featured .card-review{border-top-color:rgba(255,255,255,.15)}
.review-toggle{
  font-family:var(--grotesk);font-size:13px;font-weight:600;
  background:none;border:1.5px solid rgba(17,17,17,.12);
  padding:8px 16px;border-radius:100px;cursor:pointer;
  color:var(--ink);transition:all .15s;
}
.review-toggle:active{transform:scale(.95);background:var(--yellow);border-color:var(--yellow)}
.card.featured .review-toggle{color:#fff;border-color:rgba(255,255,255,.25)}
.card.featured .review-toggle:active{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4)}
.review-form{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.review-input{
  font-family:var(--grotesk);font-size:14px;
  padding:10px 14px;border:1.5px solid rgba(17,17,17,.12);
  border-radius:10px;background:var(--bg);color:var(--ink);outline:none;
}
.review-input:focus{border-color:var(--ink)}
.review-input::placeholder{color:rgba(17,17,17,.25)}
.card.featured .review-input{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff}
.card.featured .review-input::placeholder{color:rgba(255,255,255,.35)}
.review-rating{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.review-rating-label{font-size:12px;font-weight:600;opacity:.5}
.card.featured .review-rating-label{color:#fff}
.rating-btn{
  font-size:11px;padding:4px 8px;border-radius:100px;
  border:1.5px solid rgba(17,17,17,.1);background:none;
  cursor:pointer;transition:all .15s;
}
.rating-btn:active{transform:scale(.9)}
.rating-btn.selected{background:var(--yellow);border-color:var(--yellow)}
.card.featured .rating-btn{border-color:rgba(255,255,255,.2)}
.card.featured .rating-btn.selected{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5)}
.review-submit{
  font-family:var(--grotesk);font-size:14px;font-weight:700;
  padding:10px;border-radius:10px;
  background:var(--ink);color:var(--bg);
  border:none;cursor:pointer;transition:all .15s;
}
.review-submit:active{transform:scale(.98)}
.review-submit:disabled{opacity:.4}
.card.featured .review-submit{background:#fff;color:var(--ink)}
.review-thanks{
  margin-top:10px;font-family:var(--hand);
  font-size:18px;color:var(--pop);
}
.card.featured .review-thanks{color:var(--yellow)}

/* ===== SUGGEST FAB ===== */
.fab{
  position:fixed;
  right:14px;
  bottom:max(112px, calc(92px + env(safe-area-inset-bottom)));
  z-index:101;
  min-height:46px;
  padding:0 12px 0 8px;
  border-radius:999px;
  background:rgba(255,253,247,.92);
  color:var(--ink);
  border:1.5px solid rgba(17,17,17,.16);
  cursor:pointer;
  box-shadow:0 8px 22px rgba(17,17,17,.14);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:all .18s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.fab-icon{
  width:26px;
  height:26px;
  border-radius:50%;
  background:var(--pop);
  color:#fff;
  font-size:18px;
  line-height:1;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .18s ease, background .18s ease;
}
.fab-label{
  font-family:var(--grotesk);
  font-size:12px;
  font-weight:600;
  letter-spacing:.15px;
  text-transform:none;
  opacity:.82;
}
.fab:hover{box-shadow:0 10px 26px rgba(17,17,17,.18)}
.fab:active{transform:translateY(1px) scale(.98)}
.fab.open{background:rgba(255,253,247,.96);border-color:rgba(17,17,17,.2)}
.fab.open .fab-icon{transform:rotate(45deg);background:var(--ink)}

@media (max-width: 380px){
  .fab{right:10px;bottom:max(106px, calc(86px + env(safe-area-inset-bottom)));padding:0 10px 0 7px;}
  .fab-label{font-size:11px}
  .fab-icon{width:24px;height:24px;font-size:16px}
}

.suggest-overlay{
  position:fixed;inset:0;z-index:99;
  background:rgba(17,17,17,.6);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:flex-end;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.suggest-overlay.show{opacity:1;pointer-events:auto}
.suggest-card{
  background:var(--bg);border-radius:20px;
  border:2.5px solid var(--ink);
  padding:28px 24px;
  width:100%;max-width:400px;
  box-shadow:6px 6px 0 var(--pop);
  transform:translateY(20px);
  transition:transform .2s;
  position:relative;
}
.suggest-overlay.show .suggest-card{transform:translateY(0)}
.suggest-close{
  position:absolute;top:12px;right:12px;
  background:none;border:none;font-size:20px;cursor:pointer;opacity:.3;
  transition:opacity .15s;
}
.suggest-close:hover{opacity:1}
.suggest-title{
  font-family:var(--grotesk);font-weight:700;font-size:22px;
  letter-spacing:-0.5px;margin-bottom:4px;
}
.suggest-sub{font-size:13px;opacity:.4;margin-bottom:18px}
.suggest-input{
  display:block;width:100%;
  font-family:var(--grotesk);font-size:15px;
  padding:12px 16px;
  border:2px solid rgba(17,17,17,.12);border-radius:12px;
  background:none;color:var(--ink);
  margin-bottom:10px;outline:none;
  transition:border-color .15s;
}
.suggest-input:focus{border-color:var(--ink)}
.suggest-input::placeholder{color:rgba(17,17,17,.25)}
.suggest-submit{
  width:100%;padding:14px;
  font-family:var(--grotesk);font-size:15px;font-weight:700;
  background:var(--ink);color:var(--bg);
  border:none;border-radius:12px;
  cursor:pointer;margin-top:4px;
  transition:all .15s;
}
.suggest-submit:active{transform:scale(.98)}
.suggest-submit:disabled{opacity:.4}
.suggest-success{text-align:center;padding:20px 0}
.suggest-success p{margin-top:8px;font-size:14px;opacity:.6}

/* ===== FAV BUTTON ===== */
.fav-btn{
  position:absolute;top:12px;right:12px;z-index:2;
  background:rgba(255,255,255,0.85);border:none;
  width:44px;height:44px;padding:0;
  border-radius:50%;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  cursor:pointer;transition:transform .15s;
  display:flex;align-items:center;justify-content:center;
}
.fav-btn:active{transform:scale(.8)}
.fav-btn svg{width:20px;height:20px}
.fav-btn .heart-fill{display:none}
.fav-btn .heart-outline{display:block}
.fav-btn.faved .heart-fill{display:block}
.fav-btn.faved .heart-outline{display:none}

/* Default colours */
.fav-btn .heart-outline{stroke:rgba(17,17,17,0.5);fill:none;stroke-width:2}
.fav-btn.faved .heart-fill{fill:var(--pop);stroke:var(--pop);stroke-width:2}

/* Featured card (dark bg) */
.card.featured .fav-btn{background:rgba(0,0,0,0.3)}
.card.featured .fav-btn .heart-outline{stroke:#fff}
.card.featured .fav-btn.faved .heart-fill{fill:#fff;stroke:#fff}

/* Has-image cards: move heart below image */
.card.has-image .fav-btn{top:auto;top:unset;bottom:unset}
.card.has-image .fav-btn{top:12px}

/* Heart pop animation */
@keyframes heartPop {
  0% { transform: scale(1); }
  40% { transform: scale(1.4); }
  70% { transform: scale(0.9); }
  100% { transform: scale(1); }
}
.fav-btn.popping { animation: heartPop 0.3s ease; }

/* ===== BOTTOM NAV ===== */
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  background: var(--bg); border-top: 1.5px solid var(--ink);
  display: flex; align-items: stretch;
  padding-bottom: env(safe-area-inset-bottom);
}
.bnav-tab {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 2px;
  padding: 10px 0 8px; background: none; border: none; cursor: pointer;
  font-family: var(--grotesk); font-size: 10px; font-weight: 600;
  letter-spacing: .5px; text-transform: uppercase; color: rgba(17,17,17,.4);
  transition: color .15s; position: relative;
}
.bnav-tab.active { color: var(--ink); }
.bnav-tab:active { opacity: .7; }
.bnav-icon { font-size: 20px; line-height: 1; }
.bnav-label { }
.bnav-tab.bnav-add .bnav-plus{
  width:22px;
  height:22px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  font-weight:700;
  line-height:1;
  color:#fff;
  background:var(--pop);
  box-shadow:0 2px 6px rgba(255,51,102,.35);
}
.bnav-tab.bnav-add.open{color:var(--ink)}
.bnav-tab.bnav-add.open .bnav-plus{background:var(--ink)}
.bnav-badge {

  position: absolute; top: 6px; right: calc(50% - 22px);
  background: var(--pop); color: #fff;
  border-radius: 10px; padding: 0 5px; font-size: 9px; font-weight: 700; min-width: 16px; text-align: center;
}

/* Empty state */
.empty-state{
  text-align:center;padding:60px 20px;
  color:rgba(17,17,17,.4);
}
.empty-state-emoji{font-size:48px;margin-bottom:12px;display:block}
.empty-state-text{font-size:16px;line-height:1.5}

/* ===== RESPONSIVE ===== */
@media(min-width:500px){
  .vibes-grid{grid-template-columns:repeat(3,1fr)}
}

/* ===== AREA FILTER ===== */
.areas{padding:0 20px 20px}
.areas-header{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}
.areas-header h2{font-family:var(--grotesk);font-weight:700;font-size:24px;letter-spacing:-0.5px}
.areas-header .hand-note{font-family:var(--hand);font-size:18px;color:var(--pop);transform:rotate(-3deg);display:inline-block}
#areaGrid{display:flex;flex-wrap:wrap;gap:8px}
.area-chip{
  font-family:var(--grotesk);font-size:13px;font-weight:600;
  padding:8px 16px;border-radius:100px;
  border:2px solid var(--ink);background:none;color:var(--ink);
  cursor:pointer;transition:all .15s;
  display:inline-flex;align-items:center;gap:6px;
}
.area-chip:active{transform:scale(.95);background:var(--ink);color:var(--bg)}
.area-chip:hover{box-shadow:3px 3px 0 var(--yellow)}
.area-count{
  font-size:11px;opacity:.4;
}

/* ===== PROFILE HEADER ===== */
.profile-header{
  display:flex;align-items:center;gap:16px;
  padding:20px 0 16px;
  border-bottom:2px solid rgba(17,17,17,.08);
  margin-bottom:16px;
}
.profile-avatar{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;color:#fff;
  flex-shrink:0;
}
.profile-info{display:flex;flex-direction:column;gap:4px}
.profile-name{font-family:var(--grotesk);font-weight:700;font-size:24px;letter-spacing:-0.5px;margin:0}
.profile-bio{font-size:14px;opacity:.6;margin:0;line-height:1.4}
.profile-stats{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  font-size:13px;font-weight:600;color:rgba(17,17,17,.5);
}

/* Card area badge */
.card-area{
  font-size:11px;font-weight:600;
  color:var(--blue);
}
.card.featured .card-area{color:rgba(255,255,255,.6)}


/* Tags */
.card-tags {
  margin: 6px 0 8px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.tag {
  display: inline-block;
  padding: 2px 8px;
  background: rgba(0, 0, 0, 0.08);
  border-radius: 12px;
  font-size: 11px;
  font-weight: 500;
  color: #666;
  text-transform: lowercase;
}

/* Tag color variants */
.tag-datenight { background: #FF336620; color: #B8003A; }
.tag-sunset { background: #FF6D0020; color: #E55A00; }
.tag-solofriendly { background: #00C85320; color: #00A844; }
.tag-rainyday { background: #3D5AFE20; color: #2A4DE8; }
.tag-brunch { background: #FF6D0020; color: #E55A00; }
.tag-latenight { background: #AA00FF20; color: #8E00D4; }
.tag-outdoor { background: #1A7A8A20; color: #0D6B79; }
.tag-petfriendly { background: #00C85320; color: #00A844; }

/* Tag filtering section */
.tags {
  margin-bottom: 32px;
}

.tags-header {
  display: flex; 
  align-items: baseline;
  gap: 16px;
  margin-bottom: 16px;
}

.tags-header h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 700;
}

#tagGrid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tag-chip {
  padding: 8px 16px;
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tag-chip:hover {
  background: #e9ecef;
  transform: translateY(-1px);
}

.tag-count {
  background: rgba(0,0,0,0.1);
  padding: 2px 6px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
}

/* Auth UI Styles */
.auth-bar {
  background: var(--bg);
  border-bottom: 1px solid rgba(0,0,0,0.1);
  padding: 8px 16px;
  position: sticky;
  top: 0;
  z-index: 150;
}

.auth-content {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

.auth-signed-out, .auth-signed-in {
  display: flex;
  align-items: center;
  gap: 8px;
}

.auth-user-name {
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 3px;
}

.btn-sm {
  padding: 6px 12px;
  font-size: 13px;
}

/* Modal Styles */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal-content {
  background: var(--bg);
  border-radius: 12px;
  max-width: 400px;
  width: 90%;
  box-shadow: 0 20px 40px rgba(0,0,0,0.1);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px 0;
}

.modal-header h3 {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--ink);
}

.modal-close {
  background: none;
  border: none;
  font-size: 24px;
  color: var(--ink);
  cursor: pointer;
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal-body {
  padding: 24px;
}

.modal-body p {
  color: var(--ink);
  margin-bottom: 16px;
  font-size: 14px;
}

.input {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(0,0,0,0.2);
  border-radius: 8px;
  font-size: 14px;
  margin-bottom: 16px;
  background: var(--bg);
  color: var(--ink);
}

.input:focus {
  outline: none;
  border-color: var(--pop);
}

.auth-message {
  padding: 12px;
  border-radius: 8px;
  margin-top: 12px;
  font-size: 14px;
}

.auth-message.success {
  background: rgba(0, 200, 80, 0.1);
  color: #00C850;
  border: 1px solid rgba(0, 200, 80, 0.2);
}

.auth-message.error {
  background: rgba(255, 0, 0, 0.1);
  color: #FF3366;
  border: 1px solid rgba(255, 0, 0, 0.2);
}

.modal-body label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px;
  font-size: 14px;
  color: var(--ink);
}

textarea.input {
  resize: vertical;
  min-height: 80px;
}


/* Toast notifications */
.wud-toast {
  position: fixed;
  bottom: 90px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--ink);
  color: var(--bg);
  padding: 12px 24px;
  border-radius: 24px;
  font-family: var(--serif);
  font-size: 14px;
  z-index: 500;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.wud-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* Saved spots section on profile pages */
.saved-spots-section {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 2px dashed rgba(0,0,0,0.1);
}
.saved-spots-header {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 12px;
  padding: 0 4px;
}

/* My List sign-in CTA */
.my-list-sign-in {
  text-align: center;
  padding: 48px 20px;
}

/* Profile actions */
.profile-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.profile-actions .btn {
  font-size: 13px;
}
