:root{--brand:#1a3c5e;--bl:#2a5c8e;--acc:#c8a94a;--bg:#f5f3ef;--card:#fff;--bdr:#e8e3da;--text:#1a1814;--muted:#7a7268;--red:#dc2626;--green:#16a34a;--st:env(safe-area-inset-top,0px);--sb:env(safe-area-inset-bottom,0px)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;font-family:"DM Sans",sans-serif;background:var(--bg);color:var(--text);font-size:15px}
/* PAGE LAYOUT — each page is its own flex column */
.page{display:flex;flex-direction:column;min-height:100dvh}
.scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--sb) + 60px)}
.scroll-area::-webkit-scrollbar{display:none}
/* STATUS BAR */
.status-bar{height:var(--st);background:var(--brand);flex-shrink:0}
/* TOPBAR */
.topbar{background:var(--brand);color:#fff;flex-shrink:0;z-index:10}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px}
.brand-mark{width:34px;height:34px;border-radius:8px;background:var(--acc);color:var(--brand);display:flex;align-items:center;justify-content:center;font-family:"DM Serif Display",serif;font-size:16px;font-weight:700}
.brand-text{font-family:"DM Serif Display",serif;font-size:18px}
.brand-sub{font-size:11px;opacity:.6}
/* TOPBAR AVATAR */
.topbar-av{width:34px;height:34px;border-radius:10px;border:2px solid rgba(255,255,255,.3);overflow:hidden;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:"DM Serif Display",serif;font-size:14px;font-weight:700;color:var(--brand);background:var(--acc);text-decoration:none}
.topbar-av:active{border-color:rgba(255,255,255,.7)}
.topbar-av img{width:100%;height:100%;object-fit:cover}
/* BOTTOM NAV */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--bdr);display:flex;padding-bottom:var(--sb);z-index:200}
.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 0 8px;cursor:pointer;border:none;background:none;color:var(--muted);font-family:"DM Sans",sans-serif;position:relative;transition:color .15s;text-decoration:none}
.nav-tab.active{color:var(--brand)}
.nav-tab.active::before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--brand);border-radius:0 0 3px 3px}
.nav-icon{font-size:18px;line-height:1;margin-bottom:2px}
.nav-label{font-size:9px;font-weight:500;letter-spacing:.3px}
/* CARDS & COMMON */
.card{background:var(--card);border:1px solid var(--bdr);border-radius:14px;overflow:hidden}
.section{padding:16px 18px}
.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-title{font-weight:600;font-size:15px}
.sec-link{font-size:13px;color:var(--brand);cursor:pointer;text-decoration:none}
/* HOME HERO */
.hero{background:var(--brand);color:#fff;padding:18px 18px 22px}
.hero-greeting{font-family:"DM Serif Display",serif;font-size:28px;margin-bottom:2px}
.hero-sub{font-size:13px;opacity:.65;margin-bottom:14px}
.hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hc{background:rgba(255,255,255,.12);border-radius:12px;padding:14px}
.hc-lbl{font-size:10px;opacity:.7;letter-spacing:.5px;text-transform:uppercase;margin-bottom:3px}
.hc-val{font-size:28px;font-weight:700;font-family:"DM Serif Display",serif}
.hc-sub{font-size:11px;opacity:.6}
/* SKELETON */
.skel{background:rgba(255,255,255,.18);border-radius:6px;display:inline-block;min-width:40px;height:1em}
/* CELEB STRIP */
.celeb-strip{display:flex;gap:10px;overflow-x:auto;padding:0 18px 16px;-webkit-overflow-scrolling:touch}
.celeb-strip::-webkit-scrollbar{display:none}
.celeb-card{flex-shrink:0;width:120px;background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:12px;text-align:center}
.celeb-emoji{font-size:22px;margin-bottom:4px}
.celeb-nm{font-weight:600;font-size:12px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.celeb-sub{font-size:10px;color:var(--muted);margin-bottom:5px}
.celeb-days{font-size:10px;font-weight:700;background:#eff6ff;color:var(--brand);padding:2px 8px;border-radius:20px;display:inline-block}
.celeb-days.today{background:#fef2f2;color:var(--red)}
/* EVENT CARD */
.ev-card{background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:16px;margin-bottom:10px}
.ev-date{font-size:11px;color:var(--muted);margin-bottom:4px}
.ev-name{font-weight:600;font-size:15px;margin-bottom:4px}
.ev-venue{font-size:12px;color:var(--muted)}
/* EVENTS PAGE */
.ev-hero{background:var(--brand);color:#fff;padding:20px 18px 16px}
.ev-title{font-family:"DM Serif Display",serif;font-size:24px;margin-bottom:2px}
.ev-tabs{display:flex;background:rgba(255,255,255,.15);border-radius:10px;padding:3px;margin-top:12px}
.ev-tab{flex:1;text-align:center;padding:7px;font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;color:rgba(255,255,255,.8);transition:all .15s}
.ev-tab.active{background:#fff;color:var(--brand)}
/* DIRECTORY */
.search-wrap{padding:14px 18px 0}
.search-field{display:flex;align-items:center;gap:10px;background:var(--card);border:1.5px solid var(--bdr);border-radius:12px;padding:10px 14px}
.search-field input{border:none;outline:none;flex:1;font-size:14px;font-family:"DM Sans",sans-serif;background:transparent;color:var(--text)}
.filter-chips{display:flex;gap:8px;overflow-x:auto;padding:10px 18px;-webkit-overflow-scrolling:touch}
.filter-chips::-webkit-scrollbar{display:none}
.fchip{flex-shrink:0;padding:5px 13px;border-radius:20px;border:1.5px solid var(--bdr);font-size:12px;font-weight:500;cursor:pointer;background:var(--card);color:var(--muted);transition:all .15s}
.fchip.active{background:var(--brand);border-color:var(--brand);color:#fff}
.member-list{padding:0 18px 24px}
.alpha-hd{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 0 4px}
.member-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border:1px solid var(--bdr);border-radius:12px;margin-bottom:6px;cursor:pointer;transition:background .1s}
.member-row:active{background:var(--bg)}
.m-av{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0}
.m-name{font-weight:500;font-size:14px;margin-bottom:2px}
.m-meta{font-size:12px;color:var(--muted)}
.hbadge{display:inline-block;font-size:10px;background:#eff6ff;color:var(--brand);padding:1px 6px;border-radius:8px;margin-left:5px;font-weight:400}
/* CELEBRATIONS PAGE */
.ca-hero{background:var(--brand);color:#fff;padding:20px 18px 16px}
.ca-title{font-family:"DM Serif Display",serif;font-size:24px;margin-bottom:2px}
.ca-tabs{display:flex;background:rgba(255,255,255,.15);border-radius:10px;padding:3px;margin-top:12px}
.ca-tab{flex:1;text-align:center;padding:6px;font-size:12px;font-weight:500;border-radius:8px;cursor:pointer;color:rgba(255,255,255,.8);transition:all .15s}
.ca-tab.active{background:#fff;color:var(--brand)}
.month-bar{display:flex;gap:8px;overflow-x:auto;padding:10px 18px;background:var(--card);border-bottom:1px solid var(--bdr);-webkit-overflow-scrolling:touch}
.month-bar::-webkit-scrollbar{display:none}
.mchip{flex-shrink:0;padding:5px 12px;border-radius:16px;border:1.5px solid var(--bdr);font-size:12px;font-weight:500;cursor:pointer;background:var(--card);color:var(--muted);transition:all .15s}
.mchip.active{background:var(--brand);border-color:var(--brand);color:#fff}
.ci{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--bdr)}
.ci:last-child{border-bottom:none}
.ci-av{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}
/* BUSINESS PAGE */
.biz-hero{background:var(--brand);color:#fff;padding:20px 18px 16px}
.biz-sw{display:flex;gap:10px;margin-top:12px}
.biz-si{flex:1;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);border-radius:10px;padding:9px 12px}
.biz-si input{border:none;outline:none;background:transparent;color:#fff;font-size:13px;flex:1;font-family:"DM Sans",sans-serif}
.biz-si input::placeholder{color:rgba(255,255,255,.6)}
.biz-ab{background:var(--acc);color:var(--brand);border:none;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:"DM Sans",sans-serif;white-space:nowrap}
.biz-card{background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:16px;-webkit-tap-highlight-color:transparent}
a[href*='business_profile']:has(.biz-card){display:block;margin-bottom:10px;}
a[href*='business_profile']:active .biz-card{opacity:.85}
.biz-hdr{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.biz-av{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:15px;flex-shrink:0}
.biz-firm{font-weight:600;font-size:15px;margin-bottom:3px}
.biz-cat{font-size:11px;font-weight:600;color:var(--brand);background:#eff6ff;padding:2px 8px;border-radius:8px;display:inline-block}
.biz-mem{font-size:12px;color:var(--muted);margin-top:4px}
.biz-desc{font-size:13px;color:var(--muted);margin-bottom:10px;line-height:1.5}
.biz-acts{display:flex;gap:8px;flex-wrap:wrap}
.biz-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;border:1.5px solid var(--bdr);font-size:12px;font-weight:500;cursor:pointer;background:var(--card);color:var(--text);font-family:"DM Sans",sans-serif}
/* PROFILE PAGE */
.prof-hero{background:var(--brand);color:#fff;padding:28px 18px 24px;text-align:center}
.my-av-wrap{position:relative;width:76px;height:76px;margin:0 auto 12px;cursor:pointer}
.my-av{width:76px;height:76px;border-radius:20px;background:var(--acc);color:var(--brand);display:flex;align-items:center;justify-content:center;font-family:"DM Serif Display",serif;font-size:28px;overflow:hidden}
.my-av img{width:100%;height:100%;object-fit:cover}
.my-av-edit{position:absolute;bottom:-5px;right:-5px;width:26px;height:26px;border-radius:8px;background:var(--acc);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:14px;border:2px solid var(--brand);pointer-events:none}
.my-name{font-family:"DM Serif Display",serif;font-size:22px;margin-bottom:2px}
.my-role{font-size:12px;opacity:.7;margin-bottom:16px}
.my-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.2);border-radius:12px;overflow:hidden}
.my-stat{background:rgba(255,255,255,.1);padding:12px;text-align:center}
.ms-val{font-size:18px;font-weight:700;font-family:"DM Serif Display",serif}
.ms-label{font-size:10px;opacity:.6;margin-top:2px}
/* MENU LIST */
.menu-list{border-radius:14px;border:1px solid var(--bdr);overflow:hidden;background:var(--card)}
.menu-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--bdr);cursor:pointer;transition:background .1s}
.menu-item:last-child{border-bottom:none}
.menu-item:active{background:var(--bg)}
.mi-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.mi-label{font-weight:500;font-size:14px}
.mi-sub{font-size:12px;color:var(--muted);margin-top:1px}
.mi-chev{font-size:20px;color:var(--muted);margin-left:auto}
/* SHEET (bottom drawer) */
.sheet-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;opacity:0;pointer-events:none;transition:opacity .25s}
.sheet-ov.open{opacity:1;pointer-events:all}
.sheet{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-radius:20px 20px 0 0;z-index:301;transform:translateY(102%);transition:transform .3s cubic-bezier(.32,.72,0,1);max-height:92vh;overflow-y:auto;padding-bottom:calc(var(--sb) + 16px)}
.sheet.open{transform:translateY(0)}
.sh-handle{width:40px;height:4px;background:var(--bdr);border-radius:2px;margin:12px auto 0}
.sh-title{font-weight:600;font-size:16px;padding:14px 18px 12px;border-bottom:1px solid var(--bdr)}
/* FORMS */
.fsec{padding:14px 18px;border-bottom:1px solid var(--bdr)}
.fsec-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.fg{margin-bottom:10px}
.fg label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:4px}
.fi,.fsel,.fta{width:100%;padding:10px 12px;border:1.5px solid var(--bdr);border-radius:10px;font-size:14px;font-family:"DM Sans",sans-serif;outline:none;background:var(--bg);color:var(--text);transition:border .15s}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--brand);background:#fff}
.fta{resize:vertical;min-height:76px}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
/* TOGGLE */
.tog-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--bdr)}
.tog-row:last-child{border-bottom:none}
.tog-lbl{font-size:14px;font-weight:500}
.tog-sub{font-size:12px;color:var(--muted);margin-top:2px}
.tog{position:relative;width:44px;height:24px;flex-shrink:0}
.tog input{opacity:0;width:0;height:0;position:absolute}
.tog-sl{position:absolute;inset:0;background:#ccc;border-radius:24px;cursor:pointer;transition:.2s}
.tog-sl::before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s}
.tog input:checked+.tog-sl{background:var(--brand)}
.tog input:checked+.tog-sl::before{transform:translateX(20px)}
/* BUTTONS */
.btn-p{background:var(--brand);color:#fff;border:none;padding:13px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:"DM Sans",sans-serif;width:100%;transition:opacity .15s}
.btn-p:active{opacity:.85}
.btn-o{background:transparent;color:var(--brand);border:1.5px solid var(--brand);padding:11px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:"DM Sans",sans-serif;width:100%}
.save-bar{padding:12px 18px;border-top:1px solid var(--bdr);display:flex;gap:10px;position:sticky;bottom:0;background:var(--card)}
/* STATES */
.loading{text-align:center;padding:36px 20px;color:var(--muted);font-size:13px}
.empty{text-align:center;padding:40px 20px}
.empty-icon{font-size:36px;margin-bottom:10px}
.empty-title{font-weight:600;font-size:15px;margin-bottom:4px}
.empty-sub{font-size:13px;color:var(--muted)}
/* TOAST */
#toast{position:fixed;bottom:calc(70px + var(--sb));left:50%;transform:translateX(-50%) translateY(16px);background:#1a1814;color:#fff;padding:10px 20px;border-radius:30px;font-size:13px;font-weight:500;z-index:999;opacity:0;transition:all .3s;white-space:nowrap;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.ok{background:var(--green)}
#toast.err{background:var(--red)}
/* MEMBER DETAIL (full profile view on directory) */
.fp-hero{background:var(--brand);color:#fff;padding:24px 18px;text-align:center}
.fp-av{width:80px;height:80px;border-radius:20px;background:var(--acc);color:var(--brand);display:flex;align-items:center;justify-content:center;font-family:"DM Serif Display",serif;font-size:32px;margin:0 auto 12px;overflow:hidden}
.fp-av img{width:100%;height:100%;object-fit:cover}
.fp-name{font-family:"DM Serif Display",serif;font-size:22px;margin-bottom:4px}
.fp-meta{font-size:13px;opacity:.7}
.fp-actions{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.fp-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:10px;padding:8px 14px;font-size:13px;color:#fff;cursor:pointer;font-family:"DM Sans",sans-serif}
.fp-section{padding:14px 18px;border-bottom:1px solid var(--bdr)}
.fp-section-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.fp-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--bdr)}
.fp-row:last-child{border-bottom:none}
.fp-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.fp-row-label{font-size:12px;color:var(--muted);margin-bottom:2px}
.fp-row-value{font-size:14px;font-weight:500}
