@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;min-height:100vh;background:var(--bg2);color:var(--text);transition:background 0.2s,color 0.2s;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

body{--bg:#ffffff;--bg2:#f6f7ed;--bg3:#eaeade;--border:rgba(0,0,0,0.09);--border2:rgba(0,0,0,0.16);--text:#1a1a1a;--text2:#6b6b6b;--text3:#aaa9a0;--blue:#185fa5;--blue-bg:#e8f1fb;--blue-text:#0c3d6e;--green:#2a6610;--green-bg:#e6f3dc;--green-text:#163808;--amber:#7a4500;--amber-bg:#fdf0d5;--amber-text:#5a3300;--red:#a83030;--red-bg:#fde8e8;--red-text:#6b1414;--teal:#0a5c46;--teal-bg:#ddf5ee;--teal-text:#063d2e;--nav-h:52px;--bottom-h:60px}
body.dark{--bg:#1c1c1a;--bg2:#131310;--bg3:#252520;--border:rgba(255,255,255,0.09);--border2:rgba(255,255,255,0.17);--text:#e0e0d8;--text2:#87877e;--text3:#4e4e48;--blue:#5ba3e0;--blue-bg:#0f2235;--blue-text:#a8d0f5;--green:#6ab54e;--green-bg:#0e1f0a;--green-text:#9dd47e;--amber:#d4943a;--amber-bg:#1f1500;--amber-text:#f0c070;--red:#d96060;--red-bg:#200a0a;--red-text:#f0a0a0;--teal:#3cbf9a;--teal-bg:#061a13;--teal-text:#7ddfc0}

/* ── AUTH ──────────────────────────────────────────────────────── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg2)}
.auth-card{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:2.25rem;width:100%;max-width:400px;box-shadow:0 2px 12px rgba(0,0,0,0.06)}
.auth-logo{font-size:22px;font-weight:600;letter-spacing:-0.03em;color:var(--text);margin-bottom:0.25rem}
.auth-sub{font-size:13px;color:var(--text2);margin-bottom:1.75rem}
.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem}
.auth-tab{flex:1;padding:8px;font-size:13px;cursor:pointer;text-align:center;border-bottom:2px solid transparent;color:var(--text2);transition:color 0.15s}
.auth-tab.active{color:var(--text);border-bottom-color:var(--text);font-weight:500}
.auth-error{background:var(--red-bg);color:var(--red-text);font-size:12px;padding:8px 12px;border-radius:8px;margin-bottom:1rem;display:none;border:1px solid var(--red)}
.auth-success{background:var(--green-bg);color:var(--green-text);font-size:12px;padding:8px 12px;border-radius:8px;margin-bottom:1rem;display:none;border:1px solid var(--green)}

/* ── NAV ───────────────────────────────────────────────────────── */
.nav{background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;height:var(--nav-h);position:sticky;top:0;z-index:100}
.nav-brand{font-size:15px;font-weight:600;letter-spacing:-0.02em;margin-right:1.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;color:var(--text)}
.nav-brand span{color:var(--blue)}
.nav-tabs{display:flex;height:100%;flex:1}
.nav-tab{padding:0 1rem;height:100%;display:flex;align-items:center;font-size:13px;cursor:pointer;border-bottom:2px solid transparent;color:var(--text2);white-space:nowrap;transition:color 0.15s}
.nav-tab:hover{color:var(--text)}
.nav-tab.active{color:var(--text);border-bottom-color:var(--text);font-weight:500}
.nav-tab.public-tab{margin-left:auto;background:var(--bg3);color:var(--text2);border-radius:6px;padding:0 12px;height:32px;margin-top:auto;margin-bottom:auto;border-bottom:none;font-weight:500;border:1px solid var(--border)}
.nav-right{display:flex;align-items:center;gap:8px;margin-left:1rem;flex-shrink:0}
.nav-user{font-size:12px;color:var(--text2);white-space:nowrap}
.nav-logout{font-size:12px;color:var(--text2);cursor:pointer;padding:5px 10px;border:1px solid var(--border);border-radius:8px;background:none;transition:all 0.15s;font-family:inherit}
.nav-logout:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}
.dark-toggle{background:var(--bg);border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:5px 10px;font-size:13px;color:var(--text2);transition:background 0.15s;font-family:inherit}
.dark-toggle:hover{background:var(--bg3)}
.nav-bell-area{margin-left:auto;display:flex;align-items:center;flex-shrink:0}
@media(max-width:767px){.nav-bell-area{display:none}}
.nav-bell-btn{background:none;border:none;cursor:pointer;padding:5px;position:relative;color:var(--text2);display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background 0.15s;-webkit-tap-highlight-color:transparent}
.nav-bell-btn:hover{background:var(--bg3);color:var(--text)}
.nav-bell-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nav-bell-badge{position:absolute;top:1px;right:1px;min-width:16px;height:16px;border-radius:8px;background:var(--red);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;pointer-events:none}

/* ── SETTINGS MENU ─────────────────────────────────────────────── */
.settings-menu{background:var(--bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.15);width:90%;max-width:360px;padding:6px 0}
.sm-title{padding:16px 20px 12px;font-size:15px;font-weight:600;color:var(--text);border-bottom:1px solid var(--border);margin-bottom:4px;letter-spacing:-0.01em}
.settings-menu button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 20px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text);text-align:left;gap:16px;transition:background 0.1s;font-family:inherit}
.settings-menu button:hover{background:var(--bg3)}
.settings-menu .sm-sep{border:none;border-top:1px solid var(--border);margin:4px 0}
/* ── SETTINGS PAGE ─────────────────────────────────────────────── */
.settings-layout{display:flex;gap:0;align-items:flex-start}
.settings-nav{width:190px;min-width:190px;padding:0.25rem 1rem 0.25rem 0;flex-shrink:0}
.settings-nav-group{margin-bottom:1.25rem}
.settings-nav-label{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text3);padding:0 0.75rem 0.5rem;display:block}
.settings-nav-item{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text2);padding:7px 0.75rem;border-radius:8px;font-family:inherit;transition:color 0.15s,background 0.15s;margin-bottom:2px}
.settings-nav-item:hover{color:var(--text);background:var(--bg3)}
.settings-nav-item.active{color:var(--text);background:var(--bg3);font-weight:500}
.settings-body{flex:1;padding:0 0 1rem 2rem;border-left:1px solid var(--border);min-width:0}
.settings-sec{display:none}
.settings-sec.active{display:block}
.settings-sec-title{font-size:18px;font-weight:600;letter-spacing:-0.02em;color:var(--text);margin-bottom:0.35rem}
.settings-sec-desc{font-size:13px;color:var(--text2);margin-bottom:1.5rem;line-height:1.6;border-bottom:1px solid var(--border);padding-bottom:1.25rem}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border);gap:1rem}
.settings-row-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:3px}
.settings-row-sub{font-size:12px;color:var(--text2)}
@media(max-width:640px){.settings-layout{flex-direction:column}.settings-nav{width:100%;padding:0 0 0.5rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem;display:flex;flex-wrap:wrap;gap:4px}.settings-nav-group{margin-bottom:0.5rem}.settings-nav-label{display:none}.settings-body{padding:0;border-left:none}}
/* ── FORM BUILDER ───────────────────────────────────────────────── */
.fb-field-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:0.5px solid var(--border);flex-wrap:wrap}
.fb-field-card:last-child{border-bottom:none}
.fb-field-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;flex-wrap:wrap}
.fb-field-label{font-size:14px;font-weight:500;color:var(--text)}
.fb-type-badge{font-size:10px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;padding:3px 8px;border-radius:6px;background:var(--bg3);color:var(--text2);white-space:nowrap;flex-shrink:0}
.fb-field-actions{display:flex;gap:6px;flex-shrink:0}
.fb-option-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:0.5px solid var(--border);font-size:13px}
.fb-option-row button{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text3);padding:0 4px;line-height:1}
.fb-option-row button:hover{color:var(--red)}
.blocked-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:13px;color:var(--text)}
.blocked-row button{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text3);line-height:1;padding:0 4px}
.blocked-row button:hover{color:var(--red)}
.sm-badge{font-size:11px;padding:2px 7px;border-radius:10px;font-weight:500;background:var(--green-bg);color:var(--green)}
.sm-badge.off{background:var(--bg3);color:var(--text3)}

