:root {
  --g50:#E8F6F0;--g100:#C3E8D8;--g300:#6DC4A5;--g500:#1D9E75;--g700:#0F6E56;--g900:#085041;
  --coral:#D85A30;--coral-l:#FAECE7;--coral-d:#8C3318;
  --amber:#BA7517;--amber-l:#FDF0D5;--amber-d:#7A4C0A;
  --blue:#2E86DE;--blue-l:#E8F2FC;
  --purple:#6B4FBB;--purple-l:#F0ECFA;
  --ink:#0F1C17;--ink-2:#2A3D35;--ink-3:#4A6358;--ink-4:#7A9E8E;
  --sand:#F7FAF8;--white:#FFFFFF;--border:#E2EDE8;--border-2:#C8DDD5;
  --r-sm:8px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-full:999px;
  --shadow-sm:0 1px 3px rgba(8,80,65,.06),0 1px 2px rgba(8,80,65,.04);
  --shadow-md:0 4px 16px rgba(8,80,65,.08),0 2px 6px rgba(8,80,65,.04);
  --shadow-lg:0 12px 40px rgba(8,80,65,.10),0 4px 12px rgba(8,80,65,.06);
  --font-display:'Syne',sans-serif;
  --font-body:'DM Sans',sans-serif;
  --font-ml:'Noto Sans Malayalam',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;}
body{font-family:var(--font-body);background:var(--sand);color:var(--ink);line-height:1.5;min-height:100vh;overflow-x:hidden;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:4px;}

/* ── TOP NAV ── */
.nav{position:sticky;top:0;z-index:100;background:rgba(247,250,248,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 20px;}
.nav-inner{max-width:1100px;margin:0 auto;height:58px;display:flex;align-items:center;gap:12px;}
.logo{font-family:var(--font-display);font-size:22px;font-weight:800;letter-spacing:-0.5px;text-decoration:none;display:flex;align-items:center;gap:0;}
.logo-n{color:var(--g900);}
.logo-du{color:var(--coral);}
.logo-ml{font-family:var(--font-ml);font-size:11px;color:var(--ink-4);margin-left:6px;font-weight:400;}
.loc-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3);background:var(--white);border:1px solid var(--border);border-radius:var(--r-full);padding:5px 12px;cursor:pointer;transition:.15s;white-space:nowrap;}
.loc-btn:hover{border-color:var(--g300);}
.loc-pulse{width:7px;height:7px;background:var(--g500);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.85);}}
.nav-spacer{flex:1;}
.lang-btn{font-size:12px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--r-full);background:transparent;cursor:pointer;color:var(--ink-3);transition:.15s;display:flex;align-items:center;gap:4px;}
.lang-btn:hover{border-color:var(--g300);color:var(--g700);}
.btn-signin{font-size:13px;padding:7px 16px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--white);cursor:pointer;color:var(--ink-2);font-weight:500;transition:.15s;}
.btn-signin:hover{border-color:var(--g500);color:var(--g700);}
.btn-post{font-size:13px;padding:7px 18px;border:none;border-radius:var(--r-full);background:var(--g500);cursor:pointer;color:var(--white);font-weight:600;transition:.15s;display:flex;align-items:center;gap:6px;}
.btn-post:hover{background:var(--g700);}
.btn-post svg{width:14px;height:14px;}

