/* ===== GOOGLE FONTS ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,600&family=Jost:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

/* ─── RESET & VARIABLES ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --primary:#1F1F1F;--bg:#FFFFFF;--accent:#F5A623;--accent2:#2563EB;
  --green:#16A34A;--red:#DC2626;
  --gray50:#F9FAFB;--gray100:#F3F4F6;--gray200:#E5E7EB;--gray400:#9CA3AF;
  --gray500:#6B7280;--gray700:#374151;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow:0 4px 16px rgba(0,0,0,.10);--shadow-lg:0 10px 40px rgba(0,0,0,.15);
  --radius:14px;--radius-sm:10px;--radius-xs:8px;
  --nav-h:64px;--header-h:56px;
  --font-display:'Syne',sans-serif;--font-body:'DM Sans',sans-serif;
  --transition:all .22s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--primary);min-height:100dvh;overflow-x:hidden;overscroll-behavior:none}

/* ─── LAYOUT ─── */
.page{display:none;flex:1;overflow-y:auto;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));animation:fadeIn .2s ease}
.page.active{display:flex;flex-direction:column}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ─── HEADER ─── */
.top-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--gray200);display:flex;align-items:center;padding:0 16px;gap:12px}
.top-header .logo{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--primary);letter-spacing:-.5px}
.top-header .logo span{color:var(--accent)}
.top-header .back-btn{width:36px;height:36px;border-radius:50%;background:var(--gray100);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}
.top-header .back-btn:hover{background:var(--gray200)}
.top-header .title{font-family:var(--font-display);font-weight:700;font-size:1rem;flex:1}
.top-header .spacer{flex:1}
.top-header .icon-btn{width:36px;height:36px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.top-header .icon-btn:hover{background:var(--gray100)}

/* ─── BOTTOM NAV ─── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:200;height:calc(var(--nav-h) + env(safe-area-inset-bottom));background:rgba(255,255,255,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--gray200);display:flex;align-items:flex-start;padding-top:8px;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 20px rgba(0,0,0,.06)}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px 0;border:none;background:transparent;transition:var(--transition)}
.nav-item svg{width:22px;height:22px;transition:var(--transition)}
.nav-item span{font-size:.65rem;font-weight:500;color:var(--gray400);transition:var(--transition)}
.nav-item.active svg{stroke:var(--primary)}.nav-item.active span{color:var(--primary);font-weight:700}
.nav-item:not(.active) svg{stroke:var(--gray400)}
.nav-item.add-btn .add-circle{width:46px;height:46px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;margin-top:-18px;box-shadow:0 4px 16px rgba(31,31,31,.35);transition:var(--transition)}
.nav-item.add-btn .add-circle svg{stroke:#fff;width:22px;height:22px}
.nav-item.add-btn:hover .add-circle{transform:scale(1.08)}
.nav-item.add-btn span{color:var(--gray400);font-size:.65rem;font-weight:500;margin-top:2px}

/* ─── SCROLL ─── */
.scroll-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* ─── CARDS ─── */
.card{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--gray100);overflow:hidden;transition:var(--transition)}
.card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:.9rem;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);padding:12px 20px;width:100%}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#333;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-primary:active{transform:translateY(0)}
.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}
.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:#e09410}
.btn-ghost{background:var(--gray100);color:var(--primary)}.btn-ghost:hover{background:var(--gray200)}
.btn-green{background:var(--green);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-blue{background:var(--accent2);color:#fff}
.btn-sm{padding:8px 14px;font-size:.8rem}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ─── FORMS ─── */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-label{font-size:.8rem;font-weight:600;color:var(--gray700);letter-spacing:.02em}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 14px;border:1.5px solid var(--gray200);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;color:var(--primary);background:var(--bg);transition:var(--transition);outline:none;-webkit-appearance:none;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(31,31,31,.08)}
.form-textarea{resize:vertical;min-height:90px}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-hint{font-size:.75rem;color:var(--gray500)}

/* ─── CHIPS ─── */
.chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{padding:6px 12px;border-radius:20px;border:1.5px solid var(--gray200);font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition);background:var(--bg);color:var(--gray700)}
.chip.active{border-color:var(--primary);background:var(--primary);color:#fff}

/* ─── DIVIDER ─── */
.divider{display:flex;align-items:center;gap:12px;margin:16px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--gray200)}
.divider span{font-size:.75rem;color:var(--gray400);white-space:nowrap}