/* ── SIDEBAR ────────────────────────────────────────────────────── */
.sidebar{display:none;position:fixed;left:0;top:var(--nav-h);bottom:0;width:56px;background:var(--bg);border-right:1px solid var(--border);z-index:90;overflow:hidden;flex-direction:column;padding:8px 0;transition:width 0.22s cubic-bezier(0.4,0,0.2,1)}
.sidebar:hover{width:210px;box-shadow:2px 0 16px rgba(0,0,0,0.06)}
.sidebar-item{display:flex;align-items:center;gap:12px;padding:11px 18px;cursor:pointer;color:var(--text3);font-size:13px;font-weight:500;border:none;background:none;white-space:nowrap;width:100%;text-align:left;transition:color 0.15s,background 0.15s;font-family:inherit}
.sidebar-item:hover{color:var(--text);background:var(--bg3)}
.sidebar-item.active{color:var(--text)}
.sidebar-item svg{width:20px;height:20px;min-width:20px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.sidebar-item span{opacity:0;transition:opacity 0.15s}
.sidebar:hover .sidebar-item span{opacity:1}
.sidebar-spacer{flex:1}
.sidebar-user{padding:0 18px 10px;font-size:12px;font-weight:500;color:var(--text2);white-space:nowrap;opacity:0;transition:opacity 0.15s;overflow:hidden}
.sidebar:hover .sidebar-user{opacity:1}
.sidebar-divider{height:1px;background:var(--border);margin:0 12px;flex-shrink:0}
.sidebar-logout:hover{color:var(--red)!important;background:var(--red-bg)!important}

/* ── BOTTOM NAV ────────────────────────────────────────────────── */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-h);background:var(--bg);border-top:1px solid var(--border);z-index:100;align-items:stretch}
.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--text3);font-size:10px;padding:6px 4px;border:none;background:none;-webkit-tap-highlight-color:transparent;transition:color 0.15s;font-family:inherit}
.bottom-nav-item.active{color:var(--text)}
.bottom-nav-item svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ── PAGES & LAYOUT ────────────────────────────────────────────── */
.page{display:none;padding:1.25rem;max-width:1100px;margin:0 auto;padding-bottom:calc(1.25rem + var(--bottom-h))}
.page.active{display:block}
h2{font-size:17px;font-weight:600;letter-spacing:-0.02em;margin-bottom:1rem;color:var(--text)}
h3{font-size:14px;font-weight:600;letter-spacing:-0.01em;margin-bottom:0.75rem;color:var(--text)}
.card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1.25rem}