/* ── HERO ── */
.hero{background:linear-gradient(135deg,var(--g900) 0%,var(--g700) 60%,var(--g500) 100%);padding:48px 20px 0;overflow:hidden;position:relative;}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.hero-inner{max-width:1100px;margin:0 auto;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-full);padding:5px 12px;font-size:11px;color:rgba(255,255,255,.85);margin-bottom:18px;font-weight:500;}
.hero-badge span{font-family:var(--font-ml);}
.hero h1{font-family:var(--font-display);font-size:clamp(26px,5vw,46px);font-weight:800;color:var(--white);line-height:1.18;letter-spacing:-1px;max-width:600px;}
.hero h1 em{color:#A8F0D8;font-style:normal;}
.hero-sub{font-size:15px;color:rgba(255,255,255,.72);margin-top:10px;max-width:480px;line-height:1.6;}
.search-wrap{margin-top:24px;display:flex;gap:10px;max-width:560px;}
.search-box{flex:1;display:flex;align-items:center;background:var(--white);border-radius:var(--r-lg);padding:0 16px;gap:10px;box-shadow:var(--shadow-lg);}
.search-box svg{width:18px;height:18px;color:var(--ink-4);flex-shrink:0;}
.search-box input{flex:1;border:none;outline:none;font-size:14px;color:var(--ink);background:transparent;font-family:var(--font-body);padding:14px 0;}
.search-box input::placeholder{color:var(--ink-4);}
.search-btn{padding:14px 22px;background:var(--coral);color:var(--white);border:none;border-radius:var(--r-lg);font-size:14px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap;font-family:var(--font-body);}
.search-btn:hover{background:var(--coral-d);}
.hero-stats{display:flex;gap:32px;margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);}
.stat-item{text-align:center;}
.stat-num{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--white);}
.stat-lbl{font-size:11px;color:rgba(255,255,255,.55);margin-top:1px;}
.hero-wave{display:block;width:100%;height:36px;margin-bottom:-2px;}

/* ── SECTION TABS ── */
.tabs-wrap{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:58px;z-index:90;}
.tabs-inner{max-width:1100px;margin:0 auto;display:flex;gap:4px;padding:10px 20px;overflow-x:auto;scrollbar-width:none;}
.tabs-inner::-webkit-scrollbar{display:none;}
.tab-btn{white-space:nowrap;padding:7px 16px;border-radius:var(--r-full);font-size:13px;border:1px solid transparent;color:var(--ink-4);cursor:pointer;background:transparent;font-weight:500;font-family:var(--font-body);transition:.15s;display:flex;align-items:center;gap:6px;}
.tab-btn:hover{color:var(--g700);background:var(--g50);}
.tab-btn.active{background:var(--g900);color:var(--white);border-color:var(--g900);}
.tab-btn svg{width:14px;height:14px;}

/* ── MAIN LAYOUT ── */
.main{max-width:1100px;margin:0 auto;padding:28px 20px 80px;}

/* ── SECTION HEADER ── */
.sec-hd{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px;}
.sec-hd h2{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-0.3px;}
.sec-hd p{font-size:13px;color:var(--ink-4);margin-top:2px;}
.see-all{font-size:12px;color:var(--g700);text-decoration:none;font-weight:600;display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--white);cursor:pointer;transition:.15s;font-family:var(--font-body);}
.see-all:hover{border-color:var(--g500);background:var(--g50);}
.section-block{margin-bottom:44px;}

