@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}
@keyframes breathe{0%,100%{opacity:0.6}50%{opacity:1}}
@keyframes successPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes goldGlow{0%,100%{box-shadow:0 0 0 1px rgba(184,150,12,0.3),0 2px 8px rgba(184,150,12,0.25),inset 0 0 8px rgba(184,150,12,0.1)}50%{box-shadow:0 0 0 2px rgba(184,150,12,0.5),0 4px 16px rgba(184,150,12,0.4),inset 0 0 12px rgba(184,150,12,0.2)}}
@keyframes gentleBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.fade-section{animation:fadeIn 0.3s ease both}

/* Promo strip — remove this block when event ends */
.promo-strip{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#0c3d1f 0%,#1a5c30 50%,#0c3d1f 100%);color:#fff;text-decoration:none;font-family:Inter,'Inter Fallback',sans-serif;font-size:13px;line-height:1;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}
.promo-strip::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);background-size:200% 100%;animation:promoShimmer 3s ease infinite}
@keyframes promoShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.promo-strip-flag{font-size:18px;flex-shrink:0}
.promo-strip-text{font-weight:400;letter-spacing:.2px}
.promo-strip-text strong{font-weight:700;color:#e8c547}
.promo-strip-cta{font-size:11px;font-weight:700;color:#e8c547;background:rgba(232,197,71,.15);padding:3px 10px;border-radius:20px;white-space:nowrap;border:1px solid rgba(232,197,71,.3)}
.promo-strip:hover .promo-strip-cta{background:rgba(232,197,71,.25)}
@media(max-width:480px){.promo-strip{font-size:12px;gap:6px;padding:7px 12px}.promo-strip-cta{font-size:10px;padding:2px 8px}}

:root {
  --bg: #F4F4F4;
  --surface: #FFFFFF;
  --gold: #B8960C;
  --gold-light: #F5E9C0;
  --gold-muted: #D4A017;
  --text-primary: #1A1A1A;
  --text-secondary: #6B6B6B;
  --text-muted: #9E9E9E;
  --border: #E0E0E0;
  --danger: #C0392B;
  --success: #2E7D32;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 2px 12px rgba(0,0,0,0.08);
  --shadow-hover: 0 4px 20px rgba(0,0,0,0.16);
  --shadow-active: 0 1px 4px rgba(0,0,0,0.12);
  --transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;outline:none;}
html,body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;touch-action:pan-x pan-y;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}
a{color:var(--gold);text-decoration:none}
a:hover{text-decoration:underline}

.header{
  background:var(--surface);
  border-bottom:1px solid rgba(224,224,224,0.6);
  padding:8px 16px; /* Reduced for mobile */
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 1px 3px rgba(0,0,0,0.04);
  min-height:56px; /* Fixed height on mobile */
  display:flex;
  align-items:center;
}
.header-inner{max-width:900px;margin:0 auto;width:100%}

/* Desktop: more padding and natural height */
@media(min-width:768px){
  .header{
    padding:12px 20px;
    min-height:auto;
  }
}
.breadcrumb{font-size:12px;color:var(--text-muted);margin-bottom:4px}
.breadcrumb a{color:var(--text-secondary)}
.dest-title{display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap}
.dest-name{font-size:24px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-0.02em}
.dest-name .flag{font-size:28px}
.dest-country{font-size:14px;color:var(--text-secondary);font-weight:400}
.add-tip-btn{background:var(--gold);color:#fff;border:none;border-radius:50px;padding:12px 24px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition),box-shadow var(--transition),transform var(--transition);min-height:44px;white-space:nowrap;box-shadow:0 2px 12px rgba(184,150,12,0.3),inset 0 1px 0 rgba(255,255,255,0.2);display:flex;align-items:center;gap:8px;letter-spacing:-0.01em}
.add-tip-btn:hover{background:var(--gold-muted);box-shadow:0 4px 20px rgba(184,150,12,0.45),0 0 0 1px rgba(184,150,12,0.3),inset 0 1px 0 rgba(255,255,255,0.25);transform:translateY(-1px)}
.add-tip-btn:active{transform:scale(0.97);box-shadow:var(--shadow-active),inset 0 1px 0 rgba(255,255,255,0.15)}
.add-tip-btn .plus{display:inline-block;font-size:22px;font-weight:700;line-height:1;transition:transform 300ms cubic-bezier(0.34,1.56,0.64,1)}
.add-tip-btn:hover .plus{transform:rotate(90deg)}

      /* --- Nav links (extensible) --- */
      .nav-links { display: flex; align-items: center; gap: 0; list-style: none; margin: 0; padding: 0; flex-shrink: 0; }
      .nav-links li { display: flex; align-items: center; }
      .nav-links li:not(:last-child)::after { content: ''; display: block; width: 1px; height: 14px; background: var(--border); margin: 0 0.1rem; }
      .nav-links a { font-size: 0.8rem; color: var(--text-secondary); text-decoration: none; padding: 0.35rem 0.55rem; border-radius: var(--radius-sm); transition: var(--transition); white-space: nowrap; }
      .nav-links a:hover { color: var(--gold); background: var(--gold-light); }
      /* --- Responsive --- */
      @media (max-width: 480px) {
        .nav-links { display: none; }
      }

.main{
  max-width:900px;
  margin:0 auto;
  padding:30px 20px 40px;
}
/* Desktop: more top spacing */
@media(min-width:768px){
  .main{
    padding-top:32px;
  }
}

/* Hotel pills */
.hotel-pills{display:flex;gap:8px;overflow-x:auto;padding:8px 0;scrollbar-width:none}
.hotel-pills::-webkit-scrollbar{display:none}
.hotel-pill{flex-shrink:0;padding:8px 16px;border:1px solid rgba(224,224,224,0.8);border-radius:20px;font-size:13px;font-family:inherit;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);min-height:44px;display:flex;align-items:center}
.hotel-pill:hover{border-color:var(--gold);transform:translateY(-1px)}
.hotel-pill:active{transform:scale(0.97)}
.hotel-pill.active{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 4px 12px rgba(184,150,12,0.35),0 0 0 1px rgba(184,150,12,0.2)}

/* Hotel card */
.hotel-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:16px;border-top:1px solid rgba(255,255,255,0.6);transition:box-shadow var(--transition),transform var(--transition)}
.hotel-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.hotel-name{font-size:18px;font-weight:600;letter-spacing:-0.01em}
.hotel-address{font-size:13px;color:var(--text-muted);margin:4px 0 8px}
.hotel-stars-static{color:var(--gold);font-size:14px;margin-bottom:12px}
.hotel-overall{font-size:15px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.hotel-overall .stars{color:var(--gold)}

.facility-ratings{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.facility-row{display:flex;align-items:center;gap:10px;font-size:13px}
.facility-label{width:110px;flex-shrink:0;color:var(--text-secondary)}
.facility-bar{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden;min-width:80px}
.facility-bar-fill{height:100%;background:var(--gold);border-radius:4px;transition:width var(--transition)}
.facility-score{width:40px;text-align:right;font-weight:600;color:var(--text-primary);font-size:13px}
.facility-count{width:50px;text-align:right;font-size:11px;color:var(--text-muted)}

.hotel-reviews{margin-top:12px}
.hotel-review{padding:10px 0;border-top:1px solid var(--border);font-size:13px;color:var(--text-secondary)}
.hotel-review:first-child{border-top:none}
.hotel-review .review-rating{color:var(--gold);margin-right:6px}
.show-all-reviews{font-size:13px;color:var(--gold);cursor:pointer;background:none;border:none;font-family:inherit;padding:6px 0;min-height:44px}

.rate-hotel-btn{background:none;border:1px solid var(--gold);color:var(--gold);border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;transition:var(--transition);min-height:44px;margin-top:8px}
.rate-hotel-btn:hover{background:var(--gold-light)}

/* Map */
.map-section{margin:20px 0}
.map-container{height:280px;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
@media(min-width:600px){.map-container{height:380px}}
.map-fallback{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}

/* Category tabs */
.category-tabs{display:flex;gap:6px;overflow-x:auto;padding:12px 0;position:sticky;top:56px;background:var(--bg);z-index:50;scrollbar-width:none}
.category-tabs::-webkit-scrollbar{display:none}
.cat-tab{flex-shrink:0;padding:8px 14px;border:1px solid rgba(224,224,224,0.8);border-radius:20px;font-size:13px;font-family:inherit;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);min-height:44px;display:flex;align-items:center}
.cat-tab:hover{border-color:var(--gold);transform:translateY(-1px)}
.cat-tab:active{transform:scale(0.97)}
.cat-tab.active{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 4px 12px rgba(184,150,12,0.35),0 0 0 1px rgba(184,150,12,0.2)}

.sort-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.sort-row label{font-size:13px;color:var(--text-muted)}
.sort-select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px;font-family:inherit;background:var(--surface);min-height:44px}

/* Tip card */
.tip-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px;transition:box-shadow var(--transition),transform var(--transition);border-top:1px solid rgba(255,255,255,0.6);animation:fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both}
.tip-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.tip-card:active{transform:scale(0.99)}
.tip-card.highlighted{border:2px solid var(--gold)}
.tip-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.tip-category-pill{font-size:11px;padding:3px 10px;border-radius:10px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}
.tip-category-pill.food{background:#FFF3E0;color:#E65100}
.tip-category-pill.outdoors{background:#E8F5E9;color:#2E7D32}
.tip-category-pill.wellness{background:#F3E5F5;color:#7B1FA2}
.tip-category-pill.fun{background:#E3F2FD;color:#1565C0}
.tip-category-pill.shopping{background:#FFF8E1;color:#F57F17}
.upvote-btn{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px;font-family:inherit;cursor:pointer;transition:all var(--transition);min-height:44px;color:var(--text-secondary)}
.upvote-btn.voted{border-color:var(--gold);color:var(--gold);background:var(--gold-light);box-shadow:0 0 0 1px rgba(184,150,12,0.3),0 2px 8px rgba(184,150,12,0.25),inset 0 0 8px rgba(184,150,12,0.1)}
.upvote-btn.just-voted{animation:successPulse 0.4s ease both}
.upvote-btn:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 2px 8px rgba(184,150,12,0.2)}
.upvote-btn:active{transform:scale(0.95)}
.tip-name{font-size:16px;font-weight:600;margin-bottom:4px;letter-spacing:-0.01em}
.tip-meta{font-size:12px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.tip-text{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:10px;font-style:italic}
.tip-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.tip-action{font-size:12px;color:var(--text-secondary);background:var(--bg);padding:4px 10px;border-radius:10px;cursor:pointer;border:none;font-family:inherit;min-height:36px;display:flex;align-items:center;gap:4px;transition:var(--transition)}
.tip-action:hover{color:var(--gold)}
.tip-date{font-size:11px;color:var(--text-muted);margin-left:auto}

/* Comments */
.comments-section{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:none}
.comments-section.open{display:block}
.comment{padding:8px 0;font-size:13px;color:var(--text-secondary);animation:slideInLeft 0.3s cubic-bezier(0.4, 0, 0.2, 1) both}
.comment.just-added{animation:gentleBounce 0.5s ease both}
.comment-author{font-weight:500;color:var(--text-primary);letter-spacing:-0.01em}
.comment-time{font-size:11px;color:var(--text-muted)}
.comment-input-row{display:flex;gap:8px;margin-top:8px}
.comment-input-row input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;min-height:44px}
.comment-input-row input:focus{outline:none;border-color:var(--gold)}
.comment-input-row button{background:var(--gold);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-family:inherit;cursor:pointer;min-height:44px;font-weight:500;transition:all var(--transition);box-shadow:0 1px 4px rgba(184,150,12,0.25)}
.comment-input-row button:hover{background:var(--gold-muted);box-shadow:0 2px 8px rgba(184,150,12,0.35);transform:translateY(-1px)}
.comment-input-row button:active{transform:scale(0.97)}

/* Contacts section */
.contacts-section{margin-top:24px}
.contacts-disclaimer{background:#FFF8E1;border:1px solid var(--gold-light);border-radius:var(--radius);padding:12px 16px;font-size:12px;color:var(--text-secondary);margin-bottom:12px}
.contact-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:10px;border-top:1px solid rgba(255,255,255,0.6);transition:box-shadow var(--transition),transform var(--transition);animation:fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both}
.contact-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.contact-what{font-weight:600;font-size:15px}
.contact-detail{font-size:13px;color:var(--text-secondary);margin-top:4px}
.contact-notes{font-size:13px;color:var(--text-muted);margin-top:4px;font-style:italic}

/* Bottom sheet */
.sheet-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;opacity:0;transition:opacity 200ms ease,backdrop-filter 200ms ease}
.sheet-overlay.open{display:flex;opacity:1;justify-content:center;align-items:flex-end}
.sheet{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:500px;max-height:85vh;max-height:85dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom));animation:slideUp 200ms ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}
.sheet h3{font-size:18px;font-weight:600;margin-bottom:16px}
.sheet-close{position:sticky;top:0;float:right;background:#fff;border:1px solid var(--border);box-shadow:0 0 0 5px #fff;font-size:16px;cursor:pointer;color:var(--text-muted);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:2;margin-top:-8px;margin-bottom:-24px;transition:background 150ms ease}.sheet-close:active{background:var(--bg)}

/* Form elements */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;min-height:44px;transition:var(--transition)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-light)}
.form-group textarea{resize:vertical;min-height:80px}
.char-count{font-size:11px;color:var(--text-muted);text-align:right;margin-top:2px}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}