/* ── PAGE BANNERS ──────────────────────────────────────────────── */
.page-banner{border-radius:10px;padding:12px 16px;margin-bottom:1.25rem;display:flex;align-items:flex-start;gap:10px}
.page-banner.blue{background:var(--blue-bg);border:1px solid var(--blue)}.page-banner.blue .page-banner-title{color:var(--blue)}.page-banner.blue .page-banner-desc{color:var(--blue-text)}
.page-banner.green{background:var(--green-bg);border:1px solid var(--green)}.page-banner.green .page-banner-title{color:var(--green)}.page-banner.green .page-banner-desc{color:var(--green-text)}
.page-banner.amber{background:var(--amber-bg);border:1px solid var(--amber)}.page-banner.amber .page-banner-title{color:var(--amber)}.page-banner.amber .page-banner-desc{color:var(--amber-text)}
.page-banner.teal{background:var(--teal-bg);border:1.5px solid var(--teal-text)}.page-banner.teal .page-banner-title{color:var(--teal)}.page-banner.teal .page-banner-desc{color:var(--teal-text)}
.page-banner-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.page-banner-title{font-size:13px;font-weight:500;margin-bottom:2px}
.page-banner-desc{font-size:12px;line-height:1.5}

/* ── METRICS ───────────────────────────────────────────────────── */
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1.25rem}
.metric{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1rem;transition:box-shadow 0.15s}
.metric:hover{box-shadow:0 2px 8px rgba(0,0,0,0.07)}
.metric-label{font-size:11px;font-weight:500;letter-spacing:0.03em;text-transform:uppercase;color:var(--text3);margin-bottom:6px}
.metric-value{font-size:22px;font-weight:600;letter-spacing:-0.02em;color:var(--text)}
.metric-value.blue{color:var(--blue)}.metric-value.green{color:var(--green)}.metric-value.amber{color:var(--amber)}.metric-value.red{color:var(--red)}