/* ── ACTIVITY CARDS (h-scroll) ── */
.cards-scroll{display:flex;gap:14px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;}
.cards-scroll::-webkit-scrollbar{display:none;}
.act-card{min-width:220px;max-width:220px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;flex-shrink:0;cursor:pointer;transition:.2s;position:relative;overflow:hidden;}
.act-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.act-card.cricket::before{background:var(--g500);}
.act-card.meetup::before{background:var(--amber);}
.act-card.discussion::before{background:var(--blue);}
.act-card.volunteering::before{background:var(--coral);}
.act-card.music::before{background:var(--purple);}
.act-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.cat-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 9px;border-radius:var(--r-full);font-weight:600;margin-bottom:10px;}
.tag-cricket{background:var(--g50);color:var(--g700);}
.tag-meetup{background:var(--amber-l);color:var(--amber-d);}
.tag-discussion{background:var(--blue-l);color:#1565C0;}
.tag-volunteer{background:var(--coral-l);color:var(--coral-d);}
.tag-music{background:var(--purple-l);color:var(--purple);}
.act-card h3{font-size:14px;font-weight:600;color:var(--ink);line-height:1.4;margin-bottom:4px;}
.act-card .meta{font-size:11px;color:var(--ink-4);display:flex;align-items:center;gap:5px;}
.act-card .meta svg{width:11px;height:11px;}
.act-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;}
.av-stack{display:flex;}
.av{width:22px;height:22px;border-radius:50%;border:2px solid var(--white);margin-right:-7px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;}
.av:last-child{margin-right:0;}
.av-a{background:#9FE1CB;color:#085041;}
.av-b{background:#FAC775;color:#412402;}
.av-c{background:#B5D4F4;color:#042C53;}
.av-d{background:#F5B8A8;color:#4A1B0C;}
.join-count{font-size:11px;color:var(--ink-4);}
.rsvp-btn{font-size:11px;padding:5px 10px;border:1px solid var(--g300);border-radius:var(--r-full);background:transparent;color:var(--g700);cursor:pointer;font-weight:600;transition:.15s;font-family:var(--font-body);}
.rsvp-btn:hover,.rsvp-btn.going{background:var(--g500);color:var(--white);border-color:var(--g500);}

/* ── ATTRACTION GRID ── */
.attract-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.attract-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:.2s;}
.attract-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.attract-img{height:120px;background:linear-gradient(135deg,var(--g50),var(--g100));display:flex;align-items:center;justify-content:center;font-size:40px;position:relative;}
.attract-cat-badge{position:absolute;top:8px;left:8px;font-size:10px;padding:3px 8px;border-radius:var(--r-full);background:rgba(8,80,65,.85);color:var(--white);font-weight:600;}
.attract-body{padding:12px;}
.attract-body h3{font-size:13px;font-weight:600;color:var(--ink);}
.attract-body .dist{font-size:11px;color:var(--ink-4);margin-top:2px;display:flex;align-items:center;gap:4px;}
.rating-row{display:flex;align-items:center;justify-content:space-between;margin-top:8px;}
.stars{font-size:11px;color:var(--amber);font-weight:600;}
.review-count{font-size:10px;color:var(--ink-4);}
.free-tag{font-size:10px;padding:2px 7px;border-radius:var(--r-full);background:var(--g50);color:var(--g700);font-weight:600;}

/* ── FREEBEE LIST ── */
.freebee-list{display:flex;flex-direction:column;gap:10px;}
.freebee-item{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:.15s;}
.freebee-item:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);}
.free-ico{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.fi-food{background:#E1F5EE;}
.fi-cloth{background:#FAEEDA;}
.fi-edu{background:#E6F1FB;}
.fi-meds{background:#FAE8FA;}
.fi-books{background:#FFF3E0;}
.free-info{flex:1;}
.free-info h3{font-size:13px;font-weight:600;color:var(--ink);}
.free-info p{font-size:11px;color:var(--ink-4);margin-top:2px;}
.free-info .by{font-size:11px;color:var(--g700);margin-top:4px;font-weight:500;}
.free-badge{font-size:10px;padding:3px 9px;border-radius:var(--r-full);background:var(--g50);color:var(--g700);font-weight:600;white-space:nowrap;flex-shrink:0;}
.interest-btn{font-size:11px;padding:5px 12px;border:1px solid var(--border);border-radius:var(--r-full);background:transparent;color:var(--ink-3);cursor:pointer;transition:.15s;font-weight:500;font-family:var(--font-body);}
.interest-btn:hover,.interest-btn.interested{background:var(--g50);border-color:var(--g300);color:var(--g700);}

/* ── DEALS ── */
.deals-scroll{display:flex;gap:14px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;}
.deals-scroll::-webkit-scrollbar{display:none;}
.deal-card{min-width:180px;background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:.2s;flex-shrink:0;}
.deal-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.deal-top{padding:16px;background:linear-gradient(135deg,var(--sand),var(--white));}
.deal-pct{font-family:var(--font-display);font-size:32px;font-weight:800;color:var(--coral);line-height:1;}
.deal-pct small{font-size:14px;font-weight:600;}
.deal-shop{font-size:13px;font-weight:600;color:var(--ink);margin-top:4px;}
.deal-cat{font-size:11px;color:var(--ink-4);}
.deal-bottom{padding:8px 16px;border-top:1px solid var(--border);font-size:11px;color:var(--ink-4);display:flex;align-items:center;justify-content:space-between;}
.deal-timer{color:var(--coral);font-weight:600;}

/* ── HIDDEN SPOTS ── */
.spots-list{display:flex;flex-direction:column;gap:10px;}
.spot-item{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;display:flex;gap:14px;cursor:pointer;transition:.15s;}
.spot-item:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);}
.spot-map-thumb{width:54px;height:54px;background:var(--g50);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;}
.spot-info{flex:1;}
.spot-info h3{font-size:13px;font-weight:600;color:var(--ink);}
.spot-info p{font-size:11px;color:var(--ink-4);margin-top:3px;line-height:1.5;}
.spot-footer{display:flex;align-items:center;gap:8px;margin-top:6px;}
.spot-by{font-size:11px;color:var(--g700);font-weight:500;}
.spot-dot{width:3px;height:3px;background:var(--border-2);border-radius:50%;}
.spot-dist,.spot-saves{font-size:11px;color:var(--ink-4);}
.secret-badge{font-size:10px;padding:2px 7px;border-radius:var(--r-full);background:#FFF8E7;border:1px solid #FAC775;color:var(--amber-d);font-weight:600;}

/* ── RELAX SPOTS ── */
.relax-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;}
.relax-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:.2s;position:relative;overflow:hidden;}
.relax-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.relax-strip{height:3px;border-radius:2px;margin-bottom:12px;}
.relax-icon{font-size:26px;margin-bottom:8px;}
.relax-card h3{font-size:13px;font-weight:600;color:var(--ink);}
.relax-card .hours{font-size:11px;color:var(--ink-4);margin-top:3px;}
.relax-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:10px;}
.rtag{font-size:10px;padding:2px 7px;border-radius:var(--r-full);background:var(--sand);color:var(--ink-4);border:1px solid var(--border);}
.rtag.free-tag{background:var(--g50);color:var(--g700);border-color:var(--g100);}
.relax-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;}
.open-badge{font-size:10px;padding:2px 8px;border-radius:var(--r-full);background:#E8F6F0;color:var(--g700);font-weight:600;}
.closed-badge{font-size:10px;padding:2px 8px;border-radius:var(--r-full);background:#FEF3EE;color:var(--coral-d);font-weight:600;}

/* ── HOSTING ── */
.host-list{display:flex;flex-direction:column;gap:12px;}
.host-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:.15s;}
.host-card:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);}
.host-top{display:flex;align-items:flex-start;gap:14px;padding:16px;}
.host-av{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:18px;font-weight:700;flex-shrink:0;}
.host-info{flex:1;}
.host-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.host-name{font-size:14px;font-weight:600;color:var(--ink);}
.verified-badge{font-size:10px;background:var(--g50);color:var(--g700);padding:2px 8px;border-radius:var(--r-full);font-weight:600;display:flex;align-items:center;gap:3px;}
.host-loc{font-size:12px;color:var(--ink-4);margin-top:2px;}
.host-bio{font-size:12px;color:var(--ink-3);margin-top:6px;line-height:1.5;}
.host-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;}
.hbadge{font-size:10px;padding:3px 8px;border-radius:var(--r-full);border:1px solid var(--border);color:var(--ink-4);background:var(--sand);}
.hbadge.free{background:var(--g50);color:var(--g700);border-color:var(--g100);font-weight:600;}
.hbadge.paid{background:var(--amber-l);color:var(--amber-d);border-color:#FAC775;font-weight:600;}
.host-bottom{border-top:1px solid var(--border);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.avail-row{display:flex;align-items:center;gap:6px;}
.avail-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dot-green{background:var(--g500);}
.dot-amber{background:var(--amber);}
.dot-red{background:#E24B4A;}
.avail-txt{font-size:12px;color:var(--ink-4);}
.avail-txt strong{color:var(--ink);font-weight:600;}
.host-rating{font-size:12px;color:var(--amber);font-weight:700;}
.req-btn{font-size:12px;padding:6px 16px;border-radius:var(--r-full);border:1px solid var(--g300);color:var(--g700);background:transparent;cursor:pointer;font-weight:600;transition:.15s;font-family:var(--font-body);}
.req-btn:hover{background:var(--g500);color:var(--white);border-color:var(--g500);}

/* ── TRANSPORT ── */
.transport-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.t-tab{padding:7px 16px;border-radius:var(--r-full);font-size:12px;border:1px solid var(--border);color:var(--ink-4);cursor:pointer;background:var(--white);font-weight:500;transition:.15s;font-family:var(--font-body);}
.t-tab:hover{border-color:var(--g300);color:var(--g700);}
.t-tab.active{background:var(--g900);color:var(--white);border-color:var(--g900);}
.transport-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.t-route{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);gap:12px;cursor:pointer;transition:.15s;}
.t-route:last-child{border-bottom:none;}
.t-route:hover{background:var(--sand);}
.t-num{font-size:11px;font-weight:700;background:var(--g50);color:var(--g900);padding:4px 10px;border-radius:var(--r-sm);min-width:44px;text-align:center;font-family:var(--font-display);}
.t-info{flex:1;}
.t-info h3{font-size:13px;font-weight:600;color:var(--ink);}
.t-info p{font-size:11px;color:var(--ink-4);margin-top:2px;}
.t-fare{font-size:13px;font-weight:700;color:var(--g900);}
.t-next{font-size:11px;color:var(--coral);font-weight:600;}

/* ── VOLUNTEER ── */
.vol-list{display:flex;flex-direction:column;gap:10px;}
.vol-item{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;cursor:pointer;transition:.15s;}
.vol-item:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);}
.vol-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.vol-cause{font-size:10px;padding:3px 9px;border-radius:var(--r-full);font-weight:600;}
.vol-title{font-size:13px;font-weight:600;color:var(--ink);margin-top:6px;}
.vol-org{font-size:11px;color:var(--g700);font-weight:500;margin-top:2px;}
.vol-desc{font-size:12px;color:var(--ink-4);margin-top:6px;line-height:1.5;}
.vol-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;}
.vol-tag{font-size:10px;padding:2px 7px;border-radius:var(--r-full);background:var(--sand);color:var(--ink-4);border:1px solid var(--border);}
.vol-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;}
.vol-deadline{font-size:11px;color:var(--ink-4);}
.apply-btn{font-size:11px;padding:5px 14px;border-radius:var(--r-full);border:1px solid var(--coral);color:var(--coral);background:transparent;cursor:pointer;font-weight:600;transition:.15s;font-family:var(--font-body);}
.apply-btn:hover{background:var(--coral);color:var(--white);}