.category-select{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cat-option{padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;transition:var(--transition);font-size:13px;min-height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.cat-option:hover{border-color:var(--gold)}
.cat-option.selected{background:var(--gold);color:#fff;border-color:var(--gold)}
.cat-option .cat-icon{font-size:24px}

.submit-btn{width:100%;padding:14px;background:var(--gold);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;min-height:48px;transition:all var(--transition);box-shadow:0 2px 8px rgba(184,150,12,0.25),inset 0 1px 0 rgba(255,255,255,0.2);letter-spacing:-0.01em}
.submit-btn:hover{background:var(--gold-muted);box-shadow:0 4px 12px rgba(184,150,12,0.35),0 0 0 1px rgba(184,150,12,0.25),inset 0 1px 0 rgba(255,255,255,0.25);transform:translateY(-1px)}
.submit-btn:active{transform:scale(0.98);box-shadow:var(--shadow-active),inset 0 1px 0 rgba(255,255,255,0.15)}
.submit-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;box-shadow:0 2px 8px rgba(184,150,12,0.15)}

.tip-credit-display{padding:12px 16px;background:#EBF0FA;border:1px solid #B8C8E8;border-radius:var(--radius-sm);text-align:center;font-size:13px;color:var(--text-secondary);font-weight:500;line-height:1.3}
.tip-credit-display span:last-child{font-weight:700;color:var(--text-primary)}
.price-scale{display:inline-flex;gap:1px;font-size:13px;font-weight:600;letter-spacing:1px}
.price-scale .lit{color:var(--gold)}
.price-scale .dim{color:var(--border)}

/* Auth section in sheet */
.auth-section{text-align:center;padding:24px 0}
.auth-section h4{font-size:17px;margin-bottom:6px;color:var(--text-primary)}
.auth-section>p{max-width:300px;margin:0 auto 20px}
.phone-row{display:flex;margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition)}
.phone-row:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-light)}
.phone-row select{width:auto;max-width:200px;flex-shrink:0;padding:12px 26px 12px 10px;border:none;border-right:1px solid var(--border);background:var(--bg);font-size:13px;font-family:inherit;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%239E9E9E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;min-height:48px;cursor:pointer;outline:none}
.phone-row input{flex:1;padding:12px 14px;border:none;font-size:15px;font-family:inherit;min-height:48px;outline:none;background:transparent}
.otp-input{display:flex;gap:8px;justify-content:center;margin:20px 0}
.otp-input input{width:46px;height:54px;text-align:center;font-size:22px;font-weight:600;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;transition:border-color var(--transition),box-shadow var(--transition)}
.otp-input input:focus{border-color:var(--gold);outline:none;box-shadow:0 0 0 3px var(--gold-light)}
.cat-count{font-size:11px;opacity:.6;margin-left:2px}
.auth-error{color:var(--danger);font-size:13px;margin-top:8px}
.auth-success{color:var(--success);font-size:13px;margin-top:8px}