/* ── BUTTONS ───────────────────────────────────────────────────── */
.btn{padding:8px 14px;border:1px solid var(--border2);border-radius:8px;background:var(--bg);cursor:pointer;font-size:13px;color:var(--text);-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:all 0.15s;font-family:inherit;font-weight:400}
.btn:hover{background:var(--bg3)}.btn:active{opacity:0.8}.btn:disabled{opacity:0.4;cursor:not-allowed;pointer-events:none}
.btn.primary{background:var(--text);color:var(--bg);border-color:var(--text);font-weight:500}
.btn.primary:hover{opacity:0.85}
.btn.success{background:var(--green-bg);color:var(--green);border-color:var(--green)}
.btn.danger{background:var(--red-bg);color:var(--red);border-color:var(--red)}
.btn.small{padding:5px 10px;font-size:12px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap}
.back-btn{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text2);background:none;border:none;cursor:pointer;padding:0;margin-bottom:1rem;font-family:inherit;transition:color 0.15s}
.back-btn:hover{color:var(--text)}

/* ── TOOLBAR & SEARCH ──────────────────────────────────────────── */
.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:1rem;flex-wrap:wrap}
.search-input{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--bg);color:var(--text);flex:1;min-width:140px;font-family:inherit;transition:border-color 0.15s}
.search-input:focus{outline:none;border-color:var(--text2)}
.search-input::placeholder{color:var(--text3)}

