/* ── Cards & Glass ────────────────────────────────── */
.card{background:#151520;border:1px solid rgba(255,255,255,0.07);border-radius:16px;transition:box-shadow .2s;}
.card:hover{box-shadow:0 0 0 1px rgba(139,92,246,.25),0 8px 32px rgba(0,0,0,.4);}
.glass{background:rgba(255,255,255,0.06);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);}
.stat-card{background:#151520;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:16px;}

/* ── Buttons ──────────────────────────────────────── */
.btn-primary{background:linear-gradient(90deg,#06b6d4,#8b5cf6,#ec4899);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-size:15px;cursor:pointer;font-weight:500;transition:opacity .2s,transform .15s,box-shadow .15s;}
.btn-primary:hover{opacity:.88;box-shadow:0 4px 20px rgba(139,92,246,.35);}
.btn-primary:active{transform:scale(.97);}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;}
.btn-outline{background:rgba(255,255,255,0.07);color:#fff;border:1.5px solid rgba(255,255,255,0.2);border-radius:12px;padding:11px 20px;font-size:14px;cursor:pointer;transition:all .2s;}
.btn-outline:hover{background:rgba(255,255,255,0.12);}
.btn-ghost{background:none;color:rgba(255,255,255,0.7);border:none;cursor:pointer;font-size:14px;padding:8px 14px;border-radius:8px;transition:all .2s;}
.btn-ghost:hover{color:#fff;background:rgba(255,255,255,0.08);}

/* ── Inputs ───────────────────────────────────────── */
.inp{width:100%;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:12px;padding:12px 16px;color:#fff;font-size:15px;outline:none;transition:border .2s,box-shadow .2s;font-family:inherit;}
.inp:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.15);}
.inp::placeholder{color:rgba(255,255,255,0.3);}

/* ── Tags & Pills ─────────────────────────────────── */
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:500;}
.tag-free{background:rgba(34,211,238,.15);color:#22d3ee;}
.tag-paid{background:rgba(139,92,246,.15);color:#a78bfa;}
.tag-cat{background:rgba(236,72,153,.12);color:#f472b6;}
.cat-pill{padding:7px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.15);font-size:13px;cursor:pointer;transition:all .2s;background:rgba(255,255,255,.04);}
.cat-pill:hover{background:rgba(255,255,255,.08);}
.cat-pill.active{background:rgba(139,92,246,.25);border-color:#8b5cf6;color:#c4b5fd;}

/* ── Toggle ───────────────────────────────────────── */
.toggle{width:44px;height:24px;background:rgba(255,255,255,.15);border-radius:999px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;border:none;}
.toggle.on{background:#8b5cf6;}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;}
.toggle.on::after{transform:translateX(20px);}

/* ── Navigation ───────────────────────────────────── */
#bottom-nav{position:fixed;bottom:0;left:0;right:0;height:58px;background:rgba(10,10,15,0.97);border-top:1px solid rgba(255,255,255,0.08);display:none;align-items:center;justify-content:space-around;padding:0 8px;z-index:100;backdrop-filter:blur(20px);}
#bottom-nav.visible{display:flex;}
.nav-tab{display:flex;flex-direction:column;align-items:center;gap:3px;color:rgba(255,255,255,.35);font-size:9px;cursor:pointer;padding:4px 12px;border:none;background:none;transition:color .2s;position:relative;}
.nav-tab.active{color:#8b5cf6;}
.nav-tab.active::after{content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);width:4px;height:4px;background:#8b5cf6;border-radius:50%;}
.nav-tab svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.75;}
#top-nav{position:fixed;top:0;left:0;right:0;height:56px;background:rgba(10,10,15,0.97);border-bottom:1px solid rgba(255,255,255,0.07);display:none;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;backdrop-filter:blur(20px);}
#top-nav.visible{display:flex;}

/* ── Itinerary grid & cards ───────────────────────── */
.itin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;}
.itin-card{border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;background:#151520;}
.itin-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.5);}

/* ── Stop card ────────────────────────────────────── */
.stop-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:14px;overflow:hidden;}

/* ── Skeleton loader ──────────────────────────────── */
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.05) 25%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* ── Notification item ────────────────────────────── */
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06);}

/* ── Image upload ─────────────────────────────────── */
.img-upload-zone{border:2px dashed rgba(139,92,246,.35);border-radius:18px;text-align:center;cursor:pointer;background:rgba(139,92,246,.04);transition:all .2s;position:relative;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px;}
.img-upload-zone:hover,.img-upload-zone.drag-over{background:rgba(139,92,246,.1);border-color:rgba(139,92,246,.65);}
.img-upload-zone.has-image{padding:0;border-style:solid;border-color:rgba(139,92,246,.5);overflow:visible;}
.img-upload-zone.uploading{pointer-events:none;opacity:.8;}
.img-preview-wrap{position:relative;width:100%;height:210px;}
.img-preview-wrap img{width:100%;height:100%;object-fit:cover;display:block;}
.img-preview-overlay{position:absolute;inset:0;background:rgba(0,0,0,.48);display:flex;align-items:center;justify-content:center;gap:10px;opacity:0;transition:opacity .18s;}
.img-preview-wrap:hover .img-preview-overlay{opacity:1;}
.img-prog-bar{height:3px;background:rgba(139,92,246,.2);border-radius:2px;overflow:hidden;margin-top:12px;width:100%;max-width:200px;}
.img-prog-fill{height:100%;background:linear-gradient(90deg,#22d3ee,#8b5cf6);border-radius:2px;width:0%;transition:width .25s;}
.stop-photo-zone{border:1.5px dashed rgba(139,92,246,.4);border-radius:12px;padding:20px;text-align:center;cursor:pointer;background:rgba(139,92,246,.04);transition:all .2s;min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.stop-photo-zone:hover,.stop-photo-zone.drag-over{background:rgba(139,92,246,.1);border-color:rgba(139,92,246,.7);}
.stop-photo-zone.has-image{padding:0;border:1.5px solid rgba(52,211,153,.5);border-radius:12px;position:relative;overflow:visible;}
.stop-photo-zone.has-image img{width:100%;height:110px;object-fit:cover;display:block;border-radius:10px;}
.stop-photo-actions{display:flex;gap:8px;padding:8px;justify-content:center;background:rgba(0,0,0,.7);border-radius:0 0 10px 10px;}
.img-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;display:flex;align-items:center;justify-content:center;}
.img-lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:12px;}

/* ── Feed ─────────────────────────────────────────── */
.feed-item{position:relative;width:100%;height:calc(100vh - 58px);overflow:hidden;flex-shrink:0;scroll-snap-align:start;}
#feed-container{height:calc(100vh - 58px);overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth;}
#feed-container::-webkit-scrollbar{display:none;}

@supports (height: 100dvh) {
  .feed-item{height:calc(100dvh - 58px);}
  #feed-container{height:calc(100dvh - 58px);}
}
.verified-badge { display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px;background:rgba(34,211,238,.15);border:1px solid rgba(34,211,238,.3);color:#22d3ee;font-size:10px;font-weight:700; }
.founding-badge { display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:999px;background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.3);color:#a78bfa;font-size:10px;font-weight:700; }

.star-btn { background:none;border:none;cursor:pointer;font-size:24px;padding:2px;transition:transform .1s;color:rgba(255,255,255,.2); }
.star-btn.active { color:#fbbf24; }
.star-btn:hover { transform:scale(1.2); }