/* Duplicate warning */
.duplicate-warning{background:#FFF8E1;border:1px solid var(--gold-light);border-radius:var(--radius);padding:14px;margin:12px 0}
.duplicate-warning h4{font-size:14px;margin-bottom:6px}
.duplicate-warning p{font-size:13px;color:var(--text-secondary)}
.dup-actions{display:flex;gap:8px;margin-top:10px}
.dup-actions button{padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;cursor:pointer;min-height:44px;font-weight:500}

/* Rating modal */
.rating-stars{display:flex;gap:4px}
.rating-stars .star{font-size:28px;cursor:pointer;color:var(--border);transition:color var(--transition);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.rating-stars .star.filled{color:var(--gold)}
.rating-stars .star:hover{color:var(--gold-muted)}

.inline-msg{padding:10px 16px;border-radius:var(--radius-sm);font-size:13px;margin:8px 0}
.inline-msg.error{background:#FDECEA;color:var(--danger)}
.inline-msg.success{background:#E8F5E9;color:var(--success)}

.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);animation:breathe 3s ease-in-out infinite}
.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--text-secondary)}

.loading{text-align:center;padding:60px 20px;color:var(--text-muted)}
.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Skeleton loading */
@keyframes shimmer{0%{background-position:-468px 0}100%{background-position:468px 0}}
.skeleton{
  background:#E8E8E8;
  background-image:linear-gradient(90deg,#E8E8E8 0px,#F5F5F5 40px,#E8E8E8 80px);
  background-size:468px 100%;
  animation:shimmer 1.2s ease-in-out infinite;
  border-radius:var(--radius-sm);
}
.skeleton-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px}
.skeleton-line{height:16px;margin-bottom:10px;border-radius:4px}
.skeleton-line.short{width:60%}
.skeleton-line.medium{width:80%}

.footer{background:var(--surface);border-top:1px solid var(--border);padding:24px 20px;text-align:center}
.footer p{max-width:700px;margin:0 auto;font-size:11px;color:var(--text-muted);line-height:1.6}
.footer-links{margin-top:8px;font-size:12px;color:var(--text-muted)}
.footer-links a{color:var(--text-secondary)}

/* Section headings */
.section-heading{font-size:18px;font-weight:600;color:var(--gold);margin:24px 0 12px;display:flex;align-items:center;gap:8px}
.section-heading .count{font-size:13px;color:var(--text-muted);font-weight:400}

/* Google Places resolved info */
.places-info{display:flex;gap:12px;align-items:center;flex-wrap:wrap;font-size:12px;color:var(--text-muted);margin-bottom:8px}
.places-info .g-rating{color:var(--gold);font-weight:600}
.places-link{font-size:12px;color:var(--gold)}