/* ── VENDOR CARDS (mobile) ─────────────────────────────────────── */
.vendor-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1rem;margin-bottom:0.625rem;transition:box-shadow 0.15s}
.vendor-card:hover{box-shadow:0 2px 8px rgba(0,0,0,0.07)}
.vendor-card-header{display:flex;align-items:center;gap:10px}
.vendor-card-check{flex-shrink:0}
.vendor-card-name{font-weight:500;font-size:14px;flex:1;cursor:pointer;color:var(--text)}
.vendor-card-badge{flex-shrink:0}
.vendor-card-meta{font-size:12px;color:var(--text2);margin-top:4px;padding-left:26px}
.vendor-card-expand{padding-left:26px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.vendor-card-expand .field-label{font-size:11px;color:var(--text3);margin-bottom:2px;margin-top:8px;text-transform:uppercase;letter-spacing:0.04em;font-weight:500}
.vendor-card-expand .field-label:first-child{margin-top:0}
.vendor-card-expand .field-value{font-size:13px;color:var(--text)}

/* ── VENDOR TABLE (desktop) ────────────────────────────────────── */
.vendor-table{width:100%;border-collapse:collapse;font-size:13px}
.vendor-table th{text-align:left;padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text3);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.05em}
.vendor-table td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}
.vendor-table tr:last-child td{border-bottom:none}
.vendor-table tbody tr:hover td{background:var(--bg2)}
.expand-row td{background:var(--bg2);padding:0}
.expand-inner{padding:14px 16px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-label{font-size:11px;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;color:var(--text3);margin-bottom:3px}
.field-value{font-size:13px;color:var(--text)}

/* ── BADGES & CHIPS ────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;letter-spacing:0.01em}
.badge.pending{background:var(--amber-bg);color:var(--amber)}
.badge.paid{background:var(--green-bg);color:var(--green)}
.badge.outstanding{background:var(--red-bg);color:var(--red)}
.badge.partial{background:var(--amber-bg);color:var(--amber)}
.badge.manual,.badge.payfast{background:var(--blue-bg);color:var(--blue)}
.badge.yoco{background:var(--teal-bg);color:var(--teal)}
input[type=checkbox]{width:17px;height:17px;cursor:pointer;accent-color:var(--text)}
.chip{padding:3px 9px;border-radius:20px;font-size:11px;background:var(--teal-bg);color:var(--teal);border:1px solid var(--teal)}
.market-chips{display:flex;flex-wrap:wrap;gap:5px}
.vendor-name-btn{background:none;border:none;cursor:pointer;font-size:13px;color:var(--text);text-align:left;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;padding:0;font-family:inherit;font-weight:500}

/* ── FORMS ─────────────────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-label{font-size:13px;font-weight:500;margin-bottom:6px;display:block;color:var(--text)}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:16px;background:var(--bg);color:var(--text);font-family:inherit;transition:border-color 0.15s}
.form-input:focus{outline:none;border-color:var(--text2);box-shadow:0 0 0 3px rgba(0,0,0,0.04)}
textarea.form-input{min-height:80px;resize:vertical;font-size:15px}
select.form-input{font-size:14px}
.form-input::placeholder{color:var(--text3)}
.pw-strength-wrap{margin-top:6px}
.pw-strength-bar{height:4px;border-radius:2px;background:var(--bg3);overflow:hidden;margin-bottom:4px}
.pw-strength-fill{height:100%;width:0;border-radius:2px;transition:width 0.25s,background 0.25s}
.pw-strength-label{font-size:11px;color:var(--text3)}

/* ── MARKET CARDS ──────────────────────────────────────────────── */
.market-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:1rem;transition:box-shadow 0.15s}
.market-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.market-banner{height:110px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;color:var(--text2);position:relative;overflow:hidden}
.market-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.market-banner-fee{position:absolute;bottom:8px;right:10px;font-size:11px;z-index:1;background:rgba(0,0,0,0.45);color:#fff;padding:2px 8px;border-radius:10px;font-weight:500}
.market-body{padding:1rem}
.market-body strong{color:var(--text)}
.market-body p{color:var(--text2)}
.market-footer{padding:0.75rem 1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.date-chip{padding:3px 9px;border-radius:20px;font-size:11px;background:var(--bg3);color:var(--text2);border:1px solid var(--border2)}
.date-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.published-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500}
.published-badge.on{background:var(--green-bg);color:var(--green)}
.published-badge.off{background:var(--bg3);color:var(--text2)}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.dot.green{background:var(--green)}.dot.gray{background:var(--text3)}

/* ── PROGRESS ──────────────────────────────────────────────────── */
.progress-wrap{background:var(--bg3);border-radius:20px;height:6px;overflow:hidden;margin-top:6px}
.progress-bar{height:100%;border-radius:20px;background:var(--green);transition:width 0.4s}
.progress-bar.amber{background:var(--amber)}
.progress-bar.red{background:var(--red)}

/* ── MODALS ────────────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-overlay.open{display:flex}
.modal{background:var(--bg);border-radius:16px;padding:1.5rem;width:90%;max-width:580px;max-height:90vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,0.15)}
.modal-handle{display:none}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}
.modal-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text3);padding:4px;line-height:1;border-radius:6px;transition:all 0.15s}
.modal-close:hover{color:var(--text);background:var(--bg3)}
@media(max-width:767px){
  .modal-overlay{align-items:flex-end;backdrop-filter:none}
  .modal{border-radius:20px 20px 0 0;width:100%;max-width:100%}
  .modal-handle{display:block;width:36px;height:4px;background:var(--border2);border-radius:2px;margin:0 auto 1.25rem}
}

/* ── PUBLIC PAGE ───────────────────────────────────────────────── */
.public-page{max-width:720px;margin:0 auto;padding:1.25rem;padding-bottom:calc(1.25rem + var(--bottom-h))}
.public-banner{border-radius:12px;height:140px;background:var(--bg3);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;overflow:hidden;position:relative}
.public-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.public-banner-text{position:relative;z-index:1;text-align:center}
.tabs-inner{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.25rem}
.tab-inner{padding:10px 16px;font-size:13px;cursor:pointer;border-bottom:2px solid transparent;color:var(--text2);transition:color 0.15s}
.tab-inner.active{color:var(--text);border-bottom-color:var(--text);font-weight:500}
.market-select-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:0.75rem;display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:all 0.15s}
.market-select-card:hover{border-color:var(--border2)}
.market-select-card.selected{border-color:var(--text);background:var(--bg2)}
.msc-name{font-weight:500;font-size:14px;color:var(--text)}
.msc-dates{font-size:12px;color:var(--text2);margin-top:2px}
.msc-fee{font-size:12px;color:var(--text3);margin-top:2px}