/* ─── BADGE ─── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600}
.badge-pending{background:#FEF3C7;color:#92400E}.badge-approved{background:#D1FAE5;color:#065F46}
.badge-rejected{background:#FEE2E2;color:#991B1B}.badge-premium{background:linear-gradient(135deg,#F5A623,#E58A09);color:#fff}
.badge-pending_payment{background:#FEF3C7;color:#92400E}

/* ─── PAYMENT SYSTEM ─── */
.step-indicator{display:flex;align-items:center;padding:16px 20px 0;gap:0;margin-bottom:4px}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;transition:all .3s;flex-shrink:0;border:2px solid var(--gray200);color:var(--gray400);background:var(--bg)}
.step-dot.done{background:var(--green);border-color:var(--green);color:#fff}
.step-dot.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px rgba(31,31,31,.12)}
.step-line{flex:1;height:2px;background:var(--gray200);transition:background .3s}
.step-line.done{background:var(--green)}
.step-labels{display:flex;justify-content:space-between;padding:4px 12px 0;margin-bottom:16px}
.step-labels span{font-size:.62rem;font-weight:600;color:var(--gray400);text-align:center;flex:1}
.step-labels span.active{color:var(--primary)}
.step-labels span.done{color:var(--green)}
.form-step{display:none;animation:fadeIn .22s ease}
.form-step.active{display:block}
.upi-box{border:2px solid var(--gray200);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.upi-box-header{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px 20px;color:#fff;text-align:center}
.upi-box-header .mbp-logo-pay{font-family:var(--font-display);font-size:1.2rem;font-weight:800;margin-bottom:2px}
.upi-box-header .pay-amount{font-size:2rem;font-weight:800;font-family:var(--font-display);color:#F5A623;margin:4px 0}
.upi-box-header .pay-label{font-size:.75rem;opacity:.7}
.upi-qr-section{padding:20px;text-align:center;background:#fafafa;border-bottom:1px solid var(--gray100)}
.upi-qr-section .qr-wrap{width:160px;height:160px;margin:0 auto 12px;background:#fff;border-radius:12px;padding:8px;box-shadow:0 4px 16px rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center}
.upi-qr-section .scan-label{font-size:.78rem;color:var(--gray500);font-weight:600}
.upi-divider{display:flex;align-items:center;gap:10px;padding:0 20px;margin:12px 0}
.upi-divider::before,.upi-divider::after{content:'';flex:1;height:1px;background:var(--gray200)}
.upi-divider span{font-size:.72rem;color:var(--gray400)}
.upi-id-row{padding:0 20px 20px;display:flex;flex-direction:column;gap:8px}
.upi-id-copy{display:flex;align-items:center;gap:10px;background:var(--gray50);border:1.5px solid var(--gray200);border-radius:var(--radius-sm);padding:12px 14px}
.upi-id-copy .upi-id-val{flex:1;font-family:monospace;font-size:.95rem;font-weight:700;color:var(--primary);letter-spacing:.5px}
.upi-id-copy button{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0;white-space:nowrap}
.upi-apps{display:flex;gap:10px;padding:0 20px 20px;justify-content:center;flex-wrap:wrap}
.upi-app-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;border:1.5px solid var(--gray200);border-radius:10px;cursor:pointer;transition:var(--transition);background:var(--bg);text-decoration:none;min-width:64px}
.upi-app-btn:hover{border-color:var(--primary);background:var(--gray50)}
.upi-app-btn .app-icon{font-size:1.5rem}
.upi-app-btn .app-name{font-size:.65rem;font-weight:600;color:var(--gray700)}
.discount-timer{background:linear-gradient(135deg,#DC2626,#B91C1C);color:#fff;border-radius:var(--radius-sm);padding:10px 14px;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.discount-timer .timer-icon{font-size:1.2rem;flex-shrink:0}
.discount-timer .timer-text{flex:1;font-size:.78rem;line-height:1.4}
.discount-timer .timer-val{font-family:var(--font-display);font-size:1rem;font-weight:800;white-space:nowrap;background:rgba(255,255,255,.15);padding:4px 10px;border-radius:8px}
.ss-upload-box{border:2.5px dashed var(--gray200);border-radius:var(--radius);padding:28px 20px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--gray50);position:relative}
.ss-upload-box:hover{border-color:var(--accent);background:#FFFBEB}
.ss-upload-box input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.ss-upload-box .ss-icon{font-size:2.5rem;margin-bottom:8px}
.ss-upload-box .ss-label{font-size:.85rem;font-weight:600;color:var(--gray700);margin-bottom:4px}
.ss-upload-box .ss-hint{font-size:.75rem;color:var(--gray400)}
.ss-upload-box img.ss-preview{width:100%;max-height:220px;object-fit:contain;border-radius:8px;margin-top:12px;display:none}
.submit-success{text-align:center;padding:24px 8px}
.submit-success .success-icon{font-size:4rem;margin-bottom:12px;display:block}
.submit-success h2{font-family:var(--font-display);font-size:1.3rem;font-weight:800;margin-bottom:8px}
.submit-success p{font-size:.83rem;color:var(--gray500);line-height:1.6;margin-bottom:16px}
.submit-success .timeline{display:flex;flex-direction:column;gap:10px;text-align:left;background:var(--gray50);border-radius:var(--radius-sm);padding:14px;border:1px solid var(--gray100)}
.submit-success .tl-item{display:flex;align-items:flex-start;gap:10px;font-size:.8rem}
.submit-success .tl-dot{width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0;margin-top:1px}
.payment-row{padding:14px 16px;border-bottom:1px solid var(--gray100)}
.payment-row .pr-biz{font-weight:700;font-size:.88rem;margin-bottom:2px}
.payment-row .pr-meta{font-size:.75rem;color:var(--gray500);line-height:1.6}
.payment-row .pr-ss{width:56px;height:56px;border-radius:8px;object-fit:cover;background:var(--gray100);flex-shrink:0;cursor:pointer;border:1.5px solid var(--gray200)}
.payment-status-pending{background:#FEF3C7;color:#92400E;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;display:inline-block}
.payment-status-verified{background:#D1FAE5;color:#065F46;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;display:inline-block}
.payment-status-rejected{background:#FEE2E2;color:#991B1B;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;display:inline-block}

/* ─── PLAN CARDS (Razorpay) ─── */
.plan-card{border:2px solid var(--gray200);border-radius:var(--radius-sm);padding:14px;background:var(--bg);transition:var(--transition);cursor:pointer}
.plan-card.active{border-color:var(--primary);background:var(--gray50);box-shadow:0 0 0 3px rgba(31,31,31,.06)}
.plan-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--gray400);flex-shrink:0;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.plan-radio.active{border-color:var(--primary);background:var(--primary)}
.plan-radio.active::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}

/* ─── TOAST ─── */
#toast{position:fixed;bottom:calc(var(--nav-h)+16px+env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(20px);background:var(--primary);color:#fff;padding:10px 20px;border-radius:24px;font-size:.85rem;font-weight:500;z-index:9999;opacity:0;transition:all .3s ease;white-space:nowrap;max-width:90vw;text-align:center;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ─── MODAL ─── */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:none;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom)}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease}
.modal-sheet{background:var(--bg);border-radius:24px 24px 0 0;padding:24px 20px 32px;width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}
.modal-handle{width:36px;height:4px;background:var(--gray200);border-radius:2px;margin:0 auto 20px}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:16px}

/* ─── SPINNER ─── */
.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner-dark{border-color:rgba(31,31,31,.15);border-top-color:var(--primary)}

/* ─── AVATAR ─── */
.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--gray200);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;overflow:hidden}

/* ─── STARS ─── */
.stars{display:flex;gap:2px;align-items:center}.star{font-size:.95rem;color:#E5E7EB;line-height:1}.star.filled{color:#FBBF24!important}

/* ─── IMAGE UPLOAD ─── */
.img-upload-box{border:2px dashed var(--gray200);border-radius:var(--radius-sm);padding:24px;text-align:center;cursor:pointer;transition:var(--transition);display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--gray50);position:relative;overflow:hidden}
.img-upload-box:hover{border-color:var(--primary);background:var(--gray100)}
.img-upload-box input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.img-upload-box img.preview{width:100%;height:120px;object-fit:cover;border-radius:8px}
.img-upload-box .upload-icon{font-size:1.8rem;color:var(--gray400)}
.img-upload-box .upload-label{font-size:.8rem;color:var(--gray500);font-weight:500}

/* ─── SECTION ─── */
.section{padding:20px 16px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--primary)}

/* ─── BIZ CARD ─── */
.biz-card{display:flex;gap:14px;padding:16px;cursor:pointer}
.biz-card .biz-logo{width:72px;height:72px;border-radius:var(--radius-sm);object-fit:cover;background:var(--gray200);flex-shrink:0;border:1px solid var(--gray100)}
.biz-card .biz-info{flex:1;min-width:0}
.biz-card .biz-name{font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;color:var(--primary)}
.biz-card .biz-type{font-size:.73rem;color:#fff;background:var(--primary);display:inline-block;padding:2px 8px;border-radius:20px;margin-bottom:6px;font-weight:600;letter-spacing:.02em}
.biz-card .biz-desc{font-size:.78rem;color:var(--gray500);line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.biz-card .biz-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.biz-card .biz-addr{font-size:.73rem;color:var(--gray400);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}
.biz-card .biz-review-count{font-size:.72rem;color:var(--gray400);white-space:nowrap}
/* Richer card footer strip */
.biz-card-footer{display:flex;align-items:center;gap:8px;padding:0 16px 12px;border-top:1px solid var(--gray50);padding-top:10px}
.biz-tag{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;color:var(--gray500);background:var(--gray50);padding:3px 8px;border-radius:20px;border:1px solid var(--gray200)}

/* ─── HERO ─── */
.home-hero{padding:20px 16px 4px}
/* SEO: visible H1 for Google, styled via CSS */
.home-hero h1{font-family:var(--font-display);font-size:1.7rem;font-weight:800;line-height:1.2;margin-bottom:4px}
.home-hero h1 span{color:var(--accent)}
.home-hero p{font-size:.85rem;color:var(--gray500);margin-bottom:16px}

/* ─── SEARCH BAR ─── */
.search-bar{display:flex;align-items:center;gap:10px;background:var(--gray50);border:1.5px solid var(--gray200);border-radius:var(--radius);padding:10px 14px;transition:var(--transition)}
.search-bar:focus-within{border-color:var(--primary);background:var(--bg);box-shadow:0 0 0 3px rgba(31,31,31,.07)}
.search-bar input{flex:1;border:none;background:transparent;font-family:var(--font-body);font-size:.9rem;outline:none;color:var(--primary)}
.search-bar input::placeholder{color:var(--gray400)}
.search-bar svg{stroke:var(--gray400);flex-shrink:0}

/* ─── CATEGORIES ─── */
.cat-scroll{display:flex;gap:10px;overflow-x:auto;padding:0 16px 4px;scrollbar-width:none}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;border-radius:var(--radius-sm);background:var(--gray50);border:1.5px solid var(--gray200);cursor:pointer;transition:var(--transition);min-width:64px}
.cat-chip .cat-icon{font-size:1.3rem}.cat-chip .cat-label{font-size:.65rem;font-weight:600;color:var(--gray700);white-space:nowrap}
.cat-chip.active{background:var(--primary);border-color:var(--primary)}.cat-chip.active .cat-label{color:#fff}

/* ─── FEATURED BANNER ─── */
.featured-banner{margin:0 16px;border-radius:var(--radius);overflow:hidden;background:linear-gradient(135deg,#1F1F1F,#374151);padding:20px;position:relative}
.featured-banner::after{content:'⭐';position:absolute;right:20px;bottom:-4px;font-size:4rem;opacity:.15}
.featured-banner h2{font-family:var(--font-display);color:#fff;font-size:1.1rem;font-weight:800;margin-bottom:4px}
.featured-banner p{color:rgba(255,255,255,.65);font-size:.8rem;margin-bottom:12px}
.featured-banner .btn{width:auto;background:#fff;color:var(--primary);font-size:.8rem;padding:8px 16px}

/* ─── BIZ DETAIL ─── */
.biz-cover{width:100%;height:220px;object-fit:cover;background:linear-gradient(135deg,var(--gray100),var(--gray200));display:block}
.biz-detail-header{position:relative;padding:0 16px;margin-top:-36px;margin-bottom:16px}
.biz-detail-logo{width:76px;height:76px;border-radius:var(--radius-sm);border:3px solid #fff;box-shadow:var(--shadow);object-fit:cover;background:var(--gray200)}
.biz-detail-name{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:2px;margin-top:8px}
.biz-detail-type{font-size:.78rem;color:#fff;background:var(--primary);display:inline-block;padding:3px 10px;border-radius:20px;margin-bottom:10px;font-weight:600}
.biz-action-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.biz-action-row .btn{flex:1;padding:11px 8px;min-width:72px;font-size:.82rem}

/* ─── GALLERY ─── */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:0 16px}
.gallery-grid img{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-xs);width:100%;cursor:pointer;transition:var(--transition)}
.gallery-grid img:hover{transform:scale(.97)}

/* ─── REVIEW CARD ─── */
.review-card{padding:14px 16px;border-bottom:1px solid var(--gray100)}
.review-card:last-child{border-bottom:none}
.review-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.review-author{font-weight:600;font-size:.85rem}
.review-text{font-size:.82rem;color:var(--gray700);line-height:1.5}

/* ─── PRICING ─── */
.price-card{padding:20px;border-radius:var(--radius);border:2px solid var(--gray200);position:relative;margin-bottom:14px}
.price-card.featured{border-color:var(--primary);background:var(--primary);color:#fff}
.price-card.featured *{color:#fff!important}
.price-card .popular-tag{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:2px 12px;border-radius:10px;font-size:.7rem;font-weight:700;white-space:nowrap}
.price-card h3{font-family:var(--font-display);font-size:1.1rem;font-weight:800;margin-bottom:4px}
.price-card .price{font-size:1.8rem;font-weight:800;font-family:var(--font-display);margin-bottom:2px}
.price-card .price span{font-size:.85rem;font-weight:400;color:var(--gray500)}
.price-card ul{list-style:none;margin:12px 0;display:flex;flex-direction:column;gap:8px}
.price-card ul li{font-size:.8rem;display:flex;align-items:center;gap:6px}
.price-card ul li::before{content:'✓';font-weight:700;color:var(--green);flex-shrink:0}
.price-card.featured ul li::before{color:#86EFAC}

/* ─── FAQ ─── */
.faq-item{border-bottom:1px solid var(--gray100)}
.faq-q{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:600;font-size:.9rem}
.faq-q .chevron{transition:var(--transition);stroke:var(--gray500)}
.faq-item.open .faq-q .chevron{transform:rotate(180deg)}
.faq-a{padding:0 16px 14px;font-size:.82rem;color:var(--gray700);line-height:1.6;display:none}
.faq-item.open .faq-a{display:block}

/* ─── SETTINGS ─── */
.settings-item{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--gray100)}
.settings-item:hover{background:var(--gray50)}
.settings-item:last-child{border-bottom:none}
.settings-icon{width:38px;height:38px;border-radius:var(--radius-xs);background:var(--gray100);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.settings-label{flex:1;font-weight:500;font-size:.9rem}
.settings-chevron{stroke:var(--gray400)}

/* ─── DASHBOARD ─── */
.dash-stat{flex:1;background:var(--gray50);border-radius:var(--radius-sm);padding:14px;text-align:center;border:1px solid var(--gray100)}
.dash-stat .stat-num{font-family:var(--font-display);font-size:1.5rem;font-weight:800}
.dash-stat .stat-label{font-size:.72rem;color:var(--gray500);margin-top:2px}

/* ─── ADMIN ─── */
.admin-biz-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--gray100)}
.admin-biz-row .biz-logo-sm{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--gray200);flex-shrink:0}
.admin-biz-row .info{flex:1;min-width:0}
.admin-biz-row .name{font-weight:600;font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-biz-row .sub{font-size:.75rem;color:var(--gray500)}
.admin-actions{display:flex;gap:6px;flex-shrink:0}
.admin-actions .btn{padding:6px 10px;font-size:.75rem;width:auto}

/* ─── EMPTY STATE ─── */
.empty-state{display:flex;flex-direction:column;align-items:center;padding:48px 24px;text-align:center;gap:12px}
.empty-state .empty-icon{font-size:3rem;opacity:.4}
.empty-state h3{font-family:var(--font-display);font-weight:700;font-size:1rem}
.empty-state p{font-size:.82rem;color:var(--gray500);line-height:1.5}

/* ─── AUTH ─── */
.auth-page{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:24px 20px;background:var(--bg)}
.auth-logo{font-family:var(--font-display);font-size:2rem;font-weight:800;text-align:center;margin-bottom:4px}
.auth-logo span{color:var(--accent)}
.auth-tagline{text-align:center;font-size:.85rem;color:var(--gray500);margin-bottom:32px}
.auth-card{background:var(--bg);border-radius:var(--radius);border:1px solid var(--gray100);box-shadow:var(--shadow);padding:24px}
.auth-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:4px}
.auth-subtitle{font-size:.8rem;color:var(--gray500);margin-bottom:20px}
.btn-google{background:#fff;color:#374151;border:1.5px solid var(--gray200);box-shadow:var(--shadow-sm)}
.btn-google:hover{background:var(--gray50)}
.btn-google img{width:18px;height:18px}

/* ─── VERIFY BANNER ─── */
.verify-banner{background:#FFF3CD;border:1px solid #FFC107;border-radius:var(--radius-sm);padding:12px 14px;display:flex;align-items:center;gap:10px;margin:0 16px 12px;font-size:.8rem}
.verify-banner .v-icon{font-size:1.1rem;flex-shrink:0}
.verify-banner .v-text{flex:1;line-height:1.4}
.verify-banner .btn-verify{background:var(--primary);color:#fff;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;border:none;cursor:pointer;flex-shrink:0;white-space:nowrap}

/* ─── CHAT ─── */
.chat-bubble{padding:10px 14px;border-radius:16px;max-width:80%;font-size:.85rem;line-height:1.5;word-wrap:break-word}
.chat-bubble.user{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-bubble.admin{background:var(--gray100);color:var(--primary);align-self:flex-start;border-bottom-left-radius:4px}
.chat-bubble.system{background:transparent;color:var(--gray400);align-self:center;font-size:.75rem;text-align:center}
.chat-msg-wrap{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.chat-msg-wrap .msg-meta{font-size:.68rem;color:var(--gray400);padding:0 4px}
.chat-msg-wrap.user-wrap .msg-meta{text-align:right}
#chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}
.chat-online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);display:inline-block;margin-right:4px}
#chat-input-bar{padding:12px 16px;border-top:1px solid var(--gray100);display:flex;gap:10px;align-items:flex-end;background:var(--bg)}
#chat-input-bar textarea{flex:1;border:1.5px solid var(--gray200);border-radius:12px;padding:10px 12px;font-family:var(--font-body);font-size:.88rem;resize:none;outline:none;max-height:100px;overflow-y:auto;transition:var(--transition)}
#chat-input-bar textarea:focus{border-color:var(--primary)}
#chat-input-bar button{width:40px;height:40px;border-radius:50%;background:var(--primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#chat-input-bar button svg{stroke:#fff}
.admin-chat-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--gray100);cursor:pointer;transition:var(--transition)}
.admin-chat-row:hover{background:var(--gray50)}
.admin-chat-row .unread-badge{background:var(--red);color:#fff;border-radius:10px;padding:2px 7px;font-size:.7rem;font-weight:700;flex-shrink:0}

/* ─── PWA INSTALL ─── */
#install-prompt{position:fixed;bottom:calc(var(--nav-h)+16px+env(safe-area-inset-bottom));left:16px;right:16px;z-index:500;background:var(--primary);color:#fff;border-radius:var(--radius);padding:14px 16px;display:none;align-items:center;gap:12px;box-shadow:var(--shadow-lg)}
#install-prompt.show{display:flex;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
#install-prompt .install-text{flex:1;font-size:.82rem;line-height:1.4}
#install-prompt .install-text strong{display:block;font-size:.9rem;margin-bottom:2px}

/* ─── OFFLINE ─── */
#offline-banner{position:fixed;top:0;left:0;right:0;z-index:9998;background:#DC2626;color:#fff;text-align:center;padding:8px 16px;font-size:.8rem;font-weight:600;display:none}

/* ─── UPDATES SLIDER ─── */
.update-slide{min-width:100%;position:relative;cursor:pointer;display:block;text-decoration:none}
.update-slide img{width:100%;height:200px;object-fit:cover;display:block}
.update-slide-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.75));padding:20px 16px 12px;color:#fff}
.update-slide-cap h3{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:3px}
.update-slide-cap p{font-size:.75rem;opacity:.85}
.slider-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.35);transition:.3s;cursor:pointer}
.slider-dot.active{background:#fff;width:18px;border-radius:3px}

/* ─── LOADING OVERLAY ─── */
#page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;transition:opacity .4s ease}
#page-loader.hide{opacity:0;pointer-events:none}
#page-loader .logo-loader{font-family:var(--font-display);font-size:2rem;font-weight:800}
#page-loader .logo-loader span{color:var(--accent)}
#page-loader .loader-bar{width:160px;height:3px;background:var(--gray100);border-radius:3px;overflow:hidden}
#page-loader .loader-bar-inner{height:100%;background:var(--primary);animation:loaderBar 1.2s ease-in-out infinite}
@keyframes loaderBar{0%{width:0%;margin-left:0}50%{width:80%;margin-left:10%}100%{width:0%;margin-left:100%}}

/* ─── MISC ─── */
.text-center{text-align:center}.text-sm{font-size:.8rem}.text-muted{color:var(--gray500)}
.mb-0{margin-bottom:0!important}.mt-4{margin-top:4px}.gap-8{gap:8px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.hidden{display:none!important}
hr.sep{border:none;border-top:1px solid var(--gray100);margin:0}
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray200);border-radius:4px}

/* ─── RESPONSIVE ─── */
@media(max-width:360px){
  .home-hero h1{font-size:1.45rem}
  .biz-action-row .btn{font-size:.78rem;padding:8px 6px}
}
@media(min-width:480px){
  .auth-page{max-width:440px;margin:0 auto}
  .modal-sheet{border-radius:var(--radius) var(--radius) 0 0}
  .home-hero h1{font-size:2rem}
  .gallery-grid{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:768px){
  :root{--nav-h:68px;--header-h:60px}
  .page{max-width:480px;margin:0 auto;border-left:1px solid var(--gray100);border-right:1px solid var(--gray100)}
  .bottom-nav{max-width:480px;left:50%;transform:translateX(-50%);border-left:1px solid var(--gray200);border-right:1px solid var(--gray200);border-radius:var(--radius) var(--radius) 0 0}
}