/* Layover Info */
.layover-info{margin-top:16px}
.li-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.li-grid{grid-template-columns:1fr}}
.li-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden}
.li-card-half{/* stays in the normal 1fr column flow */}
.li-card-full{grid-column:1 / -1}
@media(max-width:480px){.li-card-full{grid-column:1}}
.li-icon{font-size:24px}
.li-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.li-value{font-size:15px;font-weight:700;color:var(--text-primary)}
.li-badge{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:16px}
.li-safe{background:#dcfce7;color:#166534}.li-caution{background:#fef9c3;color:#854d0e}.li-unsafe{background:#fee2e2;color:#991b1b}
.li-note{font-size:11px;color:var(--text-secondary);line-height:1.4}
.li-tip-green{color:#2E7D32 !important}
.li-tip-amber{color:#E65100 !important}
.li-tip-red{color:#C62828 !important}
.li-hint{font-size:12px;color:var(--text-muted);line-height:1.4;margin-top:4px}
.li-hint a{color:var(--gold);font-weight:600;font-size:12px;text-decoration:none;transition:opacity var(--transition);display:inline}
.li-hint a:hover{opacity:0.8}
.li-hint a:visited,.li-hint a:active{color:var(--gold);text-decoration:none}
.li-hint-block a{display:block;padding:4px 0}
.li-plug-row{display:flex;align-items:center;gap:10px}
.li-plug-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.li-plug-icons{display:flex;flex-wrap:wrap;gap:4px;align-items:center;justify-content:flex-end;max-width:84px}
.li-plug-icon{width:36px;height:36px;border-radius:6px;object-fit:contain;border:1px solid var(--border);background:var(--surface)}
.li-converter{display:flex;align-items:center;gap:6px;margin-top:6px}
.li-conv-field{display:flex;align-items:center;gap:4px;background:var(--bg);border-radius:8px;padding:4px 8px;flex:1;min-width:0}
.li-conv-field-currency{background:transparent;border:1.5px solid var(--gold);border-radius:8px;padding:6px 10px;flex:1;min-width:0;cursor:text}
.li-conv-field-currency input{color:var(--text-primary);width:3ch;min-width:2ch;flex:0 0 auto}
.li-conv-field-currency:focus-within{box-shadow:0 0 0 3px var(--gold-light)}
.li-conv-caret{width:1.5px;height:15px;background:var(--gold);flex-shrink:0;animation:convCaret 1.2s ease-in-out infinite;align-self:center;margin-left:-3px}
.li-conv-field-currency:focus-within .li-conv-caret{display:none}
@keyframes convCaret{0%,100%{opacity:1}50%{opacity:0}}
.li-conv-sym{font-size:12px;font-weight:600;color:var(--text-muted);flex-shrink:0}
.li-conv-field-currency .li-conv-sym{color:var(--gold)}
.li-conv-field input{border:none;background:none;font-size:13px;font-weight:600;color:var(--text-primary);width:100%;font-family:inherit;outline:none}
.li-conv-field input::-webkit-inner-spin-button{-webkit-appearance:none}
.li-conv-arrow{font-size:16px;color:var(--gold);flex-shrink:0;font-weight:700}
.li-nums{display:flex;flex-direction:column;gap:3px}
.li-num-row{font-size:12px;color:var(--text-primary);display:flex;align-items:center;gap:4px}
.li-num-row strong{font-size:14px;color:var(--text-primary);margin-left:auto}
.li-num-label{font-size:11px;color:var(--text-muted);font-weight:500}
.li-card-activities{justify-content:center;padding:14px}
.li-act-row{display:flex;gap:10px;align-items:center;margin-top:6px;flex:1}
.li-act-cover{width:48px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0}
.li-act-links{display:flex;flex-direction:column;justify-content:center;gap:10px;flex:1}
.li-act-link{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--gold);text-decoration:none;transition:opacity var(--transition)}
.li-act-link:hover{opacity:0.8}
.li-act-link:visited,.li-act-link:active{color:var(--gold);text-decoration:none}
.li-act-icon{width:18px;height:18px;border-radius:4px;flex-shrink:0;object-fit:contain}

/* eSIM card (Saily) — half-card, compact */
.li-esim-wrap{padding:14px;gap:6px}
.li-esim-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.li-esim-header img{width:28px;height:auto;object-fit:contain;border-radius:4px}
.promo-banner{display:none;align-items:center;justify-content:center;gap:4px;padding:5px 8px;margin-bottom:2px;background:var(--gold-light,#faf3d8);border:1px dashed var(--gold);border-radius:6px;font-size:10px;font-weight:600;color:var(--gold);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s}
.promo-banner:active{background:#f0e4b8}
.li-esim-cols{display:flex;flex-direction:column;gap:6px}
.li-esim-plan{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:var(--bg,#f4f4f4);border:1px solid var(--border,#e0e0e0)}
.li-esim-plan-ultra{border-color:var(--gold);background:linear-gradient(135deg,#fffdf5 0%,#faf3d8 100%);border-left:3px solid var(--gold)}
.li-esim-plan-body{flex:1;min-width:0}
.li-esim-plan-title{font-size:11px;font-weight:700;color:var(--text-primary)}
.li-esim-plan-price{font-size:13px;font-weight:700;color:var(--text-primary)}
.li-esim-plan-price small{font-size:10px;font-weight:400;color:var(--text-muted)}
.li-esim-plan-detail{font-size:10px;color:var(--text-secondary);line-height:1.3}
.li-esim-plan-perks{display:none}
.li-esim-cta{display:block;text-align:center;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:600;text-decoration:none;white-space:nowrap;flex-shrink:0}
.li-esim-cta-data{background:var(--surface);border:1px solid var(--gold);color:var(--gold)}
.li-esim-cta-data:hover{background:var(--gold-light)}
.li-esim-cta-ultra{background:var(--gold);color:#fff;border:none}
.li-esim-cta-ultra:hover{opacity:0.9}

/* Hidden */
.hidden{display:none!important}

/* ── Crew Essentials Modal ───────────────────────── */
.essentials-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;animation:fadeIn 0.15s ease}
.essentials-backdrop.hidden{display:none}
.essentials-modal{position:fixed;z-index:201;background:var(--bg);overflow-y:auto;animation:fadeIn 0.2s ease;inset:0}
.essentials-modal.hidden{display:none}
@media(min-width:600px){.essentials-modal{inset:auto;top:50%;left:50%;transform:translate(-50%,-50%);width:520px;max-height:90vh;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.25)}}
.essentials-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:1}
.essentials-title{font-size:16px;font-weight:700;color:var(--text-primary)}
.essentials-body{padding:20px}
.essentials-intro{font-size:13px;color:var(--text-secondary);margin:0 0 16px;line-height:1.5}
.essentials-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:12px;-webkit-overflow-scrolling:touch;position:relative;
  -webkit-mask-image:linear-gradient(to right,#000 85%,transparent 100%);mask-image:linear-gradient(to right,#000 85%,transparent 100%)}
.essentials-tabs::-webkit-scrollbar{display:none}
.ess-tab{font-size:12px;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-secondary);cursor:pointer;white-space:nowrap;font-family:inherit;transition:all .2s ease}
.ess-tab:active{transform:scale(0.95)}
.ess-tab.active{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 2px 8px rgba(184,150,12,0.3)}
.essentials-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:4px}
@media(min-width:400px){.essentials-grid{grid-template-columns:1fr 1fr}}
.ess-card,.ess-card:visited,.ess-card:active,.ess-card:hover{text-decoration:none;color:var(--text-primary)}
.ess-card{border:1px solid var(--border);border-radius:12px;padding:14px;transition:all 0.2s ease;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.ess-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 20px rgba(184,150,12,0.12)}
.ess-card-emoji{font-size:28px;text-align:center}
.ess-card-name{font-size:13px;font-weight:600;line-height:1.3;text-align:center}
.ess-card-desc{font-size:11px;color:var(--text-muted);text-align:center;line-height:1.4}
.ess-card-cta{font-size:11px;color:var(--gold);font-weight:600;text-align:center;margin-top:auto;padding-top:4px}
.overlay-close{background:none;border:none;font-size:14px;cursor:pointer;color:var(--text-muted);padding:4px 8px;min-height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.overlay-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:199;opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms}
.overlay-backdrop.open{opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s}
.overlay{position:fixed;inset:0;background:var(--bg);z-index:200;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms}
.overlay.open{opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s}
.overlay-header{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10}
.overlay-logo{font-size:16px;font-weight:700;color:var(--text-primary);cursor:pointer}
.overlay-body{padding:20px}

/* ── Bottom Nav Bar (mobile only) ────────────────── */
.bottom-nav{display:none}
.fab-addtip{display:none}
@media(max-width:768px){
  .bottom-nav{
    display:flex;
    position:fixed;
    bottom:0;left:0;right:0;
    z-index:300;
    background:rgba(255,255,255,0.95);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    box-shadow:0 -2px 10px rgba(0,0,0,0.08);
    height:60px;
    padding-bottom:env(safe-area-inset-bottom);
    align-items:center;
    justify-content:space-around;
  }
  .bnav-tab{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:2px;
    background:none;
    border:none;
    padding:6px 0 8px;
    min-width:44px;
    min-height:44px;
    cursor:pointer;
    color:#999;
    transition:color 150ms ease;
    -webkit-tap-highlight-color:transparent;
    flex:1;
    font-family:inherit;
    text-decoration:none;
  }
  .bnav-tab.active{color:#C9A84C}
  .bnav-icon{width:22px;height:22px;flex-shrink:0}
  .bnav-label{font-size:10px;font-weight:500;line-height:1}
  .bnav-tab.active:not(.bnav-home) .bnav-label::after{
    content:'';display:block;width:16px;height:3px;border-radius:2px;background:#C9A84C;margin:3px auto 0;
  }

  /* Center Add Tip FAB */
  .bnav-home{flex:none;width:64px;position:relative;padding-top:0;padding-bottom:12px}
  .bnav-home-circle{
    display:flex;align-items:center;justify-content:center;
    width:48px;height:48px;border-radius:50%;
    background:#fff;border:2px solid #C9A84C;
    box-shadow:0 2px 8px rgba(0,0,0,0.12);margin-top:-24px;
  }
  .bnav-addtip-plus{font-size:24px;font-weight:700;color:#C9A84C;line-height:1}
  .bnav-home .bnav-label{color:#C9A84C;font-weight:600}

  /* Hide top add-tip button on mobile */
  .add-tip-btn{display:none !important}

  /* FAB: floating add-a-tip */
  .fab-addtip{
    display:flex;
    position:fixed;
    bottom:calc(72px + env(safe-area-inset-bottom));
    right:16px;
    z-index:250;
    align-items:center;
    justify-content:center;
    gap:6px;
    background:var(--gold);
    color:#fff;
    border:none;
    border-radius:14px;
    padding:0 18px;
    height:48px;
    font-size:15px;
    font-weight:700;
    font-family:inherit;
    cursor:pointer;
    box-shadow:0 8px 24px rgba(184,150,12,0.4),0 0 0 1px rgba(184,150,12,0.2),inset 0 1px 0 rgba(255,255,255,0.2);
    transition:width 250ms ease, padding 250ms ease, gap 250ms ease, box-shadow var(--transition);
    overflow:hidden;
  }
  .fab-plus{
    font-size:28px;
    font-weight:700;
    line-height:48px;
    flex-shrink:0;
    width:28px;
    text-align:center;
    transition:transform 600ms cubic-bezier(0.34,1.56,0.64,1);
  }
  .fab-text{
    white-space:nowrap;
    max-width:100px;
    opacity:1;
    line-height:48px;
    transition:max-width 250ms ease, opacity 200ms ease;
  }
  .fab-addtip.collapsed{padding:0;width:48px;border-radius:14px;gap:0}
  .fab-addtip.collapsed .fab-plus{transform:rotate(90deg)}
  .fab-addtip.collapsed .fab-text{max-width:0;opacity:0}

  /* Essentials modal: leave room for bottom nav */
  .essentials-modal{bottom:calc(60px + env(safe-area-inset-bottom))}

  /* Body clearance for fixed nav */
  body{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
  .footer{margin-bottom:calc(60px + env(safe-area-inset-bottom))}
  
  /* iOS-specific fix: shift nav items down (closer to bottom) */
  @supports (-webkit-touch-callout: none) {
    .bnav-tab{padding-top:20px;padding-bottom:8px}
  }
}

/* Content menu buttons */
.content-menu-btn{
  background:none;
  border:1px solid rgba(224,224,224,0.8);
  border-radius:var(--radius-sm);
  color:var(--text-muted);
  cursor:pointer;
  font-size:20px;
  font-family:inherit;
  line-height:1;
  padding:6px 10px;
  min-width:44px;
  min-height:44px;
  transition:all var(--transition);
  display:flex;
  align-items:center;
  justify-content:center
}
.content-menu-btn:hover{
  border-color:var(--gold);
  color:var(--gold);
  background:var(--gold-light);
  transform:translateY(-1px);
  box-shadow:0 2px 6px rgba(184,150,12,0.15)
}
.content-menu-btn:active{
  transform:scale(0.95)
}
.content-menu-btn-small{
  background:none;
  border:none;
  color:var(--text-muted);
  cursor:pointer;
  font-size:16px;
  font-family:inherit;
  padding:4px;
  min-width:32px;
  min-height:32px;
  transition:var(--transition);
  display:flex;
  align-items:center;
  justify-content:center
}
.content-menu-btn-small:hover{
  color:var(--gold)
}

/* Content menu modal */
.content-menu-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.4);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:2000;
  justify-content:center;
  align-items:center;
  padding:20px
}
.content-menu-modal.open{
  display:flex
}
.content-menu{
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
  max-width:320px;
  width:100%;
  overflow:hidden;
  animation:menuPop 200ms ease
}
@keyframes menuPop{
  from{transform:scale(0.9);opacity:0}
  to{transform:scale(1);opacity:1}
}
.content-menu-option{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 20px;
  border:none;
  background:var(--surface);
  color:var(--text-primary);
  cursor:pointer;
  font-size:15px;
  font-family:inherit;
  font-weight:500;
  width:100%;
  text-align:left;
  transition:var(--transition);
  min-height:56px;
  border-bottom:1px solid var(--border)
}
.content-menu-option:last-child{
  border-bottom:none
}
.content-menu-option:hover{
  background:var(--bg)
}
.content-menu-option.danger{
  color:var(--danger)
}
.content-menu-option.danger:hover{
  background:#FDECEA
}
.content-menu-icon{
  font-size:20px;
  width:24px;
  text-align:center
}

/* Report modal */
.report-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.4);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:2001;
  justify-content:center;
  align-items:center;
  padding:20px
}
.report-modal.open{
  display:flex
}
.report-content{
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
  max-width:400px;
  width:100%;
  padding:24px;
  animation:menuPop 200ms ease
}
.report-content h3{
  font-size:18px;
  margin-bottom:16px
}
.report-reasons{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:16px
}
.report-reason-btn{
  padding:14px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:var(--surface);
  color:var(--text-primary);
  cursor:pointer;
  font-size:14px;
  font-family:inherit;
  font-weight:500;
  text-align:left;
  transition:var(--transition);
  min-height:48px
}
.report-reason-btn:hover{
  border-color:var(--gold);
  background:var(--gold-light)
}
.report-reason-btn.selected{
  border-color:var(--gold);
  background:var(--gold-light);
  color:var(--gold)
}
.report-actions{
  display:flex;
  gap:8px
}
.report-actions button{
  flex:1;
  padding:12px;
  border:none;
  border-radius:var(--radius-sm);
  font-size:14px;
  font-family:inherit;
  font-weight:600;
  cursor:pointer;
  min-height:44px;
  transition:var(--transition)
}
.report-submit{
  background:var(--danger);
  color:#fff
}
.report-submit:hover{
  background:#A02F22
}
.report-submit:disabled{
  opacity:0.5;
  cursor:not-allowed
}
.report-cancel{
  background:var(--bg);
  color:var(--text-secondary)
}
.report-cancel:hover{
  background:var(--border)
}

/* Confirmation toast */
.confirmation-toast{
  position:fixed;
  bottom:80px;
  bottom:calc(80px + env(safe-area-inset-bottom));
  left:50%;
  transform:translateX(-50%) translateY(100px);
  background:var(--text-primary);
  color:#fff;
  padding:14px 24px;
  border-radius:50px;
  font-size:14px;
  font-weight:500;
  box-shadow:0 4px 20px rgba(0,0,0,0.3);
  z-index:3000;
  opacity:0;
  transition:all 300ms ease;
  pointer-events:none
}
.confirmation-toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0)
}

/* ── City Chat ────────────────────────────────── */
.city-chat{
  margin-top: 2vh;
  margin-bottom:16px;
  border-radius:var(--radius);
  overflow:hidden;
  background:rgba(255,255,255,0.72);
  backdrop-filter:blur(16px) saturate(1.8);
  -webkit-backdrop-filter:blur(16px) saturate(1.8);
  border:1px solid rgba(224,224,224,0.5);
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
  transition:box-shadow 300ms ease, border-color 300ms ease;
  opacity:0;
  transform:translateY(-10px);
  transition:opacity 300ms ease, transform 300ms ease, box-shadow 300ms ease, border-color 300ms ease;
}
.city-chat.loaded{
  opacity:1;
  transform:translateY(0);
}
.city-chat:hover{
  box-shadow:0 4px 20px rgba(0,0,0,0.1);
}
.city-chat-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 20px;
  cursor:pointer;
  user-select:none;
  -webkit-user-select:none;
  min-height:64px;
  gap:12px;
}
.city-chat-header-left{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.city-chat-icon{
  font-size:20px;
}
.city-chat-title{
  font-size:15px;
  font-weight:600;
  color:var(--text-primary);
  letter-spacing:-0.01em;
}
.city-chat-badge{
  font-size:11px;
  font-weight:600;
  color:var(--gold);
  background:var(--gold-light);
  padding:2px 8px;
  border-radius:20px;
  display:none;
}
.city-chat-badge.visible{
  display:inline-block;
}
.city-chat-dm-hint{
  font-size:10px;
  color:var(--text-muted);
  opacity:0.7;
  margin-left:auto;
  white-space:nowrap;
  font-style:italic;
}
.city-chat-header-right{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.city-chat-preview{
  font-size:13px;
  color:var(--text-muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:180px;
}
.city-chat-chevron{
  width:18px;
  height:18px;
  color:var(--text-muted);
  flex-shrink:0;
  transition:transform 300ms cubic-bezier(0.34,1.56,0.64,1);
}
.city-chat.expanded .city-chat-chevron{
  transform:rotate(180deg);
}

/* Chat body */
.city-chat-body{
  max-height:0;
  overflow:hidden;
  transition:max-height 400ms cubic-bezier(0.34,1.56,0.64,1), opacity 200ms ease;
  opacity:0;
}
.city-chat.expanded .city-chat-body{
  max-height:55vh;
  opacity:1;
}

/* Messages list */
.city-chat-messages{
  max-height:calc(55vh - 64px);
  overflow-y:auto;
  padding:0 16px 8px;
  display:flex;
  flex-direction:column;
  gap:12px;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.city-chat-messages::-webkit-scrollbar{
  width:4px;
}
.city-chat-messages::-webkit-scrollbar-thumb{
  background:var(--border);
  border-radius:4px;
}

/* Empty state */
.city-chat-empty{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
  text-align:center;
}
.city-chat-empty-icon{
  font-size:36px;
  margin-bottom:12px;
  opacity:0.6;
}
.city-chat-empty p{
  font-size:15px;
  font-weight:600;
  color:var(--text-primary);
  margin-bottom:4px;
}
.city-chat-empty span{
  font-size:13px;
  color:var(--text-muted);
}

/* Message bubble */
.city-chat-msg{
  display:flex;
  gap:10px;
  align-items:flex-start;
  animation:fadeInUp 200ms ease both;
}
.city-chat-avatar{
  width:32px;
  height:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:700;
  color:#fff;
  flex-shrink:0;
  text-transform:uppercase;
}
.city-chat-msg-content{
  flex:1;
  min-width:0;
}
.city-chat-msg-header{
  display:flex;
  align-items:baseline;
  gap:8px;
  margin-bottom:2px;
}
.city-chat-msg-username{
  font-size:13px;
  font-weight:600;
  color:var(--text-primary);
}
.city-chat-msg-time{
  font-size:11px;
  color:var(--text-muted);
  flex-shrink:0;
}
.city-chat-msg-text{
  font-size:14px;
  color:var(--text-primary);
  line-height:1.45;
  word-break:break-word;
}

/* Composer */
.city-chat-composer{
  padding:12px 16px;
  border-top:1px solid rgba(224,224,224,0.5);
  background:rgba(255,255,255,0.5);
}
.city-chat-input-row{
  display:flex;
  align-items:center;
  gap:8px;
  position:relative;
}
.city-chat-input{
  flex:1;
  border:1px solid var(--border);
  border-radius:24px;
  padding:10px 16px;
  font-size:14px;
  font-family:inherit;
  background:var(--surface);
  color:var(--text-primary);
  outline:none;
  transition:border-color var(--transition), box-shadow var(--transition);
  min-height:40px;
}
.city-chat-input:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(184,150,12,0.1);
}
.city-chat-input::placeholder{
  color:var(--text-muted);
}
.city-chat-char-count{
  position:absolute;
  right:52px;
  font-size:11px;
  color:var(--text-muted);
  pointer-events:none;
}
.city-chat-char-count.warn{
  color:var(--danger);
}
.city-chat-send{
  width:36px;
  height:36px;
  border-radius:50%;
  border:none;
  background:var(--gold);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex-shrink:0;
  transition:opacity var(--transition), transform var(--transition), background var(--transition);
}
.city-chat-send svg{
  width:16px;
  height:16px;
}
.city-chat-send:disabled{
  opacity:0.4;
  cursor:not-allowed;
  transform:scale(0.9);
}
.city-chat-send:not(:disabled):hover{
  background:var(--gold-muted);
  transform:scale(1.05);
}
.city-chat-send:not(:disabled):active{
  transform:scale(0.95);
}

/* Login prompt */
.city-chat-login-prompt{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  cursor:pointer;
  border-radius:24px;
  border:1px dashed var(--border);
  margin-bottom:8px;
  transition:border-color var(--transition), background var(--transition);
}
.city-chat-login-prompt:hover{
  border-color:var(--gold);
  background:rgba(184,150,12,0.04);
}
.city-chat-login-prompt span{
  font-size:13px;
  font-weight:500;
  color:var(--gold);
}
.city-chat-login-prompt.hidden{
  display:none;
}

/* Hidden utility */
.city-chat-input-row.hidden{
  display:none;
}

@media(max-width:480px){
  .city-chat-preview{max-width:120px}
  .city-chat-header{padding:14px 16px}
  .city-chat-messages{padding:0 12px 8px}
  .city-chat-composer{padding:10px 12px}
}

/* ── Chat Context Menu ─────────────────────────── */
.chat-context-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,0.4);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:flex-end;justify-content:center;
  padding:20px;
  animation:fadeIn 150ms ease;
}
.chat-context-overlay.hidden{display:none}
.chat-context-menu{
  background:var(--surface);border-radius:16px;
  width:100%;max-width:360px;
  padding:8px;
  box-shadow:0 8px 40px rgba(0,0,0,0.2);
  animation:fadeInUp 200ms cubic-bezier(0.34,1.56,0.64,1);
}
.chat-context-option{
  display:flex;align-items:center;gap:12px;
  width:100%;padding:14px 16px;border:none;background:none;
  font-size:15px;font-family:inherit;color:var(--text-primary);
  border-radius:10px;cursor:pointer;transition:background var(--transition);
}
.chat-context-option:hover{background:var(--bg)}
.chat-context-option:active{background:var(--border)}
.chat-context-option.danger{color:var(--danger)}

/* Chat Report Modal */
.chat-report-modal{
  position:fixed;inset:0;z-index:2100;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:20px 20px 80px 20px;
  animation:fadeIn 150ms ease;
  overflow-y:auto;
}
.chat-report-modal.hidden{display:none}
.chat-report-content{
  background:var(--surface);border-radius:var(--radius);
  padding:24px;width:100%;max-width:380px;
  box-shadow:0 8px 40px rgba(0,0,0,0.2);
  animation:none;
  margin:auto;
  max-height:80vh;
  overflow-y:auto;
  position:relative;
}
.chat-report-content h3{font-size:18px;font-weight:700;margin-bottom:4px}
.chat-report-reasons{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.chat-report-reason-btn{
  padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);font-size:14px;font-family:inherit;
  cursor:pointer;text-align:left;transition:all var(--transition);
}
.chat-report-reason-btn:hover{border-color:var(--gold)}
.chat-report-reason-btn.selected{border-color:var(--gold);background:var(--gold-light);font-weight:500}
.chat-report-note{
  width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:13px;font-family:inherit;resize:none;height:60px;margin-bottom:16px;
}
.chat-report-note:focus{border-color:var(--gold);outline:none}
.chat-report-actions{display:flex;gap:10px;justify-content:flex-end}
.chat-report-cancel,.chat-report-submit{
  padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;
  font-weight:600;font-family:inherit;cursor:pointer;border:none;min-height:40px;
}
.chat-report-cancel{background:var(--bg);color:var(--text-secondary)}
.chat-report-cancel:hover{background:var(--border)}
.chat-report-submit{background:var(--danger);color:#fff}
.chat-report-submit:disabled{opacity:0.5;cursor:not-allowed}
.chat-report-submit:not(:disabled):hover{background:#A02F22}

/* Chat Block Confirm */
.chat-block-confirm{
  position:fixed;inset:0;z-index:2100;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:fadeIn 150ms ease;
}
.chat-block-confirm.hidden{display:none}
.chat-block-confirm-content{
  background:var(--surface);border-radius:var(--radius);
  padding:24px;width:100%;max-width:340px;text-align:center;
  box-shadow:0 8px 40px rgba(0,0,0,0.2);
  animation:fadeInUp 200ms cubic-bezier(0.34,1.56,0.64,1);
}
.chat-block-confirm-content h3{font-size:17px;font-weight:700;margin-bottom:4px}
.chat-block-confirm-actions{display:flex;gap:10px;justify-content:center;margin-top:8px}
.chat-block-confirm-cancel,.chat-block-confirm-submit{
  padding:10px 24px;border-radius:var(--radius-sm);font-size:14px;
  font-weight:600;font-family:inherit;cursor:pointer;border:none;min-height:40px;
}
.chat-block-confirm-cancel{background:var(--bg);color:var(--text-secondary)}
.chat-block-confirm-submit{background:var(--danger);color:#fff}
.chat-block-confirm-submit:hover{background:#A02F22}

/* Banned Screen */
.banned-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;
}
.banned-screen.hidden{display:none}
.banned-screen-content{
  text-align:center;max-width:360px;
}
.banned-screen-icon{font-size:48px;margin-bottom:16px}
.banned-screen-content h2{font-size:22px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}
.banned-screen-content p{font-size:15px;color:var(--text-secondary);line-height:1.6}
.banned-screen-content a{color:var(--gold)}

/* Redacted message */
.city-chat-msg-text.redacted{
  color:var(--text-muted);font-style:italic;
}

/* Report icon on city chat messages */
.city-chat-msg-report{
  color:var(--text-muted);opacity:0.35;font-size:12px;cursor:pointer;
  margin-left:6px;transition:opacity 150ms ease;vertical-align:middle;
}
.city-chat-msg-report:hover,.city-chat-msg-report:active{opacity:0.7}

/* ── Social Overlay (destination page) ─────────── */
#destiSocialBackdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:399;opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms}
#destiSocialBackdrop:not(.hidden){opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s}
#destiSocialOverlay{position:fixed;inset:0;background:var(--bg);z-index:400;overflow-y:auto;opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms}
#destiSocialOverlay:not(.hidden){opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s}
#destiSocialOverlay.hidden{opacity:0;visibility:hidden}
#destiSocialBackdrop.hidden{opacity:0;visibility:hidden}
@media(max-width:767px){
  #destiSocialOverlay{bottom:calc(60px + env(safe-area-inset-bottom))}
}
@media(min-width:768px){
  #destiSocialOverlay{inset:40px;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.25);max-width:640px;margin:40px auto}
}
#destiSocialOverlay .overlay-header{position:sticky;top:0;background:var(--surface);border-bottom:1px solid var(--border);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;z-index:10;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
#destiSocialOverlay .overlay-logo{font-size:16px;font-weight:700;color:var(--text-primary)}
#destiSocialOverlay .overlay-body{max-width:600px;margin:0 auto;padding:20px}

/* Social sub-tabs (shared between index + destination) */
.social-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg);border-radius:10px;padding:4px}
.social-tab{flex:1;padding:10px 12px;font-size:13px;font-weight:600;border:none;background:none;color:var(--text-muted);border-radius:8px;cursor:pointer;font-family:inherit;transition:all 200ms ease;position:relative}
.social-tab.active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 4px rgba(0,0,0,0.08)}
.social-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:10px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;margin-left:4px}
.social-tab-badge.hidden{display:none}
.social-section{display:none}
.social-section.active{display:block}
.social-nav-badge{position:absolute;top:4px;right:8px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.social-nav-badge.hidden{display:none}

/* DM chat row unread badge (on avatar) */
.dm-unread-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--surface);box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.dm-unread-badge.hidden{display:none}

/* Friend-related styles (destination page) */
.add-friend-form{background:var(--surface);border-radius:var(--radius);padding:16px;margin-bottom:20px;box-shadow:var(--shadow)}
.add-friend-form h4{font-size:14px;font-weight:600;margin-bottom:12px}
.add-friend-row{display:flex;gap:6px;flex-wrap:wrap}
.add-friend-row select{width:80px;padding:10px 4px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:inherit;flex-shrink:0}
.add-friend-row input{flex:1;min-width:100px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit}
.add-friend-row button{padding:10px 16px;background:var(--gold);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;min-height:44px;flex-shrink:0}
@media(max-width:400px){.add-friend-row button{width:100%}}
.add-friend-name{margin-bottom:10px}
.add-friend-name input{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit}
.gender-pick{display:flex;gap:8px;margin-bottom:10px}
.gender-pick button{flex:1;padding:10px;border:2px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);font-size:24px;cursor:pointer;transition:var(--transition)}
.gender-pick button.active{border-color:var(--gold);background:var(--gold-light)}
.disclaimer-small{font-size:11px;color:var(--text-muted);line-height:1.4;margin-top:10px}
.friend-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px;animation:fadeInUp 0.4s cubic-bezier(0.4, 0, 0.2, 1) both}
.friend-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.friend-info{flex:1;min-width:0}
.friend-name{font-size:14px;font-weight:600;margin-bottom:2px}
.friend-meta{font-size:12px;color:var(--text-muted)}
.friend-actions{display:flex;gap:8px}
.remove-btn{padding:6px 14px;font-size:12px;font-weight:600;border:1px solid var(--border);background:none;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;transition:var(--transition)}
.friend-actions .remove-btn:hover{border-color:var(--danger);color:var(--danger)}
.chat-btn{padding:6px 14px;font-size:12px;font-weight:600;border:1px solid var(--border);background:none;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;transition:var(--transition)}
.chat-btn:hover{border-color:var(--gold);color:var(--gold)}
.chat-btn.pending{opacity:0.5;cursor:not-allowed;pointer-events:none}
.chat-btn.pending:hover{border-color:var(--border);color:var(--text-secondary)}
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-state p{font-size:14px;margin:0}

/* Toggle (destination page) */
.ll-toggle{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0}
.ll-toggle input{opacity:0;width:0;height:0}
.ll-toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:28px;transition:background 300ms cubic-bezier(0.34,1.56,0.64,1)}
.ll-toggle-slider::before{content:'';position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform 300ms cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 1px 4px rgba(0,0,0,0.15)}
.ll-toggle input:checked+.ll-toggle-slider{background:var(--gold)}
.ll-toggle input:checked+.ll-toggle-slider::before{transform:translateX(20px)}

/* Request card (destination page) */
.request-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px}
.request-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.request-card-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.request-card-info{flex:1;min-width:0}
.request-card-name{font-size:14px;font-weight:600}
.request-card-meta{font-size:11px;color:var(--text-muted)}
.request-card-intro{font-size:13px;color:var(--text-secondary);margin-bottom:12px;line-height:1.4;font-style:italic}
.request-card-actions{display:flex;gap:8px}
.request-card-actions button{flex:1;padding:10px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:inherit;min-height:38px}
.request-accept{background:#2E7D32;color:#fff}
.request-decline{background:var(--bg);color:var(--danger);border:1px solid var(--border)!important}

/* ── DM Menus and Modals ─────────────────────────────── */
.dm-menu-overlay{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.dm-menu-overlay.hidden{display:none}
.dm-menu{background:var(--surface);border-radius:16px;width:100%;max-width:320px;padding:8px;box-shadow:0 8px 40px rgba(0,0,0,0.2);animation:fadeInUp 200ms cubic-bezier(0.34,1.56,0.64,1)}
.dm-menu-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;background:none;font-size:15px;font-family:inherit;color:var(--text-primary);border-radius:10px;cursor:pointer}
.dm-menu-option:hover{background:var(--bg)}
 .dm-menu-option.danger{color:var(--danger)}

/* Chat request compose modal */
.chat-request-compose{position:fixed;inset:0;z-index:2100;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn 150ms ease}
.chat-request-compose.hidden{display:none}
.chat-request-compose-content{background:var(--surface);border-radius:var(--radius);padding:24px;width:100%;max-width:360px;box-shadow:0 8px 40px rgba(0,0,0,0.2)}
.chat-request-compose-content h3{font-size:17px;font-weight:700;margin-bottom:4px}

/* Request card (DM requests list) */
.request-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px}
.request-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.request-card-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.request-card-info{flex:1;min-width:0}
.request-card-name{font-size:14px;font-weight:600}
.request-card-meta{font-size:11px;color:var(--text-muted)}
.request-card-intro{font-size:13px;color:var(--text-secondary);margin-bottom:12px;line-height:1.4;font-style:italic}
.request-card-actions{display:flex;gap:8px}
.request-card-actions button{flex:1;padding:10px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:inherit;min-height:38px}
.request-accept{background:var(--success,#2E7D32);color:#fff}
.request-decline{background:var(--bg);color:var(--danger);border:1px solid var(--border)!important}

/* DM Chat View - Nuclear Layout Solution */
/* Full-screen container that sits BELOW main header but ABOVE everything else */
#destiSocialOverlay .dm-chat-view,
.dm-chat-view{
  position:fixed;
  /* Mobile/PWA: Fixed header height */
  top:56px; 
  left:0;
  right:0;
  bottom:calc(60px + env(safe-area-inset-bottom)); /* End above bottom nav */
  z-index:99; /* Below main header (100) but above social overlay */
  background:var(--bg);
  display:flex;
  flex-direction:column;
  animation:fadeIn 150ms ease;
  overflow:hidden; /* Container doesn't scroll */
}

/* Desktop: larger header, no bottom nav */
@media(min-width:768px){
  #destiSocialOverlay .dm-chat-view,
  .dm-chat-view{
    top:72px; /* Desktop header is taller */
    bottom:0;
  }
}

#destiSocialOverlay .dm-chat-view.hidden,
.dm-chat-view.hidden{
  display:none;
}

/* Chat Header - Sticks at top of DM view (below main header) */
#destiSocialOverlay .dm-chat-header,
.dm-chat-header{
  display:flex;
  align-items:center;
  padding:14px 16px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  gap:12px;
  flex-shrink:0; /* Don't shrink */
  z-index:2; /* Above messages */
  position:relative; /* Not sticky, just stays at top of flex container */
}
.dm-chat-back{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-primary);padding:4px 8px;min-height:36px}
.dm-chat-name{flex:1;font-size:16px;font-weight:700;color:var(--text-primary)}
.dm-chat-menu-btn{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-muted);padding:4px 8px;min-height:36px}
.dm-ended-banner{
  background:#FFF3CD;
  color:#856404;
  text-align:center;
  padding:10px;
  font-size:13px;
  font-weight:500;
  flex-shrink:0;
}
.dm-ended-banner.hidden{display:none}

