@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* Light theme */
:root {
  --brand:    #1d4ed8;
  --brand-d:  #1e3a8a;
  --brand-lt: #dbeafe;
  --success:  #10b981;
  --danger:   #ef4444;
  --warn:     #f59e0b;
  --bg:       #f1f5f9;
  --surface:  #ffffff;
  --surface2: #f8fafc;
  --border:   #e2e8f0;
  --border2:  #cbd5e1;
  --text:     #0f172a;
  --text2:    #475569;
  --text3:    #94a3b8;
  --nav-bg:   #ffffff;
  --card-bg:  #ffffff;
  --card-bd:  #e2e8f0;
  --card-sh:  0 1px 4px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);
  --sb-bg:    #1e293b;
  --sb-text:  #94a3b8;
  --sb-hover: #334155;
  --sb-accent:#3b82f6;
  --in-bg:    #ffffff;
  --in-bd:    #cbd5e1;
  --in-focus: #3b82f6;
  --r:   10px;
  --rlg: 14px;
  --rxl: 20px;
  --tr:  all 0.18s ease;
  --sh:  0 4px 16px rgba(0,0,0,.10);
  --shlg:0 8px 32px rgba(0,0,0,.14);
}

/* Dark theme */
[data-theme="dark"] {
  --brand:    #60a5fa;
  --brand-d:  #93c5fd;
  --brand-lt: #1e3a5f;
  --bg:       #0f172a;
  --surface:  #1e293b;
  --surface2: #162032;
  --border:   #334155;
  --border2:  #475569;
  --text:     #f1f5f9;
  --text2:    #94a3b8;
  --text3:    #64748b;
  --nav-bg:   #1e293b;
  --card-bg:  #1e293b;
  --card-bd:  #334155;
  --card-sh:  0 2px 8px rgba(0,0,0,.3);
  --sb-bg:    #0f172a;
  --in-bg:    #162032;
  --in-bd:    #334155;
  --in-focus: #60a5fa;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:15px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* LAYOUT */
.container{max-width:1200px;margin:0 auto;padding:0 1rem}

/* NAVBAR */
.navbar{background:var(--nav-bg);border-bottom:1px solid var(--card-bd);position:sticky;top:0;z-index:200;height:56px}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 1rem;height:56px;display:flex;align-items:center;gap:1rem}
.logo{font-size:1.1rem;font-weight:800;color:var(--brand-d);flex-shrink:0;display:flex;align-items:center;gap:.35rem}
.logo:hover{text-decoration:none;color:var(--brand)}
.nav-links{margin-left:auto;display:flex;align-items:center;gap:.5rem}
.nav-links a{color:var(--text2);font-size:.82rem;font-weight:500;padding:.3rem .55rem;border-radius:6px;transition:var(--tr);white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--brand);background:var(--brand-lt);text-decoration:none}
.nav-user{font-size:.78rem;color:var(--text3);padding:.25rem .65rem;background:var(--surface2);border-radius:20px;border:1px solid var(--border)}
.nav-toggle{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:.4rem;margin-left:.25rem;flex-shrink:0}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--text2);border-radius:2px;transition:var(--tr)}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.theme-toggle{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:var(--tr);flex-shrink:0;color:var(--text2)}
.theme-toggle:hover{background:var(--brand-lt);border-color:var(--brand)}

/* BUTTONS */
.btn-primary,.btn-outline,.btn-danger,.btn-success,.btn-ghost,.btn-search,.btn-reveal{
  display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  padding:.5rem 1.1rem;border-radius:var(--r);font-family:inherit;
  font-size:.85rem;font-weight:600;cursor:pointer;border:none;
  transition:var(--tr);white-space:nowrap;text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-d);color:#fff;text-decoration:none}