/* ── MODAL OVERLAY ── */
.modal-overlay{position:fixed;inset:0;background:rgba(15,28,23,.5);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:.25s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--white);border-radius:var(--r-xl);padding:28px;width:100%;max-width:500px;max-height:88vh;overflow-y:auto;transform:translateY(12px);transition:.25s;box-shadow:var(--shadow-lg);}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.modal-head h2{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);}
.modal-close{width:32px;height:32px;border:1px solid var(--border);border-radius:50%;background:var(--sand);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-3);transition:.15s;}
.modal-close:hover{background:var(--border);color:var(--ink);}

/* ── POST FORM ── */
.form-group{margin-bottom:16px;}
.form-label{font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:6px;display:block;}
.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-md);font-size:13px;color:var(--ink);background:var(--white);font-family:var(--font-body);outline:none;transition:.15s;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--g500);box-shadow:0 0 0 3px rgba(29,158,117,.1);}
.form-textarea{resize:vertical;min-height:90px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.submit-btn{width:100%;padding:13px;background:var(--g500);color:var(--white);border:none;border-radius:var(--r-lg);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:.15s;margin-top:4px;}
.submit-btn:hover{background:var(--g700);}
.type-toggle{display:flex;gap:8px;flex-wrap:wrap;}
.type-pill{padding:6px 14px;border-radius:var(--r-full);font-size:12px;border:1px solid var(--border);color:var(--ink-4);cursor:pointer;background:var(--white);font-weight:500;transition:.15s;font-family:var(--font-body);}
.type-pill:hover{border-color:var(--g300);color:var(--g700);}
.type-pill.sel{background:var(--g500);color:var(--white);border-color:var(--g500);}
.google-btn{width:100%;padding:11px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--white);cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--font-body);transition:0.2s;}
.google-btn:hover{background:var(--sand);border-color:var(--ink-4);}
.otp-input{font-size:22px;letter-spacing:8px;text-align:center;}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:80px;right:20px;z-index:600;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--g900);color:var(--white);padding:10px 16px;border-radius:var(--r-lg);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);animation:slideIn .3s ease;display:flex;align-items:center;gap:8px;transition:0.3s;}
@keyframes slideIn{from{transform:translateX(40px);opacity:0;}to{transform:translateX(0);opacity:1;}}
.toast.success::before{content:'✓';width:18px;height:18px;background:var(--g500);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;}
.toast.error{background:#8C3318;}

/* ── BOTTOM NAV (mobile) ── */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--border);z-index:200;padding:8px 0 max(8px,env(safe-area-inset-bottom));}
.bn-inner{display:flex;justify-content:space-around;}
.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--ink-4);cursor:pointer;padding:4px 12px;transition:.15s;font-weight:500;}
.bn-item.active{color:var(--g500);}
.bn-icon{font-size:20px;line-height:1;}