/* Messages Area - THE ONLY SCROLLABLE PART */
.dm-chat-messages{
  flex:1; /* Takes all available space between header and composer */
  overflow-y:auto; /* ONLY this scrolls */
  overflow-x:hidden;
  scroll-behavior:smooth;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:4px;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  z-index:1; /* Below header and composer */
}

.dm-bubble{max-width:80%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.4;word-break:break-word;position:relative;user-select:none;-webkit-user-select:none;touch-action:manipulation}
.dm-bubble-mine{align-self:flex-end;background:var(--gold);color:#fff;border-bottom-right-radius:4px}
.dm-bubble-theirs{align-self:flex-start;background:var(--surface);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px}
.dm-bubble-text{white-space:pre-wrap}
.dm-read-receipt{font-size:10px;opacity:0.7;text-align:right;margin-top:2px}
.dm-time-divider{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 0;margin:8px 0}

/* DM message like heart */
.dm-heart{position:absolute;font-size:16px;line-height:1;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(0,0,0,0.15))}
.dm-heart-left{left:10%;bottom:-10px}
.dm-heart-right{right:10%;bottom:-10px}
.dm-heart-pop{animation:dmHeartPop 280ms cubic-bezier(0.18,0.89,0.32,1.28)}
.dm-heart-pop-out{animation:dmHeartPopOut 250ms ease forwards}
.dm-heart-plus{position:absolute;bottom:-10px;font-size:9px;font-weight:800;color:#111;line-height:1;pointer-events:none}
.dm-heart-left + .dm-heart-plus{left:calc(10% + 17px)}
.dm-heart-right + .dm-heart-plus{right:calc(10% - 13px)}
@keyframes dmHeartPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3);opacity:1}100%{transform:scale(1);opacity:1}}
@keyframes dmHeartPopOut{0%{transform:scale(1);opacity:1}100%{transform:scale(0);opacity:0}}