.btn-primary:active{transform:scale(.97)}
.btn-outline{background:transparent;color:var(--brand);border:1.5px solid var(--brand)}
.btn-outline:hover{background:var(--brand-lt);text-decoration:none}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#b91c1c;color:#fff}
.btn-success{background:var(--success);color:#fff}
.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--border);color:var(--text)}
.btn-search{background:var(--brand);color:#fff;padding:.62rem 1.3rem;font-size:.9rem}
.btn-reveal{background:var(--brand-lt);color:var(--brand-d);border:1.5px solid var(--brand);width:100%}
.btn-sm{padding:.28rem .65rem;font-size:.78rem;border-radius:6px}
.btn-lg{padding:.7rem 1.8rem;font-size:.95rem}
.btn-block{width:100%}

/* FORMS */
.form-row{display:flex;flex-direction:column;gap:.28rem;margin-bottom:.85rem}
.form-row label{font-size:.75rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.04em}
.form-row input,.form-row select,.form-row textarea{
  padding:.58rem .85rem;border:1.5px solid var(--in-bd);border-radius:var(--r);
  font-family:inherit;font-size:.9rem;color:var(--text);background:var(--in-bg);
  transition:var(--tr);width:100%;
  /* prevent iOS zoom on focus */
  font-size:16px;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none;border-color:var(--in-focus);box-shadow:0 0 0 3px rgba(59,130,246,.14)
}
.form-row textarea{resize:vertical;min-height:78px;font-size:.9rem}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.form-row-inline{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;margin-bottom:.85rem}
.form-actions{display:flex;gap:.65rem;margin-top:.9rem;flex-wrap:wrap}
.inline-input{padding:.32rem .7rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;background:var(--in-bg);color:var(--text)}
.inline-form{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end;margin-bottom:1rem}
.inline-form input,.inline-form select{flex:1;min-width:120px;padding:.52rem .82rem;border:1.5px solid var(--in-bd);border-radius:var(--r);font-family:inherit;font-size:.875rem;color:var(--text);background:var(--in-bg)}
.inline-form input:focus,.inline-form select:focus{outline:none;border-color:var(--in-focus)}

/* CARDS */
.card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);box-shadow:var(--card-sh);padding:1.25rem;margin-bottom:1.1rem}
.card h3,.card h4{margin-bottom:.85rem;font-size:.98rem;color:var(--text)}