/* ── MISC ──────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text3);font-size:14px}
.upload-box{border:1.5px dashed var(--border2);border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;font-size:13px;color:var(--text2);position:relative;transition:all 0.15s}
.upload-box:hover{border-color:var(--text2);color:var(--text)}
.upload-box input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-preview{width:100%;height:100px;object-fit:cover;border-radius:8px;margin-top:8px;display:block}
.img-thumb-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.img-thumb{position:relative;width:76px;height:76px}
.img-thumb img{width:100%;height:100%;object-fit:cover;border-radius:8px;border:1px solid var(--border)}
.img-thumb.clickable{cursor:zoom-in}
.img-thumb.clickable img:hover{opacity:0.85;transition:opacity 0.15s}

/* ── LIGHTBOX ───────────────────────────────────────────────────── */
#lightbox{display:none;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,0.92);align-items:center;justify-content:center}
#lightbox.open{display:flex}
#lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:8px;user-select:none}
#lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.7);font-size:13px;font-family:inherit}
.lb-close{position:absolute;top:16px;right:20px;background:none;border:none;color:#fff;font-size:28px;cursor:pointer;opacity:0.7;line-height:1;padding:4px}
.lb-close:hover{opacity:1}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.12);border:none;color:#fff;font-size:48px;cursor:pointer;width:56px;height:72px;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1;transition:background 0.15s}
.lb-arrow:hover{background:rgba(255,255,255,0.22)}
.lb-prev{left:16px}
.lb-next{right:16px}
.img-thumb-remove{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--red);color:#fff;border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}
.dot-menu-popup{display:none;position:fixed;z-index:300;background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,0.12);min-width:190px;padding:6px 0}
.dot-menu-popup .dm-label{padding:8px 14px 6px;font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);margin-bottom:4px}
.dot-menu-popup button{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text);text-align:left;transition:background 0.1s;font-family:inherit}
.dot-menu-popup button:hover{background:var(--bg3)}
.dot-menu-popup button.danger{color:var(--red)}
.info-box{padding:10px 12px;border-radius:8px;font-size:12px;margin-bottom:1rem;display:none}
.info-box.blue{background:var(--blue-bg);border:1px solid var(--blue);color:var(--blue-text)}

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media(max-width:767px){
  .nav-tabs,.nav-right{display:none}
  .nav{padding:0 1rem}
  .nav-brand{max-width:calc(100vw - 140px);font-size:13px}
  .nav-mobile-right{display:flex;align-items:center;gap:8px;margin-left:auto}
  .bottom-nav{display:flex}
  .metric-grid{grid-template-columns:1fr 1fr;gap:8px}
  .metric-value{font-size:20px}
  .page{padding:1rem;padding-bottom:calc(1rem + var(--bottom-h))}
  .desktop-table{display:none}
  .mobile-cards{display:block}
  .card{padding:1rem}
  .market-footer .btn-row{width:100%}
  .market-footer .btn-row .btn{flex:1}
}
@media(min-width:768px){
  .nav-mobile-right{display:none}
  .nav-tabs{display:none}
  .nav-right{display:none}
  .sidebar{display:flex}
  .dashboard-main{margin-left:56px}
  .desktop-table{display:table}
  .mobile-cards{display:none}
  .expand-inner{grid-template-columns:1fr 1fr}
  .page{padding-bottom:1.25rem}
}
@media(min-width:768px) and (max-width:1023px){
  .metric-grid{grid-template-columns:repeat(2,1fr)}
  .nav-brand{max-width:160px}
}
/* ── HOME PAGE ──────────────────────────────────────────────────── */
.home-hero{background:linear-gradient(135deg,var(--blue-bg) 0%,var(--bg) 100%);border:1px solid var(--blue);border-radius:12px;padding:1.75rem 2rem;margin-bottom:1.25rem}
.home-greeting{font-size:24px;font-weight:600;letter-spacing:-0.02em;color:var(--text);margin-bottom:4px}
.home-hero-sub{font-size:13px;color:var(--text2)}
.home-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:1.25rem}
.home-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem 1.25rem;cursor:pointer;transition:box-shadow 0.15s,border-color 0.15s,transform 0.1s;display:flex;flex-direction:column;align-items:flex-start;gap:10px;text-align:left}
.home-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.09);border-color:var(--border2);transform:translateY(-2px)}
.home-card-icon{width:42px;height:42px;border-radius:10px;background:var(--blue-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.home-card-icon svg{width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.home-card-title{font-size:14px;font-weight:600;color:var(--text);letter-spacing:-0.01em}
.home-card-desc{font-size:12px;color:var(--text2);line-height:1.55}
.home-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:0}
@media(max-width:767px){.home-cards{grid-template-columns:1fr 1fr}.home-hero{padding:1.25rem 1.25rem}}
@media(max-width:440px){.home-cards{grid-template-columns:1fr}}
@media(min-width:1024px){.metric-grid{grid-template-columns:repeat(4,1fr)}}