/* Composer - Sticks at bottom (above bottom nav) */
.dm-chat-composer{
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  background:var(--surface);
  border-top:1px solid var(--border);
  flex-shrink:0; /* Don't shrink */
  z-index:2; /* Above messages */
  position:relative;
}
.dm-chat-input{flex:1;border:1px solid var(--border);border-radius:24px;padding:10px 16px;font-size:14px;font-family:inherit;background:var(--bg);min-height:40px;outline:none}
.dm-chat-input:focus{border-color:var(--gold)}
.dm-chat-send{width:36px;height:36px;border-radius:50%;border:none;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.dm-chat-send svg{width:16px;height:16px}
.dm-chat-send:disabled{opacity:0.4;cursor:not-allowed}
.dm-menu-overlay{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}
.dm-menu-overlay.hidden{display:none}
.dm-menu{background:var(--surface);border-radius:16px;width:100%;max-width:320px;padding:8px;box-shadow:0 8px 40px rgba(0,0,0,0.2);animation:fadeInUp 200ms cubic-bezier(0.34,1.56,0.64,1)}
.dm-menu-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;background:none;font-size:15px;font-family:inherit;color:var(--text-primary);border-radius:10px;cursor:pointer}
.dm-menu-option:hover{background:var(--bg)}
.dm-menu-option.danger{color:var(--danger)}