/* ── FAB ── */
.fab{position:fixed;bottom:90px;right:20px;z-index:300;width:52px;height:52px;background:var(--coral);color:var(--white);border-radius:50%;border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 16px rgba(216,90,48,.4);display:none;align-items:center;justify-content:center;transition:.15s;}
.fab:hover{background:var(--coral-d);transform:scale(1.06);}

/* ── DISTRICT MODAL ── */
.district-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;}
.district-btn{padding:9px;border:1px solid var(--border);border-radius:var(--r-md);font-size:12px;text-align:center;cursor:pointer;background:var(--white);color:var(--ink-3);font-weight:500;transition:.15s;font-family:var(--font-body);}
.district-btn:hover{border-color:var(--g300);background:var(--g50);color:var(--g700);}
.district-btn.active{background:var(--g900);color:var(--white);border-color:var(--g900);}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .bottom-nav,.fab{display:flex;}
  .nav .btn-signin{display:none;}
  .nav .btn-post{display:none;}
  .hero-stats{gap:20px;}
  .stat-num{font-size:18px;}
  .main{padding-bottom:100px;}
  .form-row{grid-template-columns:1fr;}
  .relax-grid,.attract-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:480px){
  .hero h1{font-size:24px;}
  .search-wrap{flex-direction:column;}
  .search-btn{width:100%;}
  .relax-grid,.attract-grid{grid-template-columns:1fr;}
  .district-grid{grid-template-columns:repeat(2,1fr);}
  .hero-stats{display:none;}
}

/* ── SECTION VISIBLE/HIDDEN ── */
.section-block{animation:fadeUp .4s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.section-block.hidden{display:none;}

/* ── MAP PLACEHOLDER ── */
.map-placeholder{height:220px;background:linear-gradient(135deg,#e8f4f0,#d4ede5);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;border:1px solid var(--border);position:relative;overflow:hidden;margin-bottom:16px;}
.map-placeholder::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Ccircle cx='20' cy='20' r='1.5' fill='%231D9E75' opacity='.3'/%3E%3Ccircle cx='50' cy='50' r='1.5' fill='%231D9E75' opacity='.3'/%3E%3Ccircle cx='80' cy='30' r='1.5' fill='%231D9E75' opacity='.3'/%3E%3Ccircle cx='30' cy='70' r='1.5' fill='%231D9E75' opacity='.3'/%3E%3Ccircle cx='70' cy='80' r='1.5' fill='%231D9E75' opacity='.3'/%3E%3C/svg%3E") repeat;}
.map-inner{text-align:center;z-index:1;}
.map-inner p{font-size:13px;color:var(--g700);font-weight:600;margin-top:8px;}
.map-inner small{font-size:11px;color:var(--g700);opacity:.7;}
.map-pin{font-size:32px;}