/* ALERTS */
.alert{padding:.7rem .95rem;border-radius:var(--r);font-size:.85rem;margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem}
.alert-error{background:#fee2e2;color:#991b1b;border-left:3px solid var(--danger)}
.alert-success{background:#d1fae5;color:#065f46;border-left:3px solid var(--success)}
[data-theme="dark"] .alert-error{background:#450a0a;color:#fca5a5}
[data-theme="dark"] .alert-success{background:#052e16;color:#86efac}

/* BADGES */
.tag-cat{background:var(--brand-lt);color:var(--brand)}
.tag-city{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.tag-verified{background:#d1fae5;color:#065f46}
.tag-plan{background:#fef3c7;color:#92400e}
.tag-cat,.tag-city,.tag-verified,.tag-plan{display:inline-block;padding:.18rem .65rem;border-radius:20px;font-size:.73rem;font-weight:600}
[data-theme="dark"] .tag-verified{background:#052e16;color:#86efac}
[data-theme="dark"] .tag-plan{background:#451a03;color:#fcd34d}
.badge-verified{display:inline-block;font-size:.7rem;background:#d1fae5;color:#065f46;padding:.12rem .48rem;border-radius:20px;font-weight:600;margin-top:.2rem}
[data-theme="dark"] .badge-verified{background:#052e16;color:#86efac}
.status-badge{display:inline-block;padding:.18rem .58rem;border-radius:20px;font-size:.7rem;font-weight:700}
.role-badge{padding:.14rem .48rem;border-radius:20px;font-size:.7rem;font-weight:700}
.role-sa{background:#fde68a;color:#92400e}
.role-shop{background:var(--brand-lt);color:var(--brand-d)}
.role-buyer{background:#d1fae5;color:#065f46}
.role-public{background:var(--surface2);color:var(--text3)}
.plan-free{background:var(--surface2);color:var(--text3);border:1px solid var(--border)}
.plan-basic{background:#dbeafe;color:#1e3a8a}
.plan-pro{background:#fef9c3;color:#92400e}
[data-theme="dark"] .plan-basic{background:#1e3a5f;color:#93c5fd}

/* HERO */
.hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 52%,#1d4ed8 100%);padding:2.5rem 1rem 2.5rem;text-align:center;position:relative;overflow:hidden}
.hero-inner{max-width:820px;margin:0 auto;position:relative;z-index:1}
.hero h1{color:#fff;font-size:clamp(1.4rem,5vw,2.4rem);font-weight:800;line-height:1.2;margin-bottom:.65rem}
.hero-sub{color:rgba(255,255,255,.74);margin-bottom:1.5rem;font-size:.95rem}
.search-bar{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center;max-width:800px;margin:0 auto}
.search-input{flex:1 1 200px;min-width:0;padding:.65rem .9rem;border-radius:var(--r);border:none;font-family:inherit;font-size:16px;background:#fff;color:#0f172a}
.search-input:focus{outline:2px solid rgba(255,255,255,.65)}
.search-select{padding:.65rem .78rem;border-radius:var(--r);border:none;font-family:inherit;font-size:.85rem;min-width:130px;background:#fff;color:#0f172a;cursor:pointer}

/* TICKER */
.ticker-wrap{background:#1e293b;color:#fff;padding:.45rem 0;overflow:hidden;display:flex;align-items:center}
[data-theme="dark"] .ticker-wrap{background:#0a0f1e}
.ticker-label{flex-shrink:0;background:#ef4444;padding:.28rem .85rem;font-size:.72rem;font-weight:700;margin-right:.85rem;letter-spacing:.05em}
.ticker{overflow:hidden;flex:1}
.ticker-inner{display:flex;animation:tickerScroll 35s linear infinite;white-space:nowrap}
.ticker-inner:hover{animation-play-state:paused}
.ticker-item{display:inline-block;padding:0 1.75rem;font-size:.82rem}
.ticker-item a{color:#93c5fd}
.ticker-item small{color:rgba(255,255,255,.48);margin-left:.35rem}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
.section{padding:2rem 0}
.section-alt{background:var(--surface)}
.section-title{font-size:1.2rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;color:var(--text)}
.section-title::after{content:'';flex:1;height:1px;background:var(--border);margin-left:.5rem}

/* CATEGORY GRID */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.65rem}
.cat-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);padding:.9rem .6rem;text-align:center;transition:var(--tr);cursor:pointer;display:block;-webkit-tap-highlight-color:transparent}
.cat-card:hover,.cat-card:active{border-color:var(--brand);transform:translateY(-2px);text-decoration:none}
.cat-icon{font-size:1.6rem;margin-bottom:.28rem;line-height:1}
.cat-name{font-size:.72rem;font-weight:600;color:var(--text2)}

/* CITY CHIPS */
.city-grid{display:flex;flex-wrap:wrap;gap:.45rem}
.city-chip{background:var(--card-bg);color:var(--text2);border:1px solid var(--border);border-radius:20px;padding:.35rem .9rem;font-size:.8rem;font-weight:600;transition:var(--tr);display:inline-block;-webkit-tap-highlight-color:transparent}
.city-chip:hover,.city-chip:active{background:var(--brand);color:#fff;border-color:var(--brand);text-decoration:none}
.city-chip-active{background:var(--brand)!important;color:#fff!important;border-color:var(--brand)!important}

/* SHOP CARDS */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.85rem}
.shop-grid.lg{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.shop-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);overflow:hidden;transition:var(--tr);display:block;box-shadow:var(--card-sh);-webkit-tap-highlight-color:transparent}
.shop-card:hover,.shop-card:active{box-shadow:var(--shlg);transform:translateY(-2px);text-decoration:none}
.shop-cover{height:110px;background-color:var(--brand-d);background-size:cover;background-position:center}
.shop-cover-placeholder{height:110px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:1.9rem;font-weight:800;color:rgba(255,255,255,.45)}
.shop-info{padding:.65rem}
.shop-name{font-weight:700;font-size:.85rem;color:var(--text);margin-bottom:.18rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.shop-meta{font-size:.74rem;color:var(--text3)}

/* PRODUCT GRID */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:.8rem}
.product-grid.lg{grid-template-columns:repeat(auto-fill,minmax(165px,1fr))}
.product-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);overflow:hidden;box-shadow:var(--card-sh);transition:var(--tr)}
.product-card:hover{box-shadow:var(--sh);transform:translateY(-2px)}
.product-img{width:100%;height:130px;object-fit:cover}
.product-img-placeholder{height:130px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.8rem}
.product-body{padding:.65rem}
.product-name{font-weight:600;font-size:.84rem;margin-bottom:.12rem;color:var(--text)}
.product-desc{font-size:.74rem;color:var(--text3);margin-bottom:.28rem}
.product-shop{font-size:.76rem;color:var(--brand);margin-bottom:.12rem}
.product-loc{font-size:.74rem;color:var(--text3);margin-bottom:.28rem}
.price-main{font-size:.92rem;font-weight:700;color:var(--text)}
.price-sale{font-size:.92rem;font-weight:700;color:var(--success)}
.price-orig{font-size:.76rem;color:var(--text3);text-decoration:line-through;margin-left:.32rem}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.45rem}
.gallery-thumb{display:block;border-radius:var(--r);overflow:hidden}
.gallery-thumb img{width:100%;height:80px;object-fit:cover;transition:var(--tr)}
.gallery-thumb:hover img{opacity:.8}
.gallery-thumb-wrap{position:relative;border-radius:var(--r);overflow:hidden}
.gallery-thumb-wrap img{width:100%;height:80px;object-fit:cover}
.gallery-delete{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.62);color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center}

/* SALE BANNER STRIP */
.sale-banner-strip{background:#fffbeb;border-left:4px solid var(--warn);padding:.6rem 1.1rem;font-size:.84rem;color:var(--text)}
[data-theme="dark"] .sale-banner-strip{background:#1c1400;border-left-color:#d97706}
.sale-banner-strip a{color:var(--brand-d);font-weight:600}
.sale-banner-strip .banner-dates{margin-left:.8rem;font-size:.76rem;color:var(--text3)}
.sale-banner-strip.compact{margin:.35rem 0;border-radius:6px}

/* CTA */
.section-cta{background:linear-gradient(135deg,#0f172a,#1d4ed8);text-align:center;padding:3rem 1rem}
.cta-inner h2{color:#fff;font-size:clamp(1.3rem,3vw,1.75rem);margin-bottom:.65rem}
.cta-inner p{color:rgba(255,255,255,.74);margin-bottom:1.35rem}

/* FOOTER */
.footer{background:var(--surface);border-top:1px solid var(--border);padding:1.25rem 0;margin-top:2.5rem;text-align:center;font-size:.8rem;color:var(--text3)}
.footer a{color:var(--text3)}
.footer a:hover{color:var(--brand)}

/* SEARCH PAGE */
.search-header{background:#1e293b;padding:.85rem 0}
[data-theme="dark"] .search-header{background:#0a0f1e}
.search-body{padding:1.25rem 0}
.type-tabs{display:flex;gap:.38rem;margin-bottom:1rem;flex-wrap:wrap}
.tab-btn{padding:.38rem .9rem;border-radius:20px;border:1.5px solid var(--border);font-size:.8rem;font-weight:600;color:var(--text2);cursor:pointer;background:var(--card-bg);transition:var(--tr);-webkit-tap-highlight-color:transparent}
.tab-btn:hover{border-color:var(--brand);color:var(--brand)}
.tab-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.result-summary{font-size:.8rem;color:var(--text3);margin-bottom:.85rem}
.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text3);font-size:.9rem}
.pagination{display:flex;flex-wrap:wrap;gap:.32rem;margin-top:1.75rem}
.page-btn{padding:.32rem .68rem;border-radius:6px;border:1px solid var(--border);font-size:.8rem;color:var(--text2);background:var(--card-bg);cursor:pointer;transition:var(--tr);min-width:36px;text-align:center}
.page-btn:hover{border-color:var(--brand);color:var(--brand)}
.page-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* SHOP PAGE */
.shop-page{padding:1.25rem 0 2.5rem}
.sp-cover{border-radius:var(--rlg);overflow:hidden;margin-bottom:1.25rem}
.sp-cover img{width:100%;max-height:260px;object-fit:cover}
.sp-cover-placeholder{height:180px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800;color:rgba(255,255,255,.3);border-radius:var(--rlg)}
.sp-layout{display:grid;grid-template-columns:1fr 280px;gap:1.5rem;align-items:start}
.sp-header{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:1.1rem}
.sp-logo{width:60px;height:60px;border-radius:var(--rlg);object-fit:cover;border:2px solid var(--border);flex-shrink:0}
.sp-logo-placeholder{width:60px;height:60px;border-radius:var(--rlg);background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;color:#fff;flex-shrink:0}
.sp-name{font-size:clamp(1.1rem,3vw,1.45rem);font-weight:800;color:var(--text)}
.sp-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.35rem}
.sp-desc{color:var(--text2);line-height:1.7;margin-bottom:1.25rem;font-size:.9rem}
.sp-section{margin-bottom:1.6rem}
.sp-section h3{font-size:.95rem;font-weight:700;margin-bottom:.8rem;color:var(--text);border-bottom:1px solid var(--border);padding-bottom:.45rem}
.sp-sidebar{display:flex;flex-direction:column;gap:.85rem;position:sticky;top:72px}
.sidebar-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);padding:1rem;box-shadow:var(--card-sh)}
.sidebar-card h4{font-size:.78rem;font-weight:700;margin-bottom:.7rem;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}
.contact-row{font-size:.83rem;color:var(--text2);padding:.38rem 0;border-bottom:1px solid var(--border);display:flex;gap:.45rem;align-items:flex-start}
.contact-row:last-child{border:none}
.contact-row a{color:var(--brand)}
.phone-revealed{background:#d1fae5;color:#065f46;padding:.7rem .9rem;border-radius:var(--r);font-size:.9rem;font-weight:700;margin-top:.45rem}
[data-theme="dark"] .phone-revealed{background:#052e16;color:#86efac}
.phone-hint{font-size:.82rem;color:var(--text3)}
.map-frame{border-radius:var(--r);overflow:hidden;margin:.35rem 0}
.directions-link{font-size:.8rem;color:var(--brand);font-weight:600;display:inline-block;margin-top:.28rem}
.promo-card{background:var(--brand-lt);border-color:var(--brand-lt)}
.promo-card p{font-size:.83rem;color:var(--text2);margin-bottom:.6rem}

/* BOTTOM NAV - mobile only */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--nav-bg);border-top:1px solid var(--border);padding:.4rem 0 calc(.4rem + env(safe-area-inset-bottom));z-index:150}
.bottom-nav-inner{display:flex;justify-content:space-around;align-items:center}
.bn-item{display:flex;flex-direction:column;align-items:center;gap:.18rem;padding:.3rem .5rem;color:var(--text3);font-size:.62rem;font-weight:600;text-decoration:none;cursor:pointer;background:none;border:none;font-family:inherit;min-width:54px;-webkit-tap-highlight-color:transparent;transition:var(--tr)}
.bn-item:hover,.bn-item.active{color:var(--brand);text-decoration:none}
.bn-icon{font-size:1.3rem;line-height:1}

/* PAGE PADDING for bottom nav */
.has-bottom-nav{padding-bottom:70px}

/* DASHBOARD */
.dash-wrap{display:grid;grid-template-columns:250px 1fr;min-height:calc(100vh - 56px)}
.dash-sidebar{background:var(--sb-bg);border-right:1px solid rgba(255,255,255,.055);display:flex;flex-direction:column;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}
.dash-brand{padding:1rem 1.1rem .65rem;border-bottom:1px solid rgba(255,255,255,.055);font-size:.75rem;font-weight:700;color:rgba(255,255,255,.35);letter-spacing:.07em;text-transform:uppercase}
.dash-user{padding:.85rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.055);display:flex;align-items:center;gap:.65rem}
.dash-avatar{width:36px;height:36px;border-radius:50%;background:var(--sb-accent);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}
.dash-uname{font-size:.83rem;font-weight:600;color:#e2e8f0}
.dash-urole{font-size:.68rem;color:var(--sb-text)}
.dash-nav{flex:1;padding:.6rem 0}
.dash-nav-label{padding:.35rem 1.1rem;font-size:.65rem;font-weight:700;color:var(--sb-text);text-transform:uppercase;letter-spacing:.07em}
.dash-link{display:flex;align-items:center;gap:.55rem;padding:.5rem 1.1rem;font-size:.83rem;font-weight:500;color:var(--sb-text);transition:var(--tr);border-left:3px solid transparent;text-decoration:none}
.dash-link:hover{background:var(--sb-hover);color:#e2e8f0;text-decoration:none}
.dash-link.active{background:var(--sb-hover);color:#ffffff;border-left-color:var(--sb-accent)}
.dash-link-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0}
.dash-sidebar-footer{padding:.85rem 1.1rem;border-top:1px solid rgba(255,255,255,.055)}
.dash-main{background:var(--bg);padding:1.5rem;overflow-x:hidden;min-width:0}
.dash-main h2{font-size:1.15rem;font-weight:700;margin-bottom:.85rem;color:var(--text)}
.dash-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:.85rem;flex-wrap:wrap}
.dash-topbar h2{margin-bottom:0}
.dash-sidebar-toggle{display:none;position:fixed;bottom:1.25rem;right:1.25rem;width:46px;height:46px;border-radius:50%;background:var(--brand);color:#fff;border:none;font-size:1.2rem;cursor:pointer;z-index:300;box-shadow:var(--shlg);align-items:center;justify-content:center}
.dash-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:250}

/* TABS */
.tabs{display:flex;gap:.32rem;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:1.1rem}
.tab{padding:.45rem .9rem;border-radius:6px 6px 0 0;border:1px solid transparent;border-bottom:none;font-size:.8rem;font-weight:600;cursor:pointer;background:transparent;color:var(--text2);transition:var(--tr);position:relative;bottom:-1px;-webkit-tap-highlight-color:transparent}
.tab:hover{color:var(--brand);background:var(--surface2)}
.tab.active{background:var(--card-bg);color:var(--brand);border-color:var(--border);border-bottom-color:var(--card-bg)}
.tab-pane{display:none}
.tab-pane.active{display:block}

/* SHOPS LIST */
.shops-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}
.shop-row{background:var(--card-bg);border:1.5px solid var(--card-bd);border-radius:var(--rlg);padding:.8rem 1rem;cursor:pointer;display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;transition:var(--tr);box-shadow:var(--card-sh)}
.shop-row:hover,.shop-row.active-shop{border-color:var(--brand);box-shadow:0 0 0 3px rgba(59,130,246,.11)}
.shop-row-name{font-weight:700;font-size:.87rem;color:var(--text)}
.shop-row-meta{font-size:.75rem;color:var(--text3)}
.product-table{display:flex;flex-direction:column;gap:.45rem;margin-top:.65rem}
.product-row{display:flex;align-items:center;gap:.65rem;padding:.55rem .8rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);flex-wrap:wrap}
.prod-thumb{width:38px;height:38px;object-fit:cover;border-radius:6px;flex-shrink:0}
.prod-name{flex:1;font-weight:600;font-size:.84rem;min-width:80px;color:var(--text)}
.prod-price{font-size:.78rem;color:var(--text2)}
.prod-status{font-size:.7rem;background:#d1fae5;color:#065f46;padding:.12rem .45rem;border-radius:20px;font-weight:600}
[data-theme="dark"] .prod-status{background:#052e16;color:#86efac}
.upgrade-notice{background:#fffbeb;padding:.68rem .92rem;border-radius:var(--r);font-size:.83rem;margin-bottom:.65rem;border-left:3px solid var(--warn);color:var(--text2)}
[data-theme="dark"] .upgrade-notice{background:#1c1400}
.banner-row{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem;padding:.72rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:.45rem}
.admin-note{font-size:.76rem;color:var(--danger);width:100%}

/* ADMIN */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.8rem;margin-bottom:1.5rem}
.stat-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);padding:.95rem;text-align:center;box-shadow:var(--card-sh)}
.stat-val{font-size:1.85rem;font-weight:800;color:var(--brand);line-height:1}
.stat-label{font-size:.7rem;color:var(--text3);margin-top:.25rem;font-weight:500}
.admin-row{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rlg);padding:.9rem 1rem;margin-bottom:.65rem;display:flex;gap:.85rem;align-items:flex-start;justify-content:space-between;box-shadow:var(--card-sh);flex-wrap:wrap}
.admin-row-info{display:flex;flex-direction:column;gap:.18rem;font-size:.83rem;flex:1;min-width:0}
.admin-row-info strong{font-size:.9rem;color:var(--text)}
.admin-row-info span{color:var(--text2)}
.admin-row-actions{display:flex;gap:.45rem;flex-shrink:0;align-items:center;flex-wrap:wrap}
.admin-table{width:100%;border-collapse:collapse;font-size:.78rem;background:var(--card-bg);border-radius:var(--rlg);overflow:hidden;box-shadow:var(--card-sh)}
.admin-table th,.admin-table td{padding:.5rem .78rem;border-bottom:1px solid var(--border);text-align:left;color:var(--text)}
.admin-table th{background:var(--surface2);font-weight:600;color:var(--text2);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--surface2)}
.master-list{display:flex;flex-wrap:wrap;gap:.38rem;margin-top:.65rem}
.chip{background:var(--brand-lt);color:var(--brand);padding:.18rem .62rem;border-radius:20px;font-size:.75rem;font-weight:600}

/* AUTH */
.auth-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.25rem}
.auth-card{background:var(--card-bg);border:1px solid var(--card-bd);border-radius:var(--rxl);padding:2.1rem;width:100%;max-width:410px;box-shadow:var(--shlg)}
.auth-card h2{margin-bottom:1.25rem;font-size:1.25rem;color:var(--text)}
.auth-logo{display:block;text-align:center;margin-bottom:1.25rem}
.auth-logo .logo{justify-content:center;font-size:1.25rem}
.auth-footer{text-align:center;font-size:.82rem;color:var(--text3);margin-top:1.1rem}
.role-tabs{display:flex;gap:.42rem;margin-bottom:1.15rem}
.role-tab{flex:1;padding:.55rem;border-radius:var(--r);border:1.5px solid var(--border);background:transparent;font-family:inherit;font-size:.83rem;font-weight:600;cursor:pointer;color:var(--text2);transition:var(--tr);-webkit-tap-highlight-color:transparent}
.role-tab.active{border-color:var(--brand);background:var(--brand-lt);color:var(--brand)}

/* PLANS */
.plans-wrap{max-width:960px;margin:1.5rem auto;padding:0 1rem}
.plans-wrap h2{font-size:1.45rem;margin-bottom:.45rem}
.plans-sub{color:var(--text2);margin-bottom:1.6rem}
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.1rem;margin-bottom:1.6rem}
.plan-card{background:var(--card-bg);border:1.5px solid var(--card-bd);border-radius:var(--rxl);padding:1.5rem 1.3rem;position:relative;box-shadow:var(--card-sh);transition:var(--tr)}
.plan-card:hover{box-shadow:var(--shlg);transform:translateY(-2px)}
.plan-card.featured{border-color:var(--brand);box-shadow:0 0 0 3px rgba(59,130,246,.14)}
.plan-top-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-size:.68rem;font-weight:800;padding:.18rem .72rem;border-radius:20px;letter-spacing:.05em;white-space:nowrap}
.plan-name{font-size:.82rem;font-weight:700;color:var(--text2);margin-bottom:.42rem;text-transform:uppercase;letter-spacing:.06em}
.plan-price{font-size:2rem;font-weight:800;margin-bottom:.85rem;color:var(--text)}
.plan-price small{font-size:.8rem;font-weight:500;color:var(--text3)}
.plan-features{list-style:none;font-size:.82rem;color:var(--text2);margin-bottom:1.3rem;display:flex;flex-direction:column;gap:.4rem}
.plan-features li{display:flex;align-items:center;gap:.35rem}
.plan-current{display:block;text-align:center;font-size:.78rem;color:var(--text3);font-weight:600}

/* TABLET max-900px */
@media(max-width:900px){
  .sp-layout{grid-template-columns:1fr}
  .sp-sidebar{position:static}
  .dash-wrap{grid-template-columns:1fr}
  .dash-sidebar{position:fixed;left:-260px;top:56px;width:250px;height:calc(100vh - 56px);z-index:260;transition:left .25s ease}
  .dash-sidebar.open{left:0}
  .dash-overlay.open{display:block}
  .dash-sidebar-toggle{display:flex}
  .dash-main{padding:1.1rem}
}

/* MOBILE max-640px */
@media(max-width:640px){
  body{font-size:14px}
  .container{padding:0 .85rem}

  /* Navbar - hide links, show hamburger */
  .nav-links{
    display:none;flex-direction:column;
    position:fixed;top:56px;left:0;right:0;bottom:0;
    background:var(--nav-bg);padding:1.25rem 1rem;
    gap:.5rem;z-index:190;overflow-y:auto;
    box-shadow:none;border-top:1px solid var(--border)
  }
  .nav-links.open{display:flex}
  .nav-links a{font-size:1rem;padding:.7rem .9rem;border-radius:var(--r);border:1px solid var(--border)}
  .nav-links a:hover{background:var(--brand-lt)}
  .nav-toggle{display:flex}

  /* Hide desktop nav links, show bottom nav */
  .bottom-nav{display:block}
  .has-bottom-nav{padding-bottom:calc(60px + env(safe-area-inset-bottom))}

  /* Hero */
  .hero{padding:1.75rem .85rem 2rem}
  .hero h1{font-size:1.5rem}
  .hero-sub{font-size:.88rem;margin-bottom:1.25rem}
  .search-bar{flex-direction:column;gap:.4rem}
  .search-input,.search-select,.btn-search{width:100%;min-width:0}

  /* Sections */
  .section{padding:1.5rem 0}
  .section-title{font-size:1.05rem}

  /* Grids */
  .cat-grid{grid-template-columns:repeat(4,1fr);gap:.4rem}
  .cat-icon{font-size:1.45rem}
  .cat-name{font-size:.65rem}
  .shop-grid,.shop-grid.lg{grid-template-columns:repeat(2,1fr);gap:.65rem}
  .product-grid,.product-grid.lg{grid-template-columns:repeat(2,1fr);gap:.65rem}
  .stats-grid{grid-template-columns:repeat(2,1fr)}

  /* Shop page */
  .sp-header{flex-direction:column;align-items:flex-start}
  .sp-cover{border-radius:var(--r)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}

  /* Forms */
  .form-row-2{grid-template-columns:1fr;gap:0}
  .form-row input,.form-row select,.form-row textarea{font-size:16px}
  .card{padding:.9rem}
  .auth-card{padding:1.5rem 1.1rem}

  /* Plan */
  .plan-grid{grid-template-columns:1fr}

  /* Tables scroll */
  .admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Tabs scroll */
  .tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:0}
  .tab{flex-shrink:0}

  /* Dashboard */
  .dash-main{padding:.85rem}
  .product-row{flex-wrap:wrap}
  .admin-row{flex-direction:column}
  .admin-row-actions{width:100%;justify-content:flex-start}

  /* Ticker */
  .ticker-label{display:none}

  /* Inline form */
  .inline-form{flex-direction:column}
  .inline-form input,.inline-form select{width:100%;min-width:0}
  .form-row-inline{flex-direction:column;align-items:stretch}

  /* Pagination - bigger touch targets */
  .page-btn{min-width:40px;min-height:40px;display:inline-flex;align-items:center;justify-content:center}

  /* Bottom nav safe area */
  .sp-sidebar{margin-bottom:1rem}
}

/* SMALL PHONES max-380px */
@media(max-width:380px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .hero h1{font-size:1.3rem}
  .shop-grid,.shop-grid.lg{grid-template-columns:1fr}
  .btn-sm{font-size:.72rem;padding:.25rem .55rem}
}

/* TOUCH IMPROVEMENTS */
@media(hover:none){
  .shop-card:hover,.cat-card:hover,.city-chip:hover{transform:none}
  .btn-primary:hover{transform:none;box-shadow:none}
}

/* SAFE AREA (notch phones) */
@supports(padding-bottom: env(safe-area-inset-bottom)){
  .bottom-nav{padding-bottom:calc(.4rem + env(safe-area-inset-bottom))}
  .navbar{padding-top:env(safe-area-inset-top)}
}