/* Username tap action sheet (city chat) */
.chat-user-sheet{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn 150ms ease}
.chat-user-sheet.hidden{display:none}
.chat-user-sheet-menu{background:var(--surface);border-radius:16px;width:100%;max-width:360px;padding:8px;box-shadow:0 8px 40px rgba(0,0,0,0.2);animation:fadeInUp 200ms cubic-bezier(0.34,1.56,0.64,1);margin:auto}
.chat-user-sheet-header{padding:14px 16px 10px;text-align:center;border-bottom:1px solid var(--border);margin-bottom:4px}
.chat-user-sheet-header strong{font-size:15px}
.chat-user-sheet-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;background:none;font-size:15px;font-family:inherit;color:var(--text-primary);border-radius:10px;cursor:pointer;transition:background 150ms ease}
.chat-user-sheet-option:hover{background:var(--bg)}
.chat-user-sheet-option.danger{color:var(--danger)}

/* ── Dev Mode Feature Gate ────────────────────── */
#cityChat { display: block; }



/* Destination Social Overlay - ensure it behaves like index page overlay */
@media(max-width:768px){
  html.capacitor-native #destiSocialOverlay{
    top:calc(env(safe-area-inset-top,0px) + var(--native-header-h,72px)) !important;
    bottom:0 !important;
    left:0 !important;
    right:0 !important;
  }
  html.capacitor-native #destiSocialOverlay .overlay-header{
    position:sticky !important;
    top:0 !important;
    background:var(--bg) !important;
    z-index:1 !important;
  }
}
