/* ═══════════════════════════════════════════════════════════════
   BizHub / Sika — Premium Business OS UI (v2)
   Professional fintech design · Mobile-first · Desktop-class
   Fonts: Outfit (display) · Inter (body) · JetBrains Mono (data)
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@500;600;700;800;900&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
    /* ── Core palette ─────────────────────────────── */
    --bg:            #f5f7fb;
    --bg-warm:       #f7f6f2;
    --bg-elev:       #ffffff;
    --surface:       #ffffff;
    --surface-hover: #f8fafc;
    --surface-alt:   #fafbfd;
    --surface-raised:#ffffff;
    --surface-3:     var(--surface-alt);

    --primary:       #0b1220;
    --primary-soft:  #111827;
    --primary-ink:   #0f172a;

    --accent:        #10b981;
    --accent-2:      #059669;
    --accent-hover:  #0ea371;
    --accent-soft:   rgba(16,185,129,.10);
    --accent-glow:   rgba(16,185,129,.22);
    --accent-ring:   rgba(16,185,129,.28);

    --indigo:        #6366f1;
    --indigo-soft:   rgba(99,102,241,.10);
    --violet:        #8b5cf6;
    --violet-soft:   rgba(139,92,246,.10);
    --amber:         #f59e0b;
    --amber-soft:    rgba(245,158,11,.10);
    --red:           #ef4444;
    --red-soft:      rgba(239,68,68,.08);
    --green:         #10b981;
    --green-soft:    rgba(16,185,129,.08);
    --blue:          #3b82f6;
    --blue-soft:     rgba(59,130,246,.08);
    --teal:          #14b8a6;
    --teal-soft:     rgba(20,184,166,.10);

    --text:          #0f172a;
    --text-2:        #475569;
    --text-3:        #94a3b8;
    --text-inv:      #ffffff;
    --border:        #e2e8f0;
    --border-soft:   #edf1f7;
    --border-light:  #f1f5f9;
    --divider:       rgba(15,23,42,.06);

    /* ── Typography ───────────────────────────────── */
    --font-display:'Outfit', ui-sans-serif, system-ui, -apple-system, sans-serif;
    --font-body:   'Inter',  ui-sans-serif, system-ui, -apple-system, sans-serif;
    --font-mono:   'JetBrains Mono', ui-monospace, Menlo, monospace;

    /* ── Radii & shadows ──────────────────────────── */
    --r-xs:8px; --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:22px; --r-2xl:28px; --r-full:999px;

    --shadow-xs: 0 1px 2px rgba(15,23,42,.04);
    --shadow-sm: 0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.03);
    --shadow-md: 0 6px 16px -6px rgba(15,23,42,.10), 0 2px 4px rgba(15,23,42,.04);
    --shadow-lg: 0 16px 40px -12px rgba(15,23,42,.14), 0 4px 12px rgba(15,23,42,.05);
    --shadow-xl: 0 28px 60px -20px rgba(15,23,42,.24), 0 10px 20px rgba(15,23,42,.06);
    --shadow-pop:0 20px 50px -12px rgba(16,185,129,.28);

    /* ── Dimensions ───────────────────────────────── */
    --topbar-h:   64px;
    --bnav-h:     68px;
    --sidebar-w:  272px;
    --container:  1200px;
    --container-lg:1320px;
    --safe-b:     env(safe-area-inset-bottom, 0px);
    --safe-t:     env(safe-area-inset-top, 0px);

    /* ── Motion ───────────────────────────────────── */
    --ease:        cubic-bezier(.4,0,.2,1);
    --ease-out:    cubic-bezier(.16,1,.3,1);
    --ease-spring: cubic-bezier(.175,.885,.32,1.275);
}

/* ══════════════ Base & Reset ═══════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
    font-size:15px;-webkit-text-size-adjust:100%;
    scroll-behavior:smooth;text-rendering:optimizeLegibility;
}
body{
    font-family:var(--font-body);background:var(--bg);color:var(--text);
    line-height:1.55;overflow-x:hidden;
    -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
    font-feature-settings:'cv11','ss01','ss03';
}
input,textarea,select,button{font-family:var(--font-body)}
img,svg,video{max-width:100%;display:block}
button{cursor:pointer}
a{color:inherit}
::selection{background:var(--accent-soft);color:var(--accent-2)}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(15,23,42,.12);border-radius:10px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:rgba(15,23,42,.22);background-clip:content-box;border:2px solid transparent}

/* ══════════════ App Loader ═════════════════════════ */
.app-loader{
    position:fixed;inset:0;z-index:9999;
    background:radial-gradient(ellipse at top,#0f172a 0%,#020617 80%);
    display:flex;align-items:center;justify-content:center;
}
.loader-content{text-align:center}
.loader-logo{
    font-family:var(--font-display);font-size:2.4rem;font-weight:900;
    color:var(--text-inv);letter-spacing:-.04em;margin-bottom:28px;
    text-shadow:0 4px 24px rgba(16,185,129,.3);
}
.loader-logo span{
    background:linear-gradient(135deg,#34d399 0%,#10b981 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.loader-bar{
    width:140px;height:3px;background:rgba(255,255,255,.08);
    border-radius:999px;margin:0 auto;overflow:hidden;position:relative;
}
.loader-bar::after{
    content:'';position:absolute;top:0;left:0;height:100%;width:40%;
    background:linear-gradient(90deg,transparent,var(--accent) 50%,transparent);
    border-radius:999px;animation:loadSlide 1.2s var(--ease) infinite;
}
@keyframes loadSlide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ══════════════ Screens ════════════════════════════ */
.screen{min-height:100dvh}

/* ══════════════ Auth Screen (login / OTP) ══════════ */
.auth-screen-bg{
    min-height:100dvh;
    display:grid;
    grid-template-columns:1fr;
    background:var(--bg-warm);
    position:relative;overflow:hidden;
}
.auth-screen-bg::before{
    content:'';position:absolute;top:-30%;right:-25%;
    width:640px;height:640px;border-radius:50%;
    background:radial-gradient(circle,var(--accent-glow) 0%,transparent 65%);
    pointer-events:none;filter:blur(10px);
}
.auth-screen-bg::after{
    content:'';position:absolute;bottom:-40%;left:-30%;
    width:520px;height:520px;border-radius:50%;
    background:radial-gradient(circle,rgba(99,102,241,.14) 0%,transparent 70%);
    pointer-events:none;filter:blur(10px);
}
.auth-container{
    max-width:440px;margin:0 auto;width:100%;
    padding:40px 24px calc(40px + var(--safe-b));
    display:flex;flex-direction:column;justify-content:center;
    position:relative;z-index:1;min-height:100dvh;
}
.auth-logo{
    font-family:var(--font-display);font-size:2.25rem;font-weight:900;
    color:var(--primary);letter-spacing:-.04em;line-height:1;
}
.auth-logo span{
    background:var(--accent);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.auth-subtitle{color:var(--text-2);margin-top:10px;font-size:.95rem;font-weight:400;line-height:1.5}
.auth-header{margin-bottom:36px}
.auth-step{animation:fadeUp .4s var(--ease-out)}

.auth-remember{margin:0 0 18px}
.remember-check{display:inline-flex;align-items:center;gap:10px;cursor:pointer;color:var(--text-2);font-weight:650;font-size:.9rem;user-select:none}
.remember-check input{width:18px;height:18px;accent-color:var(--accent)}

.phone-input-wrap{
    display:flex;align-items:center;
    border:1.5px solid var(--border);border-radius:var(--r-md);
    overflow:hidden;transition:all .18s var(--ease);
    background:var(--surface);
}
.phone-input-wrap:focus-within{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-soft);
}
/* Country picker button (replaces old .phone-prefix) */
.country-picker-btn{
    display:flex;align-items:center;gap:5px;
    padding:0 14px;height:54px;min-width:88px;
    background:var(--surface-alt);border:none;outline:none;
    cursor:pointer;font-size:.95rem;font-weight:600;color:var(--text-2);
    border-right:1px solid var(--border);transition:background .15s;
    flex-shrink:0;
}
.country-picker-btn:hover{background:var(--surface-hover);}
#selected-flag{font-size:1.2rem;line-height:1;}
#selected-dial{font-size:.88rem;font-weight:700;letter-spacing:.01em;color:var(--primary);}

/* Country picker modal overlay */
.country-modal-overlay{
    position:fixed;inset:0;z-index:9999;
    background:rgba(15,23,42,.5);
    display:flex;align-items:flex-end;justify-content:center;
    backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
    opacity:0;transition:opacity .28s var(--ease);
}
.country-modal-overlay.visible{opacity:1;}
.country-modal-sheet{
    width:100%;max-width:480px;
    background:var(--surface);
    border-radius:var(--r-2xl) var(--r-2xl) 0 0;
    max-height:82dvh;display:flex;flex-direction:column;
    transform:translateY(100%);transition:transform .28s var(--ease-out);
    padding-bottom:var(--safe-b);
}
.country-modal-overlay.visible .country-modal-sheet{transform:translateY(0);}
.country-modal-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 20px 0;
}
.country-modal-title{font-size:1.05rem;font-weight:700;color:var(--text);}
.country-modal-close{
    background:none;border:none;cursor:pointer;
    width:34px;height:34px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:var(--text-2);font-size:1rem;
    background:var(--surface-alt);transition:all .15s;
}
.country-modal-close:hover{background:var(--border-soft);color:var(--text);}
.country-search-wrap{
    padding:14px 20px 10px;position:relative;
}
.country-search-icon{
    position:absolute;left:32px;top:50%;transform:translateY(-50%);
    color:var(--text-3);font-size:.9rem;pointer-events:none;
}
.country-search-input{
    width:100%;padding:10px 14px 10px 36px;
    border:1.5px solid var(--border);border-radius:var(--r-sm);
    font-size:.92rem;background:var(--surface-alt);color:var(--text);
    outline:none;transition:all .18s;
}
.country-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.country-list{
    flex:1;overflow-y:auto;padding:0 12px 16px;
    -webkit-overflow-scrolling:touch;
}
.country-item{
    width:100%;display:flex;align-items:center;gap:12px;
    padding:11px 12px;border:none;background:none;cursor:pointer;
    border-radius:var(--r-sm);transition:background .13s;text-align:left;
    font-size:.92rem;color:var(--text);
}
.country-item:hover{background:var(--surface-hover);}
.country-item.selected{background:var(--accent-soft);}
.country-flag{font-size:1.3rem;width:28px;text-align:center;flex-shrink:0;}
.country-name{flex:1;font-weight:500;}
.country-code{font-size:.82rem;color:var(--text-3);font-weight:600;font-variant-numeric:tabular-nums;}
.country-check{color:var(--accent);font-size:1rem;margin-left:4px;}
.country-empty{text-align:center;padding:32px 16px;color:var(--text-3);font-size:.9rem;}

/* keep old .phone-prefix for any legacy usage */
.phone-prefix{
    padding:0 16px;font-weight:600;color:var(--text-2);
    background:var(--surface-alt);height:54px;
    display:flex;align-items:center;font-size:.95rem;
    border-right:1px solid var(--border);
}
.phone-input-wrap input{
    flex:1;border:none;outline:none;padding:0 16px;
    height:54px;font-size:1rem;font-weight:500;
    letter-spacing:.02em;background:transparent;color:var(--text);
}

/* OTP Inputs */
.otp-info{color:var(--text-2);margin-bottom:0;font-size:.9rem;line-height:1.55;flex:1;}
.otp-info strong{color:var(--text);font-weight:700;display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}
.otp-info strong img{flex-shrink:0}
.otp-inputs{display:flex;gap:10px;justify-content:center;margin-top:22px;margin-bottom:28px}
.otp-inputs input{
    width:52px;height:60px;text-align:center;font-size:1.4rem;
    font-weight:700;border:1.5px solid var(--border);
    border-radius:var(--r-md);outline:none;font-family:var(--font-display);
    transition:all .18s var(--ease);background:var(--surface);color:var(--text);
}
.otp-inputs input:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-soft);
    transform:translateY(-2px);
}
.otp-actions{display:flex;justify-content:space-between;align-items:center;margin-top:18px}

@media(max-width:380px){
    .auth-container{padding:32px 18px calc(32px + var(--safe-b))}
    .otp-inputs{gap:8px}
    .otp-inputs input{width:42px;height:54px;font-size:1.2rem}
    .country-picker-btn{padding:0 12px;min-width:80px}
}

/* Desktop split-screen auth */
.auth-panel{display:none}

@media(min-width:960px){
    .auth-screen-bg{
        grid-template-columns:1.05fr .95fr;
    }
    .auth-container{
        margin:0;max-width:none;
        padding:56px 80px;
        justify-self:end;width:100%;max-width:560px;
    }
    .auth-panel{
        display:flex;position:relative;overflow:hidden;
        background:
            radial-gradient(1000px 600px at 80% 20%, rgba(16,185,129,.18) 0%, transparent 55%),
            radial-gradient(800px 500px at 10% 90%, rgba(99,102,241,.14) 0%, transparent 55%),
            linear-gradient(155deg,#0b1220 0%,#111827 45%,#0f172a 100%);
        color:var(--text-inv);
        padding:64px 72px;
        align-items:center;
    }
    .auth-panel::before{
        content:'';position:absolute;inset:0;
        background:
            radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.4), transparent),
            radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,.3), transparent),
            radial-gradient(1.5px 1.5px at 40% 80%, rgba(255,255,255,.35), transparent);
        opacity:.6;
    }
    .auth-panel-inner{position:relative;z-index:1;max-width:440px}
    .auth-panel-badge{
        display:inline-flex;align-items:center;gap:8px;
        padding:7px 14px;border-radius:999px;
        background:rgba(16,185,129,.14);
        border:1px solid rgba(16,185,129,.28);
        color:#6ee7b7;font-weight:700;font-size:.78rem;
        letter-spacing:.02em;
    }
    .auth-panel-title{
        font-family:var(--font-display);font-size:2.6rem;font-weight:900;
        letter-spacing:-.035em;line-height:1.08;margin-top:20px;
    }
    .auth-panel-title em{
        font-style:normal;
        background:linear-gradient(135deg,#34d399 0%,#a7f3d0 100%);
        -webkit-background-clip:text;background-clip:text;color:transparent;
    }
    .auth-panel-sub{
        margin-top:16px;color:rgba(255,255,255,.72);
        font-size:1rem;line-height:1.6;max-width:42ch;
    }
    .auth-panel-features{
        margin-top:36px;display:flex;flex-direction:column;gap:14px;
    }
    .auth-panel-feat{
        display:flex;align-items:center;gap:14px;
        color:rgba(255,255,255,.88);font-size:.95rem;font-weight:500;
    }
    .auth-panel-feat i{
        width:38px;height:38px;border-radius:12px;
        background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.28);
        display:flex;align-items:center;justify-content:center;
        color:#6ee7b7;font-size:1.05rem;flex-shrink:0;
    }
    .auth-panel-footer{
        position:absolute;left:72px;right:72px;bottom:36px;
        color:rgba(255,255,255,.5);font-size:.82rem;font-weight:500;
        display:flex;justify-content:space-between;align-items:center;gap:16px;
    }
    .auth-screen-bg::before,.auth-screen-bg::after{display:none}
}

/* ══════════════ Onboarding ═════════════════════════ */
.onboard-container{
    min-height:100dvh;padding:44px 24px calc(44px + var(--safe-b));
    max-width:520px;margin:0 auto;background:var(--bg-warm);
}
.onboard-header{margin-bottom:32px}
.onboard-step{
    display:inline-flex;align-items:center;gap:8px;padding:6px 14px;
    background:var(--accent-soft);color:var(--accent-2);
    font-size:.76rem;font-weight:700;border-radius:var(--r-full);
    margin-bottom:14px;letter-spacing:.02em;
    border:1px solid var(--accent-ring);
}
.onboard-header h2{
    font-family:var(--font-display);font-size:1.8rem;font-weight:800;
    color:var(--primary);letter-spacing:-.02em;line-height:1.15;
}
.onboard-header p{color:var(--text-2);margin-top:6px;font-size:.95rem}

/* ══════════════ Forms ══════════════════════════════ */
.form-stack{display:flex;flex-direction:column;gap:18px}
.input-group{display:flex;flex-direction:column;gap:8px}
.input-group label{
    font-size:.82rem;font-weight:600;color:var(--text);letter-spacing:.005em;
}
.required{color:var(--red)}

.input-group input,
.input-group textarea,
.input-group select{
    width:100%;padding:13px 15px;border:1.5px solid var(--border);
    border-radius:var(--r-sm);font-size:.94rem;
    outline:none;transition:all .18s var(--ease);background:var(--surface);
    color:var(--text);font-weight:500;
    box-shadow:var(--shadow-xs);
}
.input-group input:hover,
.input-group textarea:hover,
.input-group select:hover{border-color:var(--text-3)}
.input-group input:focus,
.input-group textarea:focus,
.input-group select:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-soft);
}
.input-group input::placeholder,
.input-group textarea::placeholder{color:var(--text-3);font-weight:400}
.input-group textarea{resize:vertical;min-height:80px;line-height:1.5}
.input-group input:disabled,
.input-group select:disabled{background:var(--surface-alt);color:var(--text-3);cursor:not-allowed}
.input-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.file-upload{
    position:relative;border:2px dashed var(--border);
    border-radius:var(--r-md);padding:22px;
    text-align:center;cursor:pointer;transition:all .18s var(--ease);
    color:var(--text-3);font-size:.88rem;font-weight:500;
    background:var(--surface-alt);
}
.file-upload:hover{
    border-color:var(--accent);background:var(--accent-soft);color:var(--accent);
    transform:translateY(-1px);
}
.file-upload.has-file{border-color:var(--accent);border-style:solid;color:var(--accent);background:var(--accent-soft)}
.file-upload i{font-size:1.5rem;display:block;margin-bottom:8px}
.file-upload input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}

.optional-fields summary{
    cursor:pointer;font-size:.86rem;font-weight:600;
    color:var(--accent);list-style:none;padding:10px 0;
    display:inline-flex;align-items:center;gap:6px;
}
.optional-fields summary::before{content:'+';font-size:1.1rem;line-height:1}
.optional-fields[open] summary::before{content:'−'}

/* ══════════════ Buttons ════════════════════════════ */
.btn{
    display:inline-flex;align-items:center;justify-content:center;
    gap:8px;padding:13px 22px;border:none;border-radius:var(--r-sm);
    font-size:.92rem;font-weight:600;cursor:pointer;
    transition:all .18s var(--ease);text-decoration:none;
    position:relative;overflow:hidden;letter-spacing:.005em;
    white-space:nowrap;
}
.btn::before{
    content:'';position:absolute;inset:0;background:rgba(255,255,255,.12);
    opacity:0;transition:opacity .18s var(--ease);
}
.btn:hover::before{opacity:1}
.btn:active{transform:translateY(1px) scale(.99)}

.btn-primary{
    background:var(--accent);
    color:var(--text-inv);
    box-shadow:0 2px 8px rgba(16,185,129,.25);
}
.btn-primary:hover{
    transform:translateY(-1px);
    box-shadow:0 4px 16px rgba(16,185,129,.3);
}
.btn-primary:active{transform:translateY(0);box-shadow:0 1px 4px rgba(16,185,129,.2)}
.btn-dark{
    background:var(--primary);color:var(--text-inv);
    box-shadow:0 4px 14px -4px rgba(15,23,42,.4);
}
.btn-dark:hover{background:var(--primary-soft);transform:translateY(-1px)}
.btn-outline{
    background:var(--surface);border:1.5px solid var(--border);color:var(--text);
    box-shadow:var(--shadow-xs);
}
.btn-outline:hover{border-color:var(--text-3);background:var(--surface-hover);transform:translateY(-1px)}
.btn-danger{
    background:var(--red);color:var(--text-inv);
    box-shadow:0 4px 14px -4px rgba(239,68,68,.4);
}
.btn-danger:hover{transform:translateY(-1px);box-shadow:0 8px 20px -4px rgba(239,68,68,.5)}
.btn-ghost{background:transparent;color:var(--text-2)}
.btn-ghost:hover{background:var(--surface-hover);color:var(--text)}

.btn-sm{padding:9px 16px;font-size:.82rem;border-radius:var(--r-xs)}
.btn-lg{padding:16px 28px;font-size:1rem;border-radius:var(--r-md)}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn:disabled::before{display:none}

.btn-link{
    background:none;border:none;color:var(--accent);
    font-size:.88rem;cursor:pointer;font-weight:600;padding:4px 0;
    display:inline-flex;align-items:center;gap:6px;
    transition:color .15s var(--ease);
}
.btn-link:hover{color:var(--accent-hover);text-decoration:underline}
.btn-link:disabled{color:var(--text-3);cursor:not-allowed;text-decoration:none}

.btn-fab{
    position:fixed;bottom:calc(var(--bnav-h) + 18px + var(--safe-b));
    right:18px;width:58px;height:58px;border-radius:var(--r-full);
    background:var(--accent);
    color:var(--text-inv);border:none;
    font-size:1.4rem;box-shadow:var(--shadow-xl),0 8px 24px rgba(16,185,129,.4);
    cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;
    transition:all .22s var(--ease-spring);
}
.btn-fab:hover{transform:scale(1.06) rotate(6deg)}
.btn-fab:active{transform:scale(.92)}

.menu-fab{
    position:fixed;
    bottom:calc(var(--bnav-h) + 18px + var(--safe-b));
    left:18px;width:54px;height:54px;border-radius:var(--r-full);
    background:rgba(255,255,255,.94);color:var(--primary);
    border:1px solid rgba(15,23,42,.08);
    box-shadow:var(--shadow-lg);
    cursor:pointer;z-index:50;display:flex;align-items:center;justify-content:center;
    transition:all .2s var(--ease-spring);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.menu-fab i{font-size:1.4rem}
.menu-fab:hover{transform:translateY(-2px)}
.menu-fab:active{transform:scale(.92)}

.btn:focus-visible,
.btn-link:focus-visible,
.menu-toggle:focus-visible,
.topbar-icon:focus-visible,
.bnav-item:focus-visible,
.nav-item:focus-visible,
.biz-picker-btn:focus-visible,
.biz-switcher:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
    outline:3px solid var(--accent-ring);
    outline-offset:2px;
}

/* ══════════════ Topbar ═════════════════════════════ */
.topbar{
    position:fixed;top:0;left:0;right:0;height:var(--topbar-h);
    background:rgba(255,255,255,.80);
    backdrop-filter:saturate(180%) blur(20px);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid var(--divider);
    display:flex;align-items:center;justify-content:space-between;
    padding:0 16px;z-index:100;
}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:10px}
.menu-toggle{
    background:none;border:none;font-size:1.4rem;
    color:var(--text);cursor:pointer;padding:8px;
    display:flex;align-items:center;border-radius:var(--r-xs);
    transition:background .15s var(--ease);
}
.menu-toggle:hover{background:var(--surface-hover)}
.biz-switcher{
    border:1.5px solid var(--border);border-radius:var(--r-sm);
    padding:8px 12px;font-size:.85rem;font-weight:600;
    color:var(--text);outline:none;max-width:180px;
    background:var(--surface);cursor:pointer;
    transition:all .18s var(--ease);
    background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 10px center;
    padding-right:30px;appearance:none;-webkit-appearance:none;
}
.biz-switcher:hover{border-color:var(--text-3)}
.biz-switcher:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.topbar-icon{
    background:var(--surface-alt);border:1px solid var(--border-soft);font-size:1.05rem;
    color:var(--text-2);cursor:pointer;padding:9px;
    border-radius:var(--r-sm);transition:all .15s var(--ease);
    display:flex;align-items:center;justify-content:center;
    position:relative;width:38px;height:38px;
}
.topbar-icon:hover{background:var(--surface);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-xs)}
.icon-badge{
    position:absolute;top:-2px;right:-2px;
    min-width:18px;height:18px;padding:0 5px;
    border-radius:999px;
    background:#ef4444;
    color:var(--surface);font-size:.66rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--surface);
    box-shadow:0 2px 6px rgba(239,68,68,.35);
}
.avatar-sm{
    width:38px;height:38px;border-radius:var(--r-full);
    background:var(--accent);
    color:var(--text-inv);display:flex;align-items:center;justify-content:center;
    font-size:.82rem;font-weight:700;cursor:pointer;overflow:hidden;
    transition:transform .15s var(--ease);
    box-shadow:0 2px 8px rgba(16,185,129,.3),inset 0 1px 0 rgba(255,255,255,.2);
    letter-spacing:.02em;
}
.avatar-sm:hover{transform:scale(1.06)}
.avatar-sm img{width:100%;height:100%;object-fit:cover}

/* ══════════════ Custom Business Picker ═════════════ */
.biz-picker-btn{
    display:flex;align-items:center;gap:8px;
    background:var(--surface-alt);border:1.5px solid var(--border);
    border-radius:var(--r-sm);padding:5px 10px 5px 6px;
    cursor:pointer;transition:all .15s var(--ease);
    max-width:200px;height:38px;
}
.biz-picker-btn:hover{background:var(--surface);border-color:var(--text-3);box-shadow:var(--shadow-xs)}
.biz-avatar-xs{
    width:26px;height:26px;border-radius:var(--r-xs);
    background:var(--accent);
    color:#fff;font-size:.72rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;flex-shrink:0;
}
.biz-avatar-xs img{width:100%;height:100%;object-fit:cover}
.biz-picker-name{
    font-size:.82rem;font-weight:700;color:var(--text);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    max-width:130px;flex:1;
}
.biz-picker-caret{font-size:.65rem;color:var(--text-3);flex-shrink:0;transition:transform .2s}
.biz-picker-btn.open .biz-picker-caret{transform:rotate(180deg)}

@media (max-width: 520px) {
    .biz-picker-btn { padding: 5px 8px 5px 6px; max-width: 56px; }
    .biz-picker-name { display: none; }
    .biz-picker-caret { display: none; }
}

/* Biz picker dropdown panel */
.biz-picker-panel{
    position:fixed;top:calc(var(--topbar-h) + 6px);left:56px;
    width:260px;background:var(--surface);
    border:1px solid var(--border);border-radius:var(--r-lg);
    box-shadow:var(--shadow-xl);z-index:350;
    opacity:0;transform:translateY(-6px) scale(.98);
    transition:opacity .22s var(--ease),transform .22s var(--ease);
    pointer-events:none;
}
.biz-picker-panel.open{opacity:1;transform:none;pointer-events:all}
.biz-picker-search-wrap{
    padding:12px 12px 8px;position:relative;border-bottom:1px solid var(--border-soft);
}
.biz-picker-search-icon{
    position:absolute;left:22px;top:50%;transform:translateY(-50%);
    color:var(--text-3);font-size:.8rem;pointer-events:none;
}
.biz-picker-search{
    width:100%;padding:8px 10px 8px 30px;
    border:1.5px solid var(--border);border-radius:var(--r-sm);
    font-size:.82rem;background:var(--surface-alt);color:var(--text);
    outline:none;transition:border-color .15s;
}
.biz-picker-search:focus{border-color:var(--accent);}
.biz-picker-list{max-height:240px;overflow-y:auto;padding:6px 6px;}
.biz-picker-item{
    width:100%;display:flex;align-items:center;gap:10px;
    padding:9px 10px;border:none;background:none;cursor:pointer;
    border-radius:var(--r-sm);transition:background .13s;text-align:left;
}
.biz-picker-item:hover{background:var(--surface-hover)}
.biz-picker-item.active{background:var(--accent-soft)}
.biz-picker-item-av{
    width:32px;height:32px;border-radius:var(--r-xs);
    background:var(--accent);
    color:#fff;font-size:.8rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;flex-shrink:0;
}
.biz-picker-item-av img{width:100%;height:100%;object-fit:cover}
.biz-picker-item-info{flex:1;min-width:0;}
.biz-picker-item-name{font-size:.85rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.biz-picker-item-cat{font-size:.72rem;color:var(--text-3);}
.biz-picker-item-check{color:var(--accent);font-size:1rem;flex-shrink:0}
.biz-picker-footer{
    border-top:1px solid var(--border-soft);padding:8px 10px;
}
.biz-picker-footer button{
    width:100%;display:flex;align-items:center;gap:8px;
    padding:9px 10px;border:none;background:none;cursor:pointer;
    border-radius:var(--r-sm);font-size:.82rem;font-weight:600;
    color:var(--accent);transition:background .13s;
}
.biz-picker-footer button:hover{background:var(--accent-soft)}
.biz-picker-empty{
    display:flex;align-items:center;gap:8px;padding:16px 10px;
    color:var(--text-3);font-size:.82rem;
}

/* ══════════════ Country Flag in Topbar ═════════════ */
.topbar-flag{
    display:flex;align-items:center;justify-content:center;
    width:34px;height:34px;border-radius:var(--r-xs);
    background:var(--surface-alt);border:1px solid var(--border-soft);
    overflow:hidden;cursor:default;flex-shrink:0;
}
.topbar-flag img{width:22px;height:auto;display:block;border-radius:2px;}

/* Quick-add button highlight */
.topbar-quick-add{
    background:var(--accent) !important;
    border-color:transparent !important;
    color:#fff !important;
    box-shadow:0 2px 8px rgba(16,185,129,.35);
}
.topbar-quick-add:hover{
    filter:brightness(1.07);
    box-shadow:0 4px 14px rgba(16,185,129,.4);
    transform:translateY(-1px);
}

/* ══════════════ Quick Actions Panel ════════════════ */
.panel-overlay{
    position:fixed;inset:0;z-index:299;
    background:rgba(15,23,42,.28);
    backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
}
.quick-actions-panel{
    position:fixed;top:calc(var(--topbar-h) + 6px);right:10px;
    width:min(320px, calc(100vw - 20px));
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--r-xl);box-shadow:var(--shadow-xl);
    z-index:350;padding:0 0 6px;
    opacity:0;transform:translateY(-8px) scale(.97);
    transition:opacity .22s var(--ease),transform .22s var(--ease);
    pointer-events:none;
}
.quick-actions-panel.open{opacity:1;transform:none;pointer-events:all}
.qa-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 16px 10px;border-bottom:1px solid var(--border-soft);
}
.qa-title{font-size:.85rem;font-weight:800;color:var(--text);letter-spacing:.01em;text-transform:uppercase;}
.qa-close{
    background:var(--surface-alt);border:1px solid var(--border-soft);
    width:30px;height:30px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:.8rem;color:var(--text-2);
    transition:all .15s;
}
.qa-close:hover{background:var(--border-soft);color:var(--text)}
.qa-grid{
    display:grid;grid-template-columns:1fr 1fr;
    gap:6px;padding:10px 10px 6px;
}
.qa-item{
    display:flex;flex-direction:column;align-items:center;gap:7px;
    padding:14px 8px;border:1.5px solid var(--border-soft);
    border-radius:var(--r-md);background:var(--surface-alt);
    cursor:pointer;transition:all .15s var(--ease);
    font-size:.76rem;font-weight:700;color:var(--text-2);
    text-align:center;
}
.qa-item i{font-size:1.35rem;color:var(--text-2);transition:transform .18s var(--ease-spring)}
.qa-item:hover{background:var(--surface);border-color:var(--border);color:var(--text);box-shadow:var(--shadow-xs)}
.qa-item:hover i{transform:scale(1.15) translateY(-1px)}
.qa-item.qa-primary{
    background:var(--accent);
    border-color:transparent;color:#fff;
    box-shadow:0 4px 12px rgba(16,185,129,.28);
    grid-column:span 2;flex-direction:row;gap:10px;padding:14px 16px;
}
.qa-item.qa-primary i{color:#fff;font-size:1.1rem;}
.qa-item.qa-primary:hover{filter:brightness(1.05);transform:none;box-shadow:0 6px 18px rgba(16,185,129,.35)}

/* ══════════════ Business Context Sheet ═════════════ */
.biz-ctx-sheet-panel{
    position:fixed;bottom:0;left:0;right:0;z-index:350;
    max-width:480px;margin:0 auto;
    background:var(--surface);
    border-radius:var(--r-2xl) var(--r-2xl) 0 0;
    box-shadow:0 -20px 60px -10px rgba(15,23,42,.25);
    transform:translateY(100%);transition:transform .32s var(--ease-out);
    padding-bottom:max(var(--safe-b),env(safe-area-inset-bottom,16px));
}
.biz-ctx-sheet-panel.open{transform:translateY(0)}
.biz-ctx-biz-header{
    display:flex;align-items:center;gap:14px;
    padding:20px 20px 16px;
    border-bottom:1px solid var(--border-soft);
}
.biz-ctx-logo{
    width:52px;height:52px;border-radius:var(--r-md);
    background:var(--accent);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;flex-shrink:0;
    box-shadow:0 4px 12px rgba(16,185,129,.22);
}
.biz-ctx-logo-img{width:100%;height:100%;object-fit:cover}
.biz-ctx-logo-initial{color:#fff;font-size:1.4rem;font-weight:900;}
.biz-ctx-biz-info{flex:1;min-width:0;}
.biz-ctx-biz-name{font-size:1rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.biz-ctx-biz-cat{font-size:.78rem;color:var(--text-3);margin-top:2px;}
.biz-ctx-close{
    background:var(--surface-alt);border:1px solid var(--border-soft);
    width:34px;height:34px;border-radius:50%;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:.88rem;color:var(--text-2);transition:all .15s;
}
.biz-ctx-close:hover{background:var(--border-soft);color:var(--text)}
.biz-ctx-menu{padding:10px 12px 6px;display:flex;flex-direction:column;gap:4px;}
.biz-ctx-menu-item{
    width:100%;display:flex;align-items:center;gap:14px;
    padding:13px 12px;border:none;background:none;cursor:pointer;
    border-radius:var(--r-md);transition:background .15s;text-align:left;
}
.biz-ctx-menu-item:hover{background:var(--surface-hover)}
.biz-ctx-menu-icon{
    width:40px;height:40px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;flex-shrink:0;
}
.biz-ctx-menu-label{font-size:.88rem;font-weight:700;color:var(--text);}
.biz-ctx-menu-sub{font-size:.74rem;color:var(--text-3);margin-top:1px;}

/* ══════════════ Dashboard Business Card ════════════ */
.dash-biz-card{
    display:flex;align-items:center;gap:12px;
    padding:14px 16px;margin-bottom:16px;
    background:var(--surface);border:1.5px solid var(--border-soft);
    border-radius:var(--r-xl);cursor:pointer;
    transition:all .16s var(--ease);
    box-shadow:0 1px 4px rgba(15,23,42,.04);
}
.dash-biz-card:hover{border-color:var(--accent-ring);box-shadow:0 4px 16px rgba(16,185,129,.10);}
.dash-biz-logo{
    width:44px;height:44px;border-radius:var(--r-md);
    background:var(--accent);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;flex-shrink:0;
    box-shadow:0 3px 8px rgba(16,185,129,.2);
}
.dash-biz-logo-img{width:100%;height:100%;object-fit:cover}
.dash-biz-logo-initial{color:#fff;font-size:1.2rem;font-weight:900;}
.dash-biz-info{flex:1;min-width:0;}
.dash-biz-name{font-size:.92rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-biz-sub{font-size:.74rem;color:var(--text-3);margin-top:1px;}
.dash-biz-actions{display:flex;align-items:center;gap:6px;}
.dash-biz-caret{color:var(--text-3);font-size:.75rem;transition:transform .2s}
.dash-biz-card:hover .dash-biz-caret{transform:translateY(2px)}

/* ══════════════ Notification Improvements ══════════ */
.notif-unread{
    background:var(--accent-soft) !important;
    border-left:3px solid var(--accent) !important;
}
.notif-dot{
    width:8px;height:8px;background:var(--accent);
    border-radius:50%;flex-shrink:0;display:inline-block;
}
.notif-icon-wrap{
    width:38px;height:38px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;flex-shrink:0;margin-right:2px;
}
.notif-icon-wrap.badge-amber{background:var(--amber-soft);color:var(--amber)}
.notif-icon-wrap.badge-green{background:var(--green-soft);color:var(--green)}
.notif-icon-wrap.badge-blue{background:var(--blue-soft);color:var(--blue)}
.notif-icon-wrap.badge-red{background:var(--red-soft);color:var(--red)}
.notif-preview{
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    max-width:230px;font-size:.8rem;
}
.ann-detail-body{padding:4px 0 16px}
.ann-detail-meta{
    display:flex;align-items:center;gap:10px;margin-bottom:14px;
    padding-bottom:12px;border-bottom:1px solid var(--border-soft);
}
.ann-detail-message{
    font-size:.93rem;line-height:1.65;color:var(--text);
    white-space:pre-wrap;word-break:break-word;
}

/* ══════════════ Sidebar ════════════════════════════ */
.sidebar{
    position:fixed;top:0;left:-100%;bottom:0;
    width:var(--sidebar-w);background:var(--surface);
    z-index:200;transition:left .3s var(--ease-out);
    display:flex;flex-direction:column;
    box-shadow:var(--shadow-xl);
}
.sidebar.open{left:0}
.sidebar-overlay{
    position:fixed;inset:0;background:rgba(15,23,42,.4);
    z-index:199;opacity:0;visibility:hidden;
    transition:all .25s var(--ease);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.sidebar-overlay.open{opacity:1;visibility:visible}
.sidebar-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 22px 18px;border-bottom:1px solid var(--border-soft);
}
.sidebar-logo{
    font-family:var(--font-display);font-size:1.25rem;font-weight:800;
    color:var(--primary);letter-spacing:-.03em;
}
.sidebar-logo span{
    background:var(--accent);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.sidebar-close{
    background:var(--surface-alt);border:1px solid var(--border-soft);font-size:1rem;
    color:var(--text-2);cursor:pointer;width:34px;height:34px;border-radius:var(--r-full);
    display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.sidebar-close:hover{background:var(--border-light);color:var(--text)}
.sidebar-nav{flex:1;overflow-y:auto;padding:14px 10px 20px;scrollbar-width:thin}
.nav-item{
    display:flex;align-items:center;gap:12px;
    padding:10px 14px;border-radius:var(--r-sm);
    color:var(--text-2);text-decoration:none;
    font-size:.9rem;font-weight:500;transition:all .15s var(--ease);
    margin-bottom:2px;position:relative;
}
.nav-item i{font-size:1.05rem;width:20px;text-align:center;opacity:.75;flex-shrink:0}
.nav-item:hover{background:var(--surface-hover);color:var(--text)}
.nav-item.active{
    background:linear-gradient(90deg,var(--accent-soft),transparent);
    color:var(--accent-2);font-weight:600;
}
.nav-item.active i{opacity:1;color:var(--accent-2)}
.nav-item.active::before{
    content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;
    background:var(--accent);border-radius:0 3px 3px 0;
}
.nav-subitem{padding:9px 14px 9px 44px;font-size:.86rem}
.nav-subitem.active::before{display:none}
.nav-group{
    border-radius:var(--r-md);
    margin:4px 6px;overflow:hidden;
    border:1px solid transparent;
    background:transparent;
    transition:all .18s var(--ease);
}
.nav-group[open]{background:var(--surface-alt);border-color:var(--border-soft)}
.nav-group.active-group,
.nav-group.active-group[open]{
    border-color:var(--accent-ring);
    background:linear-gradient(180deg,var(--accent-soft),transparent);
    box-shadow:0 4px 12px rgba(16,185,129,.08);
}
.nav-group-summary{
    list-style:none;
    display:flex;align-items:center;gap:12px;
    padding:11px 14px;cursor:pointer;
    color:var(--text);font-size:.9rem;font-weight:600;
    transition:background .15s var(--ease);border-radius:var(--r-md);
}
.nav-group-summary:hover{background:var(--surface-hover)}
.nav-group[open] .nav-group-summary{background:transparent}
.nav-group.active-group .nav-group-summary{color:var(--accent-2)}
.nav-group.active-group .nav-group-summary i{opacity:1;color:var(--accent-2)}
.nav-group-summary::-webkit-details-marker{display:none}
.nav-group-summary i{font-size:1.05rem;width:20px;text-align:center;opacity:.75;flex-shrink:0}
.nav-group-caret{
    margin-left:auto;width:auto!important;opacity:.55;
    transition:transform .2s var(--ease);font-size:.8rem!important;
}
.nav-group[open] .nav-group-caret{transform:rotate(180deg)}
.nav-group-body{padding:4px 0 8px}

.info-banner{
    border:1px solid rgba(59,130,246,.2);
    background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(99,102,241,.05));
    border-radius:var(--r-lg);padding:14px 16px;
    display:flex;gap:12px;align-items:flex-start;
    color:var(--primary);margin-bottom:14px;
}
.info-banner i{color:var(--blue);font-size:1.2rem;margin-top:1px;flex-shrink:0}
.info-banner-title{font-weight:700;margin-bottom:2px;font-size:.92rem}
.info-banner-sub{color:var(--text-2);font-size:.85rem;line-height:1.5}

.nav-section{
    padding:14px 14px 8px;
    font-size:.7rem;font-weight:700;letter-spacing:.1em;
    text-transform:uppercase;color:var(--text-3);
}
.nav-divider{height:1px;background:var(--border-soft);margin:10px 14px}
.sidebar-footer{
    padding:14px 20px calc(14px + var(--safe-b));
    border-top:1px solid var(--border-soft);
    background:var(--surface-alt);
}

/* ══════════════ Bottom Nav ═════════════════════════ */
.bottom-nav{
    position:fixed;bottom:0;left:0;right:0;
    /* generous safe-area fallback: 20px for notched phones without env() support */
    height:calc(var(--bnav-h) + max(var(--safe-b), env(safe-area-inset-bottom, 20px)));
    padding:0 4px;
    padding-bottom:max(var(--safe-b), env(safe-area-inset-bottom, 20px));
    background:rgba(255,255,255,.95);
    backdrop-filter:saturate(180%) blur(20px);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    border-top:1px solid var(--divider);
    display:flex;justify-content:space-around;align-items:center;
    z-index:200; /* raised above modals backdrop for reliable tap */
    box-shadow:0 -4px 24px -4px rgba(15,23,42,.10);
    /* ensure items never get squeezed below minimum tap area */
    min-height:calc(60px + max(var(--safe-b), env(safe-area-inset-bottom, 20px)));
}
/* Push page content up so nothing hides behind nav */
@supports not (padding-bottom: env(safe-area-inset-bottom)) {
    .bottom-nav { height: calc(var(--bnav-h) + 20px); padding-bottom: 20px; }
    .page-content { padding-bottom: calc(var(--bnav-h) + 20px + 22px) !important; }
}
.bnav-item{
    display:flex;flex-direction:column;align-items:center;gap:3px;
    background:none;border:none;color:var(--text-3);
    font-size:.66rem;font-weight:600;cursor:pointer;
    padding:6px 10px;transition:all .18s var(--ease);
    border-radius:var(--r-sm);position:relative;
    flex:1;min-width:0;max-width:80px;
    min-height:44px;/* WCAG touch target */
}
.nav-badge{
    position:absolute;top:6px;right:10px;
    min-width:16px;height:16px;padding:0 5px;
    border-radius:999px;
    background:#ef4444;
    color:var(--surface);font-size:.65rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 2px 4px rgba(239,68,68,.3);
}
.bottom-nav .nav-badge{top:3px;right:14px}
.bnav-item i{font-size:1.25rem;transition:transform .22s var(--ease-spring)}
.bnav-item:hover{color:var(--text-2)}
.bnav-item.active{color:var(--accent-2)}
.bnav-item.active i{transform:scale(1.12) translateY(-1px)}
.bnav-item.active::before{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:26px;height:3px;
    background:var(--accent);
    border-radius:0 0 3px 3px;
}

/* ══════════════ Page Content ═══════════════════════ */
.page-content{
    margin-top:var(--topbar-h);
    padding:22px 16px calc(var(--bnav-h) + max(var(--safe-b), env(safe-area-inset-bottom, 20px)) + 28px);
    min-height:calc(100dvh - var(--topbar-h));
    animation:fadeUp .35s var(--ease-out);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ══════════════ Cards ══════════════════════════════ */
.card{
    background:var(--surface);border-radius:var(--r-lg);
    padding:20px;box-shadow:var(--shadow-sm);
    border:1px solid var(--border-soft);
    transition:all .2s var(--ease);
    position:relative;
}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--border)}
.card-title{
    font-size:.72rem;font-weight:700;color:var(--text-3);
    text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;
}
.card-value{
    font-family:var(--font-display);font-size:1.75rem;font-weight:800;
    color:var(--text);letter-spacing:-.025em;line-height:1.1;
}
.card-sub{font-size:.78rem;color:var(--text-3);margin-top:6px;font-weight:500;display:flex;align-items:center;gap:4px}
.card-sub.up{color:var(--accent-2)}
.card-sub.down{color:var(--red)}

.stat-grid{
    display:grid;grid-template-columns:repeat(2,1fr);
    gap:12px;margin-bottom:22px;
}
.stat-card{position:relative;overflow:hidden}
.stat-card::after{
    content:'';position:absolute;top:-20px;right:-20px;
    width:80px;height:80px;border-radius:50%;opacity:.06;
}
.stat-icon{
    position:absolute;top:16px;right:16px;
    width:42px;height:42px;border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    font-size:1.05rem;
}
.stat-icon.teal{background:var(--accent-soft);color:var(--accent-2)}
.stat-icon.amber{background:var(--amber-soft);color:var(--amber)}
.stat-icon.red{background:var(--red-soft);color:var(--red)}
.stat-icon.blue{background:var(--blue-soft);color:var(--blue)}
.stat-icon.green{background:var(--green-soft);color:var(--green)}
.stat-icon.violet{background:var(--violet-soft);color:var(--violet)}
.stat-icon.indigo{background:var(--indigo-soft);color:var(--indigo)}

/* ══════════════ Packages ═══════════════════════════ */
.packages-grid{display:flex;flex-direction:column;gap:14px}
.package-card{
    background:var(--surface);border-radius:var(--r-lg);
    padding:26px;border:1.5px solid var(--border);
    transition:all .22s var(--ease);cursor:pointer;
    position:relative;
}
.package-card:hover{
    border-color:var(--accent);
    box-shadow:var(--shadow-md);
    transform:translateY(-2px);
}
.package-card.popular{
    border-color:var(--accent);
    box-shadow:0 0 0 1px var(--accent),var(--shadow-md);
    background:
        linear-gradient(180deg,var(--accent-soft),transparent 40%),
        var(--surface);
}
.package-card.popular::before{
    content:'★ Most Popular';display:inline-block;
    background:var(--accent);
    color:var(--text-inv);
    font-size:.7rem;font-weight:700;padding:5px 14px;
    border-radius:var(--r-full);margin-bottom:14px;letter-spacing:.02em;
    box-shadow:0 4px 12px rgba(16,185,129,.3);
}
.package-name{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text);letter-spacing:-.01em}
.package-price{
    font-family:var(--font-display);font-size:2.2rem;font-weight:900;color:var(--text);
    margin:10px 0;letter-spacing:-.03em;line-height:1;
}
.package-price span{font-size:.85rem;font-weight:500;color:var(--text-3)}
.package-features{list-style:none;padding:0;margin:18px 0}
.package-features li{
    padding:8px 0;font-size:.88rem;color:var(--text-2);
    display:flex;align-items:center;gap:10px;font-weight:500;
    border-bottom:1px solid var(--border-soft);
}
.package-features li:last-child{border-bottom:none}
.package-features li i{color:var(--accent);font-size:.95rem;flex-shrink:0}
.package-features li.disabled{color:var(--text-3);opacity:.55}
.package-features li.disabled i{color:var(--text-3)}

/* ══════════════ Data List ══════════════════════════ */
.data-list{display:flex;flex-direction:column;gap:8px}
.data-item{
    background:var(--surface);border-radius:var(--r-md);
    padding:14px 16px;
    display:flex;justify-content:space-between;align-items:center;
    cursor:pointer;transition:all .15s var(--ease);
    box-shadow:var(--shadow-xs);border:1px solid var(--border-soft);
}
.data-item:hover{
    box-shadow:var(--shadow-md);transform:translateY(-1px);
    border-color:var(--border);
}
.data-item:active{transform:translateY(0)}
.data-item-left{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.data-item-title{
    font-weight:600;font-size:.92rem;color:var(--text);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.data-item-sub{font-size:.78rem;color:var(--text-3);font-weight:500}
.data-item-right{text-align:right;flex-shrink:0;margin-left:12px}
.data-item-amount{
    font-family:var(--font-display);font-weight:700;font-size:1rem;
    color:var(--text);letter-spacing:-.015em;
}

.badge{
    display:inline-flex;align-items:center;gap:4px;
    padding:3px 10px;border-radius:var(--r-full);
    font-size:.7rem;font-weight:700;letter-spacing:.02em;
    line-height:1.5;
}
.badge-green{background:var(--green-soft);color:var(--accent-2);border:1px solid var(--accent-ring)}
.badge-amber{background:var(--amber-soft);color:#b45309;border:1px solid rgba(245,158,11,.25)}
.badge-red{background:var(--red-soft);color:#b91c1c;border:1px solid rgba(239,68,68,.25)}
.badge-blue{background:var(--blue-soft);color:#1d4ed8;border:1px solid rgba(59,130,246,.25)}
.badge-violet{background:var(--violet-soft);color:#6d28d9;border:1px solid rgba(139,92,246,.25)}

/* ══════════════ Page Header ════════════════════════ */
.page-header{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:22px;gap:12px;flex-wrap:wrap;
}
.page-title{
    font-family:var(--font-display);font-size:1.5rem;
    font-weight:800;color:var(--text);letter-spacing:-.025em;line-height:1.15;
}

/* ══════════════ Modal ══════════════════════════════ */
.modal-overlay{
    position:fixed;inset:0;background:rgba(15,23,42,.48);
    z-index:2500;display:flex;align-items:flex-end;
    justify-content:center;opacity:0;visibility:hidden;
    transition:all .28s var(--ease);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{
    background:var(--surface);
    border-radius:var(--r-2xl) var(--r-2xl) 0 0;
    width:100%;max-width:560px;max-height:90dvh;
    overflow-y:auto;padding:26px 24px calc(26px + var(--safe-b));
    transform:translateY(100%);transition:transform .38s var(--ease-out);
    box-shadow:0 -20px 60px -10px rgba(15,23,42,.3);
}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-header{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--border-soft);
    position:sticky;top:0;background:var(--surface);padding-top:2px;z-index:2;
}
.modal-title{
    font-family:var(--font-display);font-size:1.15rem;font-weight:800;
    color:var(--text);letter-spacing:-.015em;
}
.modal-close{
    background:var(--surface-alt);border:1px solid var(--border-soft);
    font-size:1rem;color:var(--text-2);cursor:pointer;
    width:36px;height:36px;border-radius:var(--r-full);
    display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.modal-close:hover{background:var(--border-light);color:var(--text)}

/* ══════════════ Help / Info Modals ═════════════════ */
/* Contextual "?" trigger button */
.help-trigger{
    display:inline-flex;align-items:center;justify-content:center;
    width:32px;height:32px;border-radius:50%;
    background:var(--surface-alt);border:1px solid var(--border-soft);
    color:var(--text-3);cursor:pointer;font-size:.95rem;
    transition:all .15s;flex-shrink:0;
}
.help-trigger:hover{background:var(--accent-soft);border-color:var(--accent-ring);color:var(--accent);}

/* Help modal body */
.modal-help-body{padding-bottom:12px;}
.help-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:16px;}
.help-step{
    display:flex;align-items:flex-start;gap:14px;
    padding:14px;background:var(--surface-alt);
    border-radius:var(--r-md);border:1px solid var(--border-soft);
}
.help-step-num{
    width:28px;height:28px;border-radius:50%;flex-shrink:0;
    background:var(--accent);
    color:#fff;font-size:.8rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
}
.help-step strong{display:block;font-size:.9rem;color:var(--text);margin-bottom:3px;}
.help-step div:last-child{font-size:.85rem;color:var(--text-2);line-height:1.5;}
.help-note{
    display:flex;align-items:flex-start;gap:10px;
    padding:12px 14px;border-radius:var(--r-sm);
    background:var(--accent-soft);
    font-size:.83rem;color:var(--text-2);line-height:1.55;
}
.help-note i{color:var(--accent);font-size:1rem;margin-top:1px;flex-shrink:0;}
.help-list{
    padding-left:0;margin:0 0 16px;list-style:none;
    display:flex;flex-direction:column;gap:10px;
}
.help-list li{
    padding:10px 14px;background:var(--surface-alt);
    border-radius:var(--r-sm);border:1px solid var(--border-soft);
    font-size:.86rem;color:var(--text-2);line-height:1.5;
}
.help-list li strong{color:var(--text);font-weight:700;}

/* ── Auth "How it works" steps ────────────────────── */
.auth-how-steps{
    display:flex;gap:0;justify-content:center;
    margin:22px 0 0;padding:18px;
    background:rgba(16,185,129,.06);border-radius:var(--r-lg);
    border:1px solid rgba(16,185,129,.12);
}
.auth-how-step{
    display:flex;flex-direction:column;align-items:center;
    text-align:center;flex:1;gap:6px;padding:0 8px;
    position:relative;
}
.auth-how-step:not(:last-child)::after{
    content:'';position:absolute;right:-1px;top:16px;
    height:20px;width:1px;background:rgba(16,185,129,.2);
}
.auth-how-num{
    width:28px;height:28px;border-radius:50%;
    background:var(--accent);
    color:#fff;font-size:.75rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
}
.auth-how-label{font-size:.72rem;font-weight:600;color:var(--text-2);}

/* ══════════════ Empty State ════════════════════════ */
.empty-state{
    text-align:center;padding:56px 24px;color:var(--text-3);
    background:var(--surface);border-radius:var(--r-lg);
    border:1px dashed var(--border);
}
.empty-state i{
    font-size:2.8rem;margin-bottom:14px;display:block;
    color:var(--text-3);opacity:.5;
}
.empty-state h3{
    font-family:var(--font-display);font-size:1.05rem;
    color:var(--text);margin-bottom:6px;font-weight:700;
}
.empty-state p{font-size:.88rem;font-weight:500;max-width:40ch;margin:0 auto}

/* ══════════════ Toast ══════════════════════════════ */
.toast{
    position:fixed;bottom:calc(var(--bnav-h) + var(--safe-b) + 18px);
    left:50%;transform:translateX(-50%) translateY(100px);
    background:var(--primary);color:var(--text-inv);
    padding:12px 22px;border-radius:var(--r-full);
    font-size:.88rem;font-weight:600;z-index:500;
    opacity:0;transition:all .32s var(--ease-spring);
    white-space:nowrap;box-shadow:var(--shadow-xl);max-width:90%;
    letter-spacing:.005em;
    display:inline-flex;align-items:center;gap:8px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{background:#ef4444}
.toast.success{background:var(--accent)}

/* ══════════════ Search Bar ═════════════════════════ */
.search-bar{
    display:flex;align-items:center;gap:10px;
    background:var(--surface);border:1.5px solid var(--border);
    border-radius:var(--r-sm);padding:0 14px;margin-bottom:16px;
    transition:all .18s var(--ease);box-shadow:var(--shadow-xs);
}
.search-bar:hover{border-color:var(--text-3)}
.search-bar:focus-within{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-soft);
}
.search-bar i{color:var(--text-3);font-size:1rem}
.search-bar input{
    flex:1;border:none;outline:none;padding:12px 0;
    font-size:.92rem;background:transparent;color:var(--text);font-weight:500;
}

/* ══════════════ Product Grid ═══════════════════════ */
.product-grid{
    display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
.product-card{
    background:var(--surface);border-radius:var(--r-md);
    overflow:hidden;cursor:pointer;
    transition:all .22s var(--ease);
    box-shadow:var(--shadow-xs);border:1px solid var(--border-soft);
    display:flex;flex-direction:column;
}
.product-card:hover{
    box-shadow:var(--shadow-lg);
    transform:translateY(-3px);border-color:var(--border);
}
.product-card:active{transform:translateY(0)}
.product-img{
    width:100%;aspect-ratio:1;object-fit:cover;
    background:var(--surface-alt);
}
.product-info{padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.product-name{
    font-weight:600;font-size:.88rem;color:var(--text);line-height:1.4;
    line-clamp:2;-webkit-line-clamp:2;display:-webkit-box;
    -webkit-box-orient:vertical;overflow:hidden;
}
.product-price{
    font-family:var(--font-display);font-size:1rem;font-weight:800;
    color:var(--accent-2);margin-top:4px;letter-spacing:-.015em;
}
.product-store{font-size:.72rem;color:var(--text-3);margin-top:2px;font-weight:500}
.product-stock{
    font-size:.68rem;padding:3px 8px;border-radius:var(--r-full);
    display:inline-block;margin-top:6px;font-weight:700;align-self:flex-start;
}

body.mp2 .product-info{padding:10px 12px;gap:3px}
body.mp2 .product-name{font-size:.82rem}
body.mp2 .product-price{font-size:.92rem}
body.mp2 .product-store{font-size:.68rem}

@media (min-width: 768px){
    body.mp2 .product-grid{grid-template-columns:repeat(3,1fr)}
}

@media (min-width: 992px){
    body.mp2 .product-grid{grid-template-columns:repeat(4,1fr);gap:14px}
}

@media (min-width: 1200px){
    body.mp2 .product-grid{grid-template-columns:repeat(5,1fr)}
}

/* ══════════════ Tab Bar ════════════════════════════ */
.tab-bar{
    display:flex;gap:4px;background:var(--surface-alt);
    border-radius:var(--r-sm);padding:4px;margin-bottom:18px;
    border:1px solid var(--border-soft);
}
.tab-bar button{
    flex:1;padding:9px 14px;border:none;background:transparent;
    font-size:.84rem;font-weight:600;color:var(--text-2);
    cursor:pointer;border-radius:7px;transition:all .2s var(--ease);
}
.tab-bar button:hover{color:var(--text)}
.tab-bar button.active{
    background:var(--surface);color:var(--text);
    box-shadow:var(--shadow-xs);
}

/* ══════════════ Section Label ══════════════════════ */
.section-label{
    font-size:.74rem;font-weight:700;color:var(--text-3);
    text-transform:uppercase;letter-spacing:.08em;
    margin-bottom:12px;margin-top:8px;
}

/* ══════════════ Avatar Large ═══════════════════════ */
.avatar-lg{
    width:88px;height:88px;border-radius:var(--r-full);
    background:var(--accent);
    color:var(--text-inv);display:flex;align-items:center;
    justify-content:center;font-size:2rem;font-weight:700;
    overflow:hidden;
    box-shadow:0 8px 24px rgba(16,185,129,.28),inset 0 1px 0 rgba(255,255,255,.2);
}
.avatar-lg img{width:100%;height:100%;object-fit:cover}

/* ══════════════ Utility ════════════════════════════ */
.text-teal,.text-accent{color:var(--accent-2)!important}
.text-red{color:var(--red)!important}
.text-green{color:var(--green)!important}
.text-muted{color:var(--text-3)!important}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}
.flex{display:flex}
.flex-between{display:flex;justify-content:space-between;align-items:center;gap:12px}
.spin{animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══════════════ Skeleton Loading ═══════════════════ */
.skeleton{
    background:linear-gradient(90deg,var(--border-light) 25%,var(--surface) 50%,var(--border-light) 75%);
    background-size:200% 100%;animation:shimmer 1.6s infinite ease-in-out;
    border-radius:var(--r-md);
}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

.page-loader{margin-top:6px}
.page-loader-bar{
    height:3px;border-radius:999px;
    background:rgba(16,185,129,.12);overflow:hidden;
}
.page-loader-bar-inner{
    height:100%;width:40%;
    background:linear-gradient(90deg,rgba(16,185,129,.2),rgba(16,185,129,.85),rgba(16,185,129,.2));
    animation:pagebar 1.2s infinite var(--ease);
}
@keyframes pagebar{0%{transform:translateX(-120%)}100%{transform:translateX(320%)}}
.page-loader-body{display:flex;align-items:center;gap:12px;padding:16px 4px}
.page-loader-icon{
    width:36px;height:36px;border-radius:12px;
    background:var(--accent-soft);display:flex;align-items:center;justify-content:center;
    color:var(--accent-2);
}
.page-loader-text{color:var(--text-2);font-size:.92rem;font-weight:600}

/* ══════════════ Tablet & Desktop ═══════════════════ */
@media(max-width:767px){
    input,textarea,select{font-size:16px}

    /* On mobile, biz picker and quick actions become bottom sheets */
    .biz-picker-panel{
        position:fixed;top:auto;left:0;right:0;bottom:0;
        width:100%;border-radius:var(--r-2xl) var(--r-2xl) 0 0;
        border:none;border-top:1px solid var(--border-soft);
        transform:translateY(100%) !important;
        opacity:1 !important;
        transition:transform .3s var(--ease-out);
        pointer-events:none;
        padding-bottom:max(var(--safe-b),env(safe-area-inset-bottom,16px));
    }
    .biz-picker-panel.open{transform:translateY(0) !important;pointer-events:all}
    .biz-picker-list{max-height:45dvh}

    .quick-actions-panel{
        position:fixed;top:auto;left:0;right:0;bottom:0;
        width:100%;border-radius:var(--r-2xl) var(--r-2xl) 0 0;
        border:none;border-top:1px solid var(--border-soft);
        transform:translateY(100%) !important;
        opacity:1 !important;
        transition:transform .3s var(--ease-out);
        pointer-events:none;
        padding-bottom:max(var(--safe-b),env(safe-area-inset-bottom,16px));
    }
    .quick-actions-panel.open{transform:translateY(0) !important;pointer-events:all}
    .qa-grid{grid-template-columns:repeat(4,1fr);gap:8px;padding:12px}
    .qa-item{padding:12px 6px;font-size:.7rem;}
    .qa-item i{font-size:1.25rem;}
    .qa-item.qa-primary{grid-column:span 4;flex-direction:row;}

    /* Biz picker name truncate tighter */
    .biz-picker-name{max-width:90px;}

    /* Notif preview shorter on mobile */
    .notif-preview{max-width:180px;}
}

@media(min-width:768px){
    :root{--topbar-h:68px}
    .sidebar{
        left:0;position:fixed;top:var(--topbar-h);bottom:0;
        box-shadow:none;
        border-right:1px solid var(--border-soft);
        background:var(--surface);
    }
    .sidebar-header,.sidebar-close{display:none}
    .sidebar-overlay{display:none}
    .menu-toggle{display:none}
    .menu-fab{display:none!important}
    .bottom-nav{display:none}
    .page-content{
        margin-left:var(--sidebar-w);
        padding:28px 32px 40px;
        max-width:none;
    }
    .page-content > *{max-width:var(--container);margin-left:auto;margin-right:auto}
    .btn-fab{bottom:28px;right:28px}
    .stat-grid{grid-template-columns:repeat(4,1fr);gap:16px}
    .product-grid{grid-template-columns:repeat(3,1fr);gap:16px}
    .modal{
        border-radius:var(--r-xl);
        max-width:560px;padding:28px;
    }
    .modal-overlay{align-items:center;padding:24px}
    .page-title{font-size:1.7rem}
    .card{padding:22px}
    .card-value{font-size:1.9rem}
    .topbar{padding:0 24px}
}

@media(min-width:768px){
    body.pos-fullscreen .page-content{
        margin-left:0!important;
    }
    body.pos-fullscreen .page-content > *{
        max-width:none!important;
        margin-left:0!important;
        margin-right:0!important;
    }
}

@media(min-width:1024px){
    :root{--sidebar-w:280px}
    .product-grid{grid-template-columns:repeat(4,1fr)}
    .page-content{padding:32px 40px 44px}
    /* Wider biz picker on desktop */
    .biz-picker-panel{width:280px}
    .biz-picker-name{max-width:160px}
    /* QA panel: 4-col grid on large screens */
    .qa-grid{grid-template-columns:repeat(4,1fr)}
    .qa-item.qa-primary{grid-column:span 4}
    /* Business context sheet: centered card on desktop */
    .biz-ctx-sheet-panel{
        max-width:420px;
        border-radius:var(--r-2xl);
        bottom:auto;top:50%;left:50%;
        transform:translate(-50%,-50%) scale(.95);
        transition:transform .28s var(--ease-out), opacity .28s;
        opacity:0;pointer-events:none;
    }
    .biz-ctx-sheet-panel.open{
        transform:translate(-50%,-50%) scale(1);
        opacity:1;pointer-events:all;
    }
}

@media(min-width:1280px){
    .page-content > *{max-width:var(--container)}
}

/* ══════════════ Print ═════════════════════════════ */
@media print{
    .topbar,.sidebar,.bottom-nav,.btn-fab,.sidebar-overlay,.menu-fab{display:none!important}
    .page-content{margin:0;padding:0}
    body{background:#fff}
}

/* ══════════════════════════════════════════════════ */
/* Marketplace                                         */
/* ══════════════════════════════════════════════════ */
body.mp-page{background:var(--bg-warm)}
body.mp2{background:var(--bg);padding-bottom:calc(var(--bnav-h) + var(--safe-b))}

.mp2-topbar{
    position:fixed;top:0;left:0;right:0;z-index:140;
    background:rgba(255,255,255,.9);
    backdrop-filter:saturate(180%) blur(16px);
    -webkit-backdrop-filter:saturate(180%) blur(16px);
    border-bottom:1px solid var(--divider);
    padding-top:var(--safe-t);
}
.mp2-topbar-inner{
    max-width:var(--container-lg);margin:0 auto;
    height:var(--topbar-h);
    display:flex;align-items:center;gap:12px;
    padding:0 14px;
}
.mp2-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.mp2-brand-mark{
    width:34px;height:34px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    background:var(--accent);
    color:var(--text-inv);font-family:var(--font-display);
    font-weight:900;letter-spacing:-.04em;font-size:1.05rem;
    box-shadow:0 8px 20px rgba(16,185,129,.25),inset 0 1px 0 rgba(255,255,255,.2);
}
.mp2-brand-text{font-family:var(--font-display);font-weight:900;color:var(--primary);letter-spacing:-.03em;font-size:.98rem}
.mp2-search{
    flex:1;display:flex;align-items:center;gap:10px;
    background:var(--surface);
    border:1.5px solid var(--border-soft);
    border-radius:999px;
    padding:10px 14px;
    transition:all .18s var(--ease);
    box-shadow:var(--shadow-xs);
}
.mp2-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.mp2-search i{color:var(--text-3)}
.mp2-search input{border:none;outline:none;background:transparent;width:100%;font-size:.9rem;font-weight:600}
.mp2-icon-btn{
    width:44px;height:44px;border-radius:14px;
    border:1px solid var(--border-soft);
    background:var(--surface);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .18s var(--ease);
    box-shadow:var(--shadow-xs);color:var(--text-2);
    position:relative;
}
.mp2-icon-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);color:var(--text);border-color:var(--border)}
.mp2-wish-btn{width:40px;height:40px;border-radius:14px}
.mp2-wish-btn i{color:var(--text-3)}
.mp2-wish-btn.active{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.08)}
.mp2-wish-btn.active i{color:#ef4444}
.mp2-badge{
    position:absolute;top:-6px;right:-6px;
    min-width:20px;height:20px;padding:0 6px;
    border-radius:999px;
    background:var(--accent);
    color:var(--text-inv);font-size:.68rem;font-weight:900;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--surface);
    box-shadow:0 2px 6px rgba(16,185,129,.35);
}

.mp2-view{
    padding-top:calc(var(--topbar-h) + var(--safe-t));
    padding-bottom:calc(var(--bnav-h) + var(--safe-b) + 16px);
}
.mp2-bottom-nav{
    position:fixed;left:0;right:0;bottom:0;z-index:150;
    height:calc(var(--bnav-h) + var(--safe-b));
    padding-bottom:var(--safe-b);
    background:rgba(255,255,255,.92);
    backdrop-filter:saturate(180%) blur(16px);
    -webkit-backdrop-filter:saturate(180%) blur(16px);
    border-top:1px solid var(--divider);
    display:flex;align-items:center;
}
.mp2-desktop-only{display:none}

@media (min-width: 992px){
    body.mp2{padding-bottom:0}
    .mp2-bottom-nav{display:none}
    .mp2-desktop-only{display:flex}
    .mp2-view{padding-bottom:24px}
    .mp-filter-fab{display:none}
}
.mp2-nav-item{
    flex:1;border:none;background:transparent;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:4px;padding:10px 6px;
    color:var(--text-3);
    font-weight:800;font-size:.72rem;
}
.mp2-nav-item i{font-size:1.25rem}
.mp2-nav-item.active{color:var(--primary)}
.mp2-nav-item.active i{color:var(--accent-2)}

.mp2-page{max-width:var(--container-lg);margin:0 auto}
.mp2-pad{padding:12px 14px 0}
.mp2-section{padding:0 14px}
.mp2-rowhead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:12px 0 8px}
.mp2-rowtitle{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.02rem}
.mp2-h1{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.2rem;margin-bottom:10px}
.mp2-select{border:1px solid var(--border-soft);background:var(--surface);border-radius:12px;padding:8px 10px;font-weight:800;font-size:.82rem}
.mp2-more{margin-top:12px}

.mp2-chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}
.mp2-chip-row::-webkit-scrollbar{display:none}
.mp2-chip{
    border:1px solid var(--border-soft);
    background:var(--surface);
    border-radius:999px;
    padding:8px 12px;
    font-weight:900;font-size:.78rem;
    display:inline-flex;align-items:center;gap:7px;
    white-space:nowrap;
    box-shadow:var(--shadow-xs);
}
.mp2-chip.active{background:var(--accent-soft);border-color:rgba(16,185,129,.25);color:var(--accent-2)}

.mp2-back{border:none;background:transparent;color:var(--text-2);font-weight:800;display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px}
.mp2-back:hover{background:rgba(15,23,42,.04);color:var(--text)}

.mp2-banner{
    margin:14px 14px 0;
    padding:12px 14px;
    border-radius:16px;
    border:1px solid var(--border-soft);
    background:linear-gradient(180deg,rgba(16,185,129,.12),rgba(16,185,129,.06));
    display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.mp2-banner-title{font-weight:900;color:var(--primary);display:flex;align-items:center;gap:8px}
.mp2-banner-sub{color:var(--text-2);font-weight:700;font-size:.86rem;margin-top:2px}

.mp2-img-ph{
    background:var(--surface-alt);
    border:1px solid var(--border-soft);
    border-radius:14px;
    display:flex;align-items:center;justify-content:center;
    color:var(--text-3);
}
.mp2-img-square{aspect-ratio:1;border-radius:0}
.mp2-img-hero{height:280px}
.mp2-img-thumb{width:64px;height:64px;border-radius:14px}

.mp2-card-badges{position:absolute;left:10px;top:10px;display:flex;gap:8px;align-items:center}
.mp2-badge-pill{
    display:inline-flex;align-items:center;gap:6px;
    background:rgba(15,23,42,.72);
    color:#fff;border-radius:999px;
    padding:4px 10px;
    font-size:.72rem;font-weight:900;
}
.mp2-rating{
    display:inline-flex;align-items:center;gap:5px;
    background:rgba(255,255,255,.9);
    border:1px solid rgba(15,23,42,.10);
    color:var(--primary);
    border-radius:999px;
    padding:4px 10px;
    font-size:.72rem;font-weight:900;
}
.mp2-card-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.mp2-rating-lg{display:inline-flex;align-items:center;gap:6px;font-weight:900;color:var(--primary)}
.mp2-rating-sub{color:var(--text-3);font-weight:800}

.mp2-cats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.mp2-cat-tile{
    border:1px solid var(--border-soft);
    background:var(--surface);
    border-radius:16px;
    padding:14px;
    text-align:left;
    box-shadow:var(--shadow-xs);
    transition:all .18s var(--ease);
}
.mp2-cat-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border)}
.mp2-cat-ic{width:42px;height:42px;border-radius:14px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent-2);font-size:1.2rem}
.mp2-cat-name{margin-top:10px;font-weight:900;color:var(--primary);letter-spacing:-.01em}
.mp2-cat-sub{margin-top:4px;color:var(--text-3);font-weight:800;font-size:.78rem}

.mp2-stores-grid{display:flex;flex-direction:column;gap:12px}
.mp2-store-tile{
    border:1px solid var(--border-soft);
    background:var(--surface);
    border-radius:18px;
    overflow:hidden;
    box-shadow:var(--shadow-xs);
    text-align:left;
    transition:all .18s var(--ease);
}
.mp2-store-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border)}
.mp2-store-banner{height:72px;background:linear-gradient(135deg,var(--indigo-soft),var(--accent-soft));background-size:cover;background-position:center}
.mp2-store-body{display:flex;gap:12px;padding:12px 14px 14px;align-items:flex-start}
.mp2-store-logo{width:54px;height:54px;border-radius:18px;background:var(--surface-alt);border:1px solid var(--border-soft);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mp2-store-logo img{width:100%;height:100%;object-fit:cover}
.mp2-store-meta{min-width:0}
.mp2-store-name{font-weight:900;color:var(--primary);letter-spacing:-.02em;display:flex;align-items:center;gap:8px}
.mp2-store-sub{margin-top:4px;color:var(--text-2);font-weight:600;font-size:.84rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mp2-store-foot{margin-top:8px;color:var(--text-3);font-weight:900;font-size:.78rem}

.mp2-store-hero{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border-soft);background:var(--surface);border-radius:18px;padding:14px;box-shadow:var(--shadow-xs)}
.mp2-store-hero-logo{width:64px;height:64px;border-radius:18px;border:1px solid var(--border-soft);background:var(--surface-alt);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mp2-store-hero-logo img{width:100%;height:100%;object-fit:cover}
.mp2-store-hero-meta{min-width:0}
.mp2-store-hero-name{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.15rem;display:flex;align-items:center;gap:8px}
.mp2-store-hero-sub{margin-top:4px;color:var(--text-2);font-weight:600;font-size:.88rem}
.mp2-store-hero-tags{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.mp2-tag{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-soft);background:rgba(15,23,42,.03);padding:6px 10px;border-radius:999px;color:var(--text-2);font-weight:900;font-size:.74rem}
.mp2-tag-featured{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.22);color:#b45309}
.mp2-store-link{border:none;background:transparent;color:var(--text);font-weight:900;display:inline-flex;align-items:center;gap:8px;padding:0}
.mp2-store-link:hover{color:var(--accent-2)}

.mp2-product-card{border:1px solid var(--border-soft);background:var(--surface);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-xs)}
.mp2-product-body{padding:14px}
.mp2-product-title{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.12rem;line-height:1.2}
.mp2-product-price{font-family:var(--font-display);font-weight:900;color:var(--accent-2);font-size:1.15rem}
.mp2-product-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.mp2-product-subrow{margin-top:8px;display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}
.mp2-product-tags{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.mp2-product-desc{margin-top:12px;color:var(--text-2);font-weight:500;line-height:1.6}
.mp2-atc{margin-top:14px;display:flex;gap:10px;align-items:center}
.mp2-qty{display:flex;align-items:center;border:1px solid var(--border-soft);border-radius:14px;overflow:hidden;background:var(--surface-alt)}
.mp2-qty-btn{width:38px;height:38px;border:none;background:transparent;font-weight:900;color:var(--primary);font-size:1.1rem}
.mp2-qty-input{width:46px;height:38px;border:none;background:transparent;text-align:center;font-weight:900}
.mp2-atc-btn{flex:1}

.mp2-cart-item{display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:start}
.mp2-cart-item-main{min-width:0}
.mp2-cart-qty-input{width:46px}
.mp2-checkout{margin-top:18px}
.mp2-muted{margin-top:6px;color:var(--text-3);font-weight:700;font-size:.8rem}

.mp2-card{border:1px solid var(--border-soft);background:var(--surface);border-radius:18px;padding:14px;box-shadow:var(--shadow-xs)}
.mp2-card-title{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.08rem}
.mp2-card-sub{margin-top:4px;color:var(--text-2);font-weight:600;font-size:.88rem}
.mp2-account-top{display:flex;gap:12px;align-items:center}
.mp2-avatar{width:44px;height:44px;border-radius:16px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-family:var(--font-display)}
.mp2-account-meta{min-width:0}
.mp2-account-name{font-weight:900;color:var(--primary)}
.mp2-account-sub{margin-top:2px;color:var(--text-3);font-weight:800;font-size:.8rem}
.mp2-orders{margin-top:10px;display:flex;flex-direction:column;gap:10px}
.mp2-order{border:1px solid var(--border-soft);border-radius:16px;padding:12px;background:var(--surface-alt)}
.mp2-order-row{display:flex;justify-content:space-between;gap:10px;align-items:center}
.mp2-order-ref{font-weight:900;color:var(--primary)}
.mp2-order-amt{font-weight:900;color:var(--accent-2);font-family:var(--font-display)}
.mp2-order-sub{margin-top:6px;color:var(--text-2);font-weight:700;font-size:.82rem;display:flex;gap:10px;flex-wrap:wrap}

.mp2-empty{text-align:center;padding:28px 14px;border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.7)}
.mp2-empty-ic{width:52px;height:52px;border-radius:18px;background:var(--surface-alt);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;color:var(--text-3);font-size:1.4rem}
.mp2-empty-title{font-weight:900;color:var(--primary);font-size:1.05rem}
.mp2-empty-sub{margin-top:6px;color:var(--text-2);font-weight:600;font-size:.88rem;margin-bottom:14px}

.mp2-home-grid{display:grid;grid-template-columns:1fr;gap:16px;padding:0 14px}
.mp2-col{min-width:0}
.mp2-side-card{border:1px solid var(--border-soft);background:var(--surface);border-radius:18px;padding:14px;box-shadow:var(--shadow-xs)}
.mp2-side-title{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center}
.mp2-side-list{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.mp2-side-link{border:1px solid var(--border-soft);background:var(--surface-alt);border-radius:14px;padding:10px 12px;font-weight:900;color:var(--primary);display:flex;justify-content:space-between;align-items:center;gap:10px}
.mp2-side-link:hover{border-color:var(--border);background:var(--surface);box-shadow:var(--shadow-xs)}
.mp2-side-sub{color:var(--text-3);font-weight:900;font-size:.75rem}

@media (min-width: 992px){
    .mp2-home-grid{grid-template-columns:280px 1fr 320px;align-items:start}
    .mp2-section{padding:0}
    .mp2-pad{padding:12px 0 0}
    .mp2-page{padding:0 20px}
    .mp2-topbar-inner{padding:0 20px}
}

@media (min-width: 768px){
    .product-grid{grid-template-columns:repeat(3,1fr)}
}
@media (min-width: 1100px){
    .product-grid{grid-template-columns:repeat(4,1fr);gap:14px}
}

.mp2-card-atc{
    position:absolute;right:10px;bottom:10px;
    width:38px;height:38px;border-radius:14px;
    border:1px solid rgba(15,23,42,.10);
    background:rgba(255,255,255,.92);
    backdrop-filter: blur(10px);
    display:flex;align-items:center;justify-content:center;
    color:var(--primary);
}
.mp2-card-atc:hover{background:var(--accent);border-color:rgba(16,185,129,.25);color:#fff}

.mp-topbar{
    position:sticky;top:0;z-index:120;
    background:rgba(255,255,255,.85);
    backdrop-filter:saturate(180%) blur(18px);
    -webkit-backdrop-filter:saturate(180%) blur(18px);
    border-bottom:1px solid var(--divider);
}
.mp-topbar-inner{
    max-width:var(--container-lg);margin:0 auto;
    height:76px;padding:0 20px;
    display:flex;align-items:center;gap:14px;
}
.mp-brand{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.mp-brand-mark{
    width:40px;height:40px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    background:var(--accent);
    color:var(--text-inv);font-family:var(--font-display);
    font-weight:900;letter-spacing:-.04em;font-size:1.2rem;
    box-shadow:0 8px 20px rgba(16,185,129,.25),inset 0 1px 0 rgba(255,255,255,.2);
}
.mp-brand-text{
    font-family:var(--font-display);font-weight:900;
    color:var(--primary);letter-spacing:-.03em;font-size:1.05rem;
}
.mp-search{
    flex:1;display:flex;align-items:center;gap:10px;
    background:var(--surface);
    border:1.5px solid var(--border-soft);
    border-radius:var(--r-md);padding:11px 14px;
    transition:all .18s var(--ease);
    box-shadow:var(--shadow-xs);
}
.mp-search:focus-within{
    border-color:var(--accent);
    box-shadow:0 0 0 4px var(--accent-soft);
}
.mp-search i{color:var(--text-3)}
.mp-search input{
    border:none;outline:none;background:transparent;
    width:100%;font-size:.92rem;font-weight:500;
}
.mp-actions{display:flex;align-items:center;gap:8px}
.mp-icon-btn{
    width:44px;height:44px;border-radius:var(--r-md);
    border:1px solid var(--border-soft);
    background:var(--surface);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .18s var(--ease);
    box-shadow:var(--shadow-xs);color:var(--text-2);
}
.mp-icon-btn:hover{
    transform:translateY(-1px);box-shadow:var(--shadow-md);
    color:var(--text);border-color:var(--border);
}
.mp-cart-btn{position:relative}
.mp-badge{
    position:absolute;top:-6px;right:-6px;
    min-width:20px;height:20px;padding:0 5px;
    border-radius:999px;
    background:var(--accent);
    color:var(--text-inv);font-size:.68rem;font-weight:800;
    display:flex;align-items:center;justify-content:center;
    border:2px solid var(--surface);
    box-shadow:0 2px 6px rgba(16,185,129,.35);
}
.mp-sell-btn{
    text-decoration:none;
    padding:11px 16px;border-radius:var(--r-md);
    background:var(--primary);color:var(--text-inv);
    font-size:.86rem;font-weight:700;
    box-shadow:0 8px 20px rgba(15,23,42,.18),inset 0 1px 0 rgba(255,255,255,.08);
    transition:all .18s var(--ease);
    white-space:nowrap;
}
.mp-sell-btn:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(15,23,42,.24)}

.mp-shell{
    max-width:var(--container-lg);margin:0 auto;
    display:grid;grid-template-columns:1fr;gap:18px;padding:20px 16px;
}
.mp-sidebar{display:none}
.mp-main{min-width:0}

.mp-hero{
    background:
        radial-gradient(1200px 400px at 20% 10%, rgba(16,185,129,.2) 0%, transparent 55%),
        radial-gradient(900px 380px at 90% 30%, rgba(99,102,241,.16) 0%, transparent 55%),
        linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.85) 100%);
    border:1px solid rgba(15,23,42,.06);
    border-radius:var(--r-2xl);
    padding:28px 22px;
    box-shadow:var(--shadow-md);
    position:relative;overflow:hidden;
}
.mp-hero::after{
    content:'';position:absolute;top:-50px;right:-50px;
    width:200px;height:200px;border-radius:50%;
    background:radial-gradient(circle,rgba(16,185,129,.12) 0%,transparent 70%);
    pointer-events:none;
}
.mp-hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    padding:8px 14px;border-radius:999px;
    background:var(--accent-soft);color:var(--accent-2);
    font-weight:800;font-size:.78rem;letter-spacing:.02em;
    border:1px solid var(--accent-ring);
}
.mp-hero-title{
    margin-top:14px;font-family:var(--font-display);
    font-weight:900;letter-spacing:-.04em;font-size:1.85rem;
    color:var(--primary);line-height:1.1;max-width:22ch;
}
.mp-hero-sub{
    margin-top:12px;color:var(--text-2);
    max-width:58ch;font-size:.98rem;line-height:1.55;
}
.mp-hero-cta{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}
.mp-hero-error{
    background:
        radial-gradient(600px 300px at 20% 20%, rgba(239,68,68,.1) 0%, transparent 60%),
        linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.88) 70%);
}

.mp-store-hero{
    border-radius:var(--r-2xl);overflow:hidden;
    border:1px solid rgba(15,23,42,.06);
    box-shadow:var(--shadow-lg);
    background:
        radial-gradient(800px 400px at 20% 20%, rgba(16,185,129,.3) 0%, transparent 55%),
        linear-gradient(135deg, #0b1220 0%, #111827 45%, #1e293b 100%);
}
.mp-store-hero-inner{padding:22px}
.mp-back{
    display:inline-flex;align-items:center;gap:8px;text-decoration:none;
    color:rgba(255,255,255,.82);font-weight:700;font-size:.84rem;
    padding:6px 10px;border-radius:var(--r-sm);
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
    transition:all .15s var(--ease);
}
.mp-back:hover{background:rgba(255,255,255,.1);color:#fff}
.mp-store-card{
    margin-top:16px;display:flex;gap:16px;align-items:center;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.14);
    border-radius:var(--r-lg);padding:16px;
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.mp-store-logo{
    width:64px;height:64px;border-radius:var(--r-md);overflow:hidden;
    background:rgba(16,185,129,.18);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    border:1px solid rgba(16,185,129,.3);
}
.mp-store-logo img{width:100%;height:100%;object-fit:cover}
.mp-store-letter{
    font-family:var(--font-display);font-weight:900;
    color:#fff;font-size:1.6rem;
}
.mp-store-name{
    font-family:var(--font-display);font-weight:900;
    color:#fff;letter-spacing:-.03em;
    font-size:1.35rem;line-height:1.15;
}
.mp-store-sub{margin-top:4px;color:rgba(255,255,255,.72);font-size:.88rem;font-weight:500}
.mp-store-badges{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.mp-pill{
    display:inline-flex;align-items:center;gap:8px;
    padding:7px 12px;border-radius:999px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.16);
    color:rgba(255,255,255,.9);
    font-size:.78rem;font-weight:700;
}

.mp-panel{
    background:var(--surface);border:1px solid var(--border-soft);
    border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-xs);
}
.mp-panel-muted{background:var(--surface-alt)}
.mp-panel-title{
    font-size:.78rem;font-weight:800;color:var(--primary);
    letter-spacing:.02em;margin-bottom:12px;
    text-transform:uppercase;
}
.mp-cat-list{display:flex;flex-direction:column;gap:4px}
.mp-cat{
    border:none;background:transparent;cursor:pointer;
    display:flex;align-items:center;gap:10px;
    padding:10px 12px;border-radius:var(--r-sm);
    color:var(--text-2);font-weight:600;font-size:.88rem;
    transition:all .15s var(--ease);text-align:left;
}
.mp-cat i{opacity:.7;flex-shrink:0}
.mp-cat:hover{background:var(--surface-hover);color:var(--text)}
.mp-cat.active{
    background:var(--accent-soft);color:var(--accent-2);font-weight:700;
}
.mp-cat.active i{opacity:1}
.mp-cat-count{
    margin-left:auto;font-size:.72rem;color:var(--text-3);font-weight:800;
    padding:2px 8px;background:var(--surface-alt);border-radius:var(--r-full);
}
.mp-cat.active .mp-cat-count{background:var(--surface);color:var(--accent-2)}
.mp-filter-row label{font-size:.78rem;font-weight:700;color:var(--text);display:block;margin-bottom:8px}
.mp-price-row{display:flex;gap:8px;margin-bottom:10px}
.mp-price-row input{
    width:100%;padding:10px 12px;border-radius:var(--r-sm);
    border:1.5px solid var(--border);
    background:var(--surface);outline:none;font-size:.88rem;font-weight:500;
    transition:all .15s var(--ease);
}
.mp-price-row input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}

.mp-chip-row{
    display:flex;gap:8px;overflow:auto;padding:10px 2px 2px;margin-top:14px;
    -ms-overflow-style:none;scrollbar-width:none;
}
.mp-chip-row::-webkit-scrollbar{display:none}
.mp-chip{
    border:1px solid var(--border-soft);cursor:pointer;
    display:inline-flex;align-items:center;gap:8px;
    padding:9px 14px;border-radius:999px;
    background:var(--surface);
    color:var(--text-2);font-weight:700;font-size:.82rem;
    white-space:nowrap;
    transition:all .15s var(--ease);box-shadow:var(--shadow-xs);
}
.mp-chip:hover{border-color:var(--text-3);color:var(--text);transform:translateY(-1px)}
.mp-chip.active{
    background:var(--accent-soft);border-color:var(--accent-ring);color:var(--accent-2);
    box-shadow:0 4px 12px rgba(16,185,129,.15);
}
.mp-chip-ghost{background:var(--surface-alt)}

.mp-toolbar{
    display:flex;align-items:center;justify-content:space-between;
    margin-top:14px;gap:10px;flex-wrap:wrap;
}
.mp-results{color:var(--text-3);font-weight:700;font-size:.85rem}
.mp-grid{margin-top:14px}
.mp-card{border:1px solid var(--border-soft)}
.mp-img{position:relative;background:var(--surface-alt)}
.mp-img-ph{
    height:100%;display:flex;align-items:center;justify-content:center;
    color:var(--text-3);font-size:2rem;opacity:.5;
}
.mp-add{
    position:absolute;bottom:10px;right:10px;
    width:42px;height:42px;border-radius:var(--r-md);
    border:1px solid rgba(255,255,255,.28);
    background:rgba(15,23,42,.88);color:#fff;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .18s var(--ease);
    box-shadow:0 12px 24px rgba(0,0,0,.3);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.mp-add:hover{transform:translateY(-2px) scale(1.05);background:var(--accent-2)}
.mp-add:active{transform:translateY(0) scale(.95)}
.mp-name{
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;color:var(--text);font-weight:600;
}
.mp-price{
    margin-top:6px;font-family:var(--font-display);
    font-weight:900;color:var(--primary);letter-spacing:-.02em;font-size:1.05rem;
}
.mp-store{margin-top:6px;color:var(--text-3);font-size:.8rem;font-weight:600}
.mp-store a{color:inherit;text-decoration:none;transition:color .15s}
.mp-store a:hover{color:var(--accent-2)}

.mp-load-wrap{display:flex;justify-content:center;margin:22px 0 8px}
.mp-empty{
    background:var(--surface);border:1px dashed var(--border);
    border-radius:var(--r-2xl);padding:44px 28px;text-align:center;
    box-shadow:var(--shadow-xs);
}
.mp-empty i{font-size:2.6rem;color:var(--text-3);opacity:.4}
.mp-empty h3{
    margin-top:12px;font-family:var(--font-display);font-weight:800;
    color:var(--primary);letter-spacing:-.02em;font-size:1.1rem;
}
.mp-empty p{margin-top:6px;color:var(--text-3);font-weight:500}

.mp-product-modal{display:grid;grid-template-columns:1fr;gap:16px}
.mp-pimg{
    width:100%;height:260px;object-fit:cover;border-radius:var(--r-lg);
    background:var(--surface-alt);border:1px solid var(--border-soft);
}
.mp-pimg-ph{display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:2.4rem;opacity:.5}
.mp-pprice{
    font-family:var(--font-display);font-weight:900;color:var(--primary);
    font-size:1.75rem;letter-spacing:-.03em;line-height:1.1;
}
.mp-pdesc{margin-top:10px;color:var(--text-2);font-weight:500;line-height:1.55}
.mp-muted{color:var(--text-3)!important}
.mp-ppills{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.mp-pactions{margin-top:18px}

.mp-cart-store{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.mp-cart-store-title{font-weight:800;color:var(--primary);letter-spacing:-.015em;font-size:1rem}
.mp-cart-list{display:flex;flex-direction:column;gap:10px}
.mp-cart-item{
    display:grid;grid-template-columns:56px 1fr auto;gap:12px;
    align-items:center;padding:12px;
    border-radius:var(--r-md);border:1px solid var(--border-soft);
    background:var(--surface);transition:all .15s var(--ease);
}
.mp-cart-item:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}
.mp-cart-thumb{
    width:56px;height:56px;border-radius:var(--r-sm);overflow:hidden;
    background:var(--surface-alt);
    display:flex;align-items:center;justify-content:center;color:var(--text-3);
}
.mp-cart-thumb img{width:100%;height:100%;object-fit:cover}
.mp-cart-name{font-weight:700;color:var(--text);letter-spacing:-.015em;font-size:.92rem}
.mp-cart-sub{color:var(--text-3);font-weight:600;font-size:.78rem;margin-top:2px}
.mp-cart-qty{margin-top:8px;display:flex;align-items:center;gap:6px}
.mp-qty-btn{
    width:32px;height:32px;border-radius:var(--r-xs);
    border:1px solid var(--border);background:var(--surface);cursor:pointer;
    transition:all .15s var(--ease);color:var(--text-2);
    display:flex;align-items:center;justify-content:center;
}
.mp-qty-btn:hover{border-color:var(--accent);color:var(--accent-2);background:var(--accent-soft)}
.mp-qty-btn:disabled{opacity:.4;cursor:not-allowed}
.mp-cart-qty input{
    width:56px;padding:7px 8px;border-radius:var(--r-xs);
    border:1px solid var(--border);background:var(--surface);
    text-align:center;font-weight:800;outline:none;
}
.mp-trash{
    margin-left:6px;width:32px;height:32px;border-radius:var(--r-xs);
    border:1px solid rgba(239,68,68,.25);
    background:var(--red-soft);color:var(--red);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .15s var(--ease);
}
.mp-trash:hover{background:var(--red);color:#fff}
.mp-cart-amt{font-weight:800;color:var(--primary);font-family:var(--font-display)}
.mp-cart-total{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border)}
.mp-kv{
    display:flex;justify-content:space-between;align-items:center;
    gap:10px;color:var(--text-2);font-weight:700;font-size:.88rem;margin-top:8px;
}
.mp-thanks{text-align:center;padding:16px 8px}
.mp-thanks-icon{
    width:80px;height:80px;border-radius:var(--r-xl);margin:0 auto 14px;
    background:linear-gradient(135deg,var(--accent-soft),var(--green-soft));
    border:1px solid var(--accent-ring);
    display:flex;align-items:center;justify-content:center;
    color:var(--accent-2);font-size:2.4rem;
    box-shadow:0 8px 24px rgba(16,185,129,.16);
}
.mp-thanks-title{
    font-family:var(--font-display);font-weight:900;color:var(--primary);
    letter-spacing:-.04em;font-size:1.7rem;
}
.mp-thanks-sub{margin-top:8px;color:var(--text-2);font-weight:600}
.mp-alert{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px}
.mp-alert-red{background:var(--red-soft);border-color:rgba(239,68,68,.2);color:#b91c1c;font-weight:700}
.mp-small{font-size:.84rem;color:var(--text-2);font-weight:600;line-height:1.55}

@media(min-width:768px){
    .mp-hero{padding:36px 32px}
    .mp-hero-title{font-size:2.3rem}
    .mp-store-hero-inner{padding:32px}
    .mp-store-name{font-size:1.65rem}
}

@media(min-width:960px){
    .mp-shell{
        grid-template-columns:300px 1fr;gap:22px;padding:24px 20px;
    }
    .mp-sidebar{
        display:flex;flex-direction:column;gap:16px;
        position:sticky;top:96px;
        max-height:calc(100dvh - 116px);overflow:auto;padding-bottom:20px;
    }
    .mp-chip-row{display:none}
    .mp-hero{padding:40px 36px}
    .mp-hero-title{font-size:2.6rem}
    .mp-product-modal{grid-template-columns:1.1fr .9fr;align-items:start}
    .mp-pimg{height:340px}
}

@media(min-width:1200px){
    .mp-shell{grid-template-columns:320px 1fr;gap:28px}
    .mp-hero-title{font-size:2.8rem}
}

/* ── Verification Feature ──────────────────────────── */
.upload-drop-zone {
    border: 2px dashed var(--border);
    border-radius: 16px;
    padding: 28px 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    background: var(--surface);
    position: relative;
}
.upload-drop-zone:hover,
.upload-drop-zone.dragover {
    border-color: var(--accent);
    background: var(--accent-soft);
}
.upload-drop-zone.has-file {
    border-color: #10b981;
    background: rgba(16,185,129,.06);
}
.upload-drop-zone .drop-icon {
    font-size: 2rem;
    color: var(--text-3);
    margin-bottom: 8px;
    display: block;
    transition: color .2s;
}
.upload-drop-zone:hover .drop-icon,
.upload-drop-zone.has-file .drop-icon {
    color: var(--accent);
}
.upload-drop-zone .drop-label {
    font-weight: 700;
    font-size: .9rem;
    color: var(--text);
}
.upload-drop-zone .drop-sub {
    font-size: .76rem;
    color: var(--text-3);
    margin-top: 4px;
}
.upload-drop-zone .drop-preview {
    max-width: 100%;
    max-height: 140px;
    border-radius: 10px;
    object-fit: contain;
    margin-top: 10px;
    display: none;
}
.upload-drop-zone.has-file .drop-preview {
    display: block;
    margin: 10px auto 0;
}
.upload-drop-zone input[type=file] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
}

/* Verified badge — inline in headings */
.verif-badge {
    color: #10b981;
    font-size: 1em;
    vertical-align: middle;
    margin-left: 4px;
}
/* Larger badge for profile/storefront hero */
.verif-badge-large {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(16,185,129,.1);
    color: #059669;
    border: 1px solid rgba(16,185,129,.25);
    border-radius: 999px;
    padding: 4px 12px;
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .01em;
}
.verif-badge-large i {
    font-size: 1rem;
}

/* Verification benefit grid */
.verif-benefits {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 12px 0;
}
.verif-benefit-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: var(--surface-hover);
    border-radius: 12px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-2);
}
.verif-benefit-item i {
    color: var(--accent);
    font-size: 1rem;
    flex-shrink: 0;
}

/* Step indicator for verification flow */
.verif-steps {
    display: flex;
    justify-content: center;
    gap: 0;
    margin-bottom: 20px;
}
.verif-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    position: relative;
}
.verif-step + .verif-step::before {
    content: '';
    position: absolute;
    top: 14px;
    left: -50%;
    right: 50%;
    height: 2px;
    background: var(--border);
    z-index: 0;
}
.verif-step.done + .verif-step::before,
.verif-step.active + .verif-step::before {
    background: var(--accent);
}
.verif-step-dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    font-weight: 800;
    color: var(--text-3);
    position: relative;
    z-index: 1;
}
.verif-step.done .verif-step-dot {
    background: var(--accent);
    color: #fff;
}
.verif-step.active .verif-step-dot {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 0 0 4px var(--accent-soft);
}
.verif-step-label {
    font-size: .68rem;
    font-weight: 700;
    color: var(--text-3);
    margin-top: 5px;
    text-align: center;
}

/* ============================================================
   MARKETPLACE — NEW STOREFRONT COMPONENTS
   ============================================================ */

/* ---- Cart FAB ---- */
.mp-cart-fab {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 1200;
    display: none;
    align-items: center;
    gap: 10px;
    background: var(--primary);
    color: #fff;
    border: none;
    border-radius: 28px;
    padding: 12px 20px;
    font-size: .9rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(99,102,241,.35);
    transition: transform .15s, box-shadow .15s;
}
.mp-cart-fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(99,102,241,.45);
}
.mp-cart-fab i { font-size: 1.15rem; }
.mp-fab-info, .mp-cart-fab-info { display: flex; flex-direction: column; line-height: 1.2; }
.mp-fab-count, .mp-cart-fab-count { font-size: .78rem; opacity: .85; }
.mp-fab-total, .mp-cart-fab-total { font-size: .95rem; font-weight: 800; }

/* ---- Filters FAB ---- */
.mp-filter-fab{
    position: fixed;
    bottom: 24px;
    left: 24px;
    z-index: 1200;
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(15,23,42,.12);
    box-shadow: 0 10px 24px rgba(0,0,0,.18);
    cursor: pointer;
    backdrop-filter: blur(10px);
}
.mp-filter-fab i{ font-size: 1.25rem; color: var(--primary); }

/* ---- Map modal overlay (sits above checkout, doesn't replace it) ---- */
.mp-map-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 2200;
    background: rgba(0,0,0,.55);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s;
}
.mp-map-modal-overlay.open,
.mp-map-modal-overlay.mp-map-overlay-open {
    opacity: 1;
    pointer-events: all;
}
.mp-map-modal-inner {
    background: var(--surface);
    border-radius: 20px 20px 0 0;
    width: 100%;
    max-width: 560px;
    padding: 20px;
    box-shadow: 0 -6px 40px rgba(0,0,0,.18);
    transform: translateY(30px);
    transition: transform .22s;
}
.mp-map-modal-overlay.open .mp-map-modal-inner,
.mp-map-modal-overlay.mp-map-overlay-open .mp-map-modal-inner {
    transform: translateY(0);
}
#mp-map-leaflet { height: 300px; border-radius: 12px; overflow: hidden; margin-bottom: 12px; }

/* ---- Full-page Product Panel ---- */
.mp-product-panel {
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: var(--bg);
    transform: translateX(100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}
.mp-product-panel.mp-product-panel-open {
    transform: translateX(0);
}
.mp-panel-topbar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 14px 18px;
}
.mp-panel-topbar button {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-1);
    font-size: 1.25rem;
    padding: 4px;
    border-radius: 8px;
    line-height: 1;
}
.mp-panel-topbar button:hover { background: var(--border); }
.mp-panel-topbar-title {
    flex: 1;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mp-panel-body {
    flex: 1;
    padding: 0 0 100px;
}

/* Gallery */
.mp-panel-gallery {
    background: var(--surface);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px;
    gap: 10px;
}
.mp-panel-mainimg {
    width: 100%;
    max-width: 480px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 16px;
    background: var(--border);
    cursor: zoom-in;
}
.mp-panel-thumbs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
}
.mp-panel-thumb {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 8px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color .15s;
    background: var(--border);
}
.mp-panel-thumb.active,
.mp-panel-thumb:hover {
    border-color: var(--primary);
}

/* Panel body sections */
.mp-panel-info { padding: 18px 18px 0; }
.mp-panel-price {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--primary);
    margin: 4px 0 10px;
}
.mp-panel-store-row {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .82rem;
    color: var(--text-2);
    margin-bottom: 12px;
}
.mp-panel-store-row a { color: var(--primary); text-decoration: none; font-weight: 600; }
.mp-panel-desc {
    font-size: .88rem;
    color: var(--text-2);
    line-height: 1.55;
    white-space: pre-wrap;
    padding: 0 18px;
    margin-bottom: 16px;
}
.mp-panel-section-title {
    font-size: .8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-3);
    padding: 0 18px;
    margin-bottom: 8px;
}

/* Variation chips */
.mp-var-group { padding: 0 18px; margin-bottom: 16px; }
.mp-var-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.mp-var-chip {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
    padding: 7px 14px;
    border: 2px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
    cursor: pointer;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-1);
    transition: border-color .15s, background .15s;
    line-height: 1.3;
}
.mp-var-chip:hover {
    border-color: var(--primary-soft, rgba(99,102,241,.35));
    background: var(--accent-soft, rgba(16,185,129,.08));
}
.mp-var-chip.active {
    border-color: var(--primary);
    background: var(--primary-soft, rgba(99,102,241,.1));
    color: var(--primary);
}
.mp-var-chip .mp-var-mod {
    font-size: .7rem;
    font-weight: 700;
    color: var(--accent);
}

/* Related products */
.mp-related-wrap { padding: 0 18px; }
.mp-related-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 8px;
}
@media (min-width: 480px) {
    .mp-related-grid { grid-template-columns: repeat(3, 1fr); }
}
.mp-related-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px;
    overflow: hidden;
    cursor: pointer;
    transition: box-shadow .15s, transform .15s;
}
.mp-related-card:hover {
    box-shadow: 0 4px 18px rgba(0,0,0,.08);
    transform: translateY(-2px);
}
.mp-related-card img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    background: var(--border);
}
.mp-related-card-info { padding: 8px 10px; }
.mp-related-card-name {
    font-size: .82rem;
    font-weight: 700;
    color: var(--text-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mp-related-card-price {
    font-size: .8rem;
    font-weight: 800;
    color: var(--primary);
    margin-top: 2px;
}

/* Fixed add-to-cart footer on panel */
.mp-panel-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2010;
    background: var(--surface);
    border-top: 1px solid var(--border);
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    box-shadow: 0 -4px 20px rgba(0,0,0,.08);
}
.mp-panel-footer-price {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--primary);
    flex-shrink: 0;
}
.mp-panel-footer .btn { flex: 1; }

/* Featured badge */
.mp-featured-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: linear-gradient(135deg, #f59e0b, #fbbf24);
    color: #fff;
    font-size: .68rem;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: .04em;
    vertical-align: middle;
}

/* In-cart product card state */
.mp-add.mp-add-incart {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}
.mp-add.mp-add-incart:hover {
    background: var(--accent-dark, #059669);
    border-color: var(--accent-dark, #059669);
}
.mp-incart-badge {
    font-size: .72rem;
    color: var(--accent);
    font-weight: 700;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 3px;
}

/* ---- Checkout layout — sticky footer ---- */
.mp-checkout-wrap {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}
.mp-checkout-scroll {
    flex: 1;
    overflow-y: auto;
    padding: 2px 0 8px;
    -webkit-overflow-scrolling: touch;
}
.mp-checkout-footer {
    position: sticky;
    bottom: 0;
    background: var(--surface);
    border-top: 1px solid var(--border);
    padding: 14px 0 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 10;
}

/* spin animation for loading indicators */
@keyframes spin { to { transform: rotate(360deg); } }
.spin { display: inline-block; animation: spin .7s linear infinite; }

/* Modal checkout: make modal flex so inner scroll + sticky footer works */
.modal:has(.mp-checkout-wrap) {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding-bottom: 0;
}
.modal:has(.mp-checkout-wrap) .modal-header {
    flex-shrink: 0;
    position: relative; /* disable sticky since modal doesn't scroll anymore */
}
.modal:has(.mp-checkout-wrap) .mp-checkout-wrap {
    flex: 1;
    min-height: 0;
    overflow: hidden;
}
.mp-checkout-scroll {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
    padding: 4px 0 12px;
    -webkit-overflow-scrolling: touch;
}
.mp-checkout-footer {
    flex-shrink: 0;
    background: var(--surface);
    border-top: 1px solid var(--border);
    padding: 14px 0 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mp-map-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    font-size: 1rem;
    font-weight: 800;
    color: var(--text-1);
}

/* ---- Product panel inner layout ---- */
.mp-panel-content { padding: 16px 18px 0; }
.mp-panel-name {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--text-1);
    line-height: 1.3;
    margin-bottom: 4px;
}
.mp-panel-price {
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--primary);
}
.mp-panel-store {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .82rem;
    color: var(--text-2);
    margin: 6px 0 14px;
}
.mp-panel-store a { color: var(--primary); font-weight: 700; text-decoration: none; }
.mp-panel-section {
    padding: 0;
    margin-bottom: 18px;
}
.mp-panel-desc {
    font-size: .88rem;
    color: var(--text-2);
    line-height: 1.6;
    white-space: pre-wrap;
}
/* Panel thumb as background-image div */
.mp-panel-thumb {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color .15s;
    background-color: var(--border);
    background-size: cover;
    background-position: center;
}
/* Related products grid inside panel */
.mp-panel-related {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 10px;
}
@media (min-width: 380px) { .mp-panel-related { grid-template-columns: repeat(3, 1fr); } }
.mp-related-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: box-shadow .15s, transform .15s;
}
.mp-related-card:hover {
    box-shadow: 0 3px 14px rgba(0,0,0,.08);
    transform: translateY(-2px);
}
.mp-related-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    background: var(--border) center/cover no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    color: var(--text-3);
}
.mp-related-name {
    font-size: .78rem;
    font-weight: 700;
    color: var(--text-1);
    padding: 6px 8px 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mp-related-price {
    font-size: .78rem;
    font-weight: 800;
    color: var(--primary);
    padding: 0 8px 8px;
}

/* Featured badge on panel gallery */
.mp-featured-badge-panel {
    align-self: flex-start;
    margin-bottom: 4px;
}

/* Product panel polish */
.mp-product-panel{
    background: linear-gradient(180deg, #f8fafc 0%, var(--bg) 36%);
}
.mp-panel-topbar{
    background: rgba(255,255,255,.84);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.mp-panel-content{
    padding-top: 12px;
}
.mp-panel-name{
    font-size: 1.4rem;
    line-height: 1.25;
    margin-bottom: 6px;
}
.mp-panel-gallery{
    padding: 18px 18px 12px;
}
.mp-panel-mainimg{
    border-radius: 20px;
    box-shadow: 0 10px 28px rgba(15,23,42,.12);
}
.mp-panel-section{
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: 14px;
    padding: 12px;
    margin-bottom: 12px;
}
.mp-panel-section-title,
.mp-panel-desc,
.mp-var-group{
    padding-left: 0;
    padding-right: 0;
}
.mp-panel-footer{
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.mp-pd-section{
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: 14px;
    padding: 12px;
    margin: 10px 0;
}
.mp-pd-section-label{
    font-size: .82rem;
    letter-spacing: .03em;
    text-transform: uppercase;
    color: var(--text-3);
    margin-bottom: 8px;
}
.mp-pd-price-row{
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}
.mp-panel-desc{
    line-height: 1.6;
    font-size: .94rem;
    color: var(--text-2);
}
.mp-pd-trust{
    background: var(--surface);
    border: 1px dashed var(--border);
    border-radius: 14px;
    padding: 10px;
}
.mp-var-chip{
    border-radius: 999px;
}
.mp-pd-atc-btn{
    border-radius: 12px;
    min-height: 46px;
    font-weight: 800;
}

/* ============================================================
   DASHBOARD REDESIGN — Donezo-inspired mobile-first
   ============================================================ */

/* ── Greeting header ── */
.dsb-greeting {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 18px;
}
.dsb-greeting-wave {
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-3);
    margin-bottom: 3px;
}
.dsb-greeting-biz {
    font-size: 1.3rem;
    font-weight: 900;
    color: var(--text);
    letter-spacing: -.025em;
    line-height: 1.2;
}
.dsb-greeting-date {
    font-size: .75rem;
    color: var(--text-3);
    margin-top: 3px;
    font-weight: 500;
}
.dsb-biz-pill {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--surface);
    border: 1.5px solid var(--border);
    border-radius: 28px;
    padding: 5px 10px 5px 5px;
    cursor: pointer;
    transition: all .15s;
    flex-shrink: 0;
    box-shadow: var(--shadow-xs);
}
.dsb-biz-pill:hover { border-color: var(--accent-ring); }
.dsb-biz-pill-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, #10b981, #059669);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-weight: 800;
    font-size: .8rem;
    color: #fff;
}
.dsb-biz-pill-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* ── Subscription pill ── */
.dsb-sub-pill {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--accent-soft);
    border: 1px solid var(--accent-ring);
    border-radius: 12px;
    padding: 10px 14px;
    cursor: pointer;
    font-size: .82rem;
    font-weight: 700;
    color: var(--accent-2);
    margin-bottom: 14px;
    transition: all .15s;
}
.dsb-sub-pill:hover { background: rgba(16,185,129,.15); }
.dsb-sub-pill.urgent { background: rgba(245,158,11,.1); border-color: rgba(245,158,11,.3); color: var(--amber); }
.dsb-sub-pill.no-plan { background: rgba(239,68,68,.07); border-color: rgba(239,68,68,.2); color: var(--red); }
.dsb-sub-days {
    background: rgba(16,185,129,.15);
    border-radius: 20px;
    padding: 2px 8px;
    font-size: .72rem;
}
.dsb-sub-cta { margin-left: auto; font-weight: 800; font-size: .78rem; }

/* ── Setup card ── */
.dsb-setup-card {
    background: linear-gradient(135deg, #0a2e1a 0%, #1a5c35 100%);
    border-radius: 20px;
    padding: 20px;
    margin-bottom: 16px;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.dsb-setup-card::before {
    content: '';
    position: absolute;
    top: -30px; right: -30px;
    width: 140px; height: 140px;
    border-radius: 50%;
    background: rgba(255,255,255,.05);
}
.dsb-setup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.dsb-setup-title {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 2px;
}
.dsb-setup-sub { font-size: .78rem; opacity: .65; }
.dsb-setup-ring {
    position: relative;
    width: 52px;
    height: 52px;
    flex-shrink: 0;
}
.dsb-setup-ring svg { width: 52px; height: 52px; transform: rotate(-90deg); }
.dsb-setup-ring span {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    font-weight: 800;
}
.dsb-setup-steps { display: flex; flex-direction: column; gap: 8px; }
.dsb-setup-step {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(255,255,255,.1);
    border-radius: 10px;
    padding: 10px 12px;
    cursor: pointer;
    font-size: .85rem;
    font-weight: 600;
    transition: background .15s;
}
.dsb-setup-step:hover { background: rgba(255,255,255,.16); }
.dsb-setup-step.done { opacity: .55; cursor: default; text-decoration: line-through; }
.dsb-setup-step-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: rgba(255,255,255,.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}

/* ── Scope toggle ── */
.dsb-scope-toggle {
    display: flex;
    gap: 6px;
    margin-bottom: 14px;
}
.dsb-scope-toggle button {
    flex: 1;
    padding: 8px 12px;
    border-radius: 10px;
    border: 1.5px solid var(--border);
    background: var(--surface);
    font-size: .8rem;
    font-weight: 700;
    color: var(--text-2);
    cursor: pointer;
    transition: all .15s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.dsb-scope-toggle button.active {
    background: #0a2e1a;
    border-color: #0a2e1a;
    color: #fff;
}

/* ── KPI grid ── */
.dsb-kpi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    gap: 12px;
    margin-bottom: 20px;
}
/* Primary card spans full width */
.dsb-kpi-primary {
    grid-column: 1 / -1;
    background: linear-gradient(135deg, #0a2e1a 0%, #1a5c35 100%);
    border-radius: 20px;
    padding: 22px 20px 18px;
    color: #fff;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: transform .15s, box-shadow .15s;
}
.dsb-kpi-primary::after {
    content: '';
    position: absolute;
    bottom: -20px; right: -20px;
    width: 110px; height: 110px;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
}
.dsb-kpi-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(10,46,26,.28); }
.dsb-kpi-primary-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}
.dsb-kpi-arrow-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: rgba(255,255,255,.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .95rem;
    flex-shrink: 0;
}
.dsb-kpi-big {
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: -.04em;
    line-height: 1.1;
    margin-bottom: 8px;
}
.dsb-kpi-trend {
    font-size: .78rem;
    opacity: .75;
    display: flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
}
/* Secondary cards */
.dsb-kpi-secondary {
    background: var(--surface);
    border-radius: 18px;
    padding: 16px 14px;
    border: 1.5px solid var(--border-soft);
    cursor: pointer;
    transition: all .15s;
    box-shadow: var(--shadow-xs);
}
.dsb-kpi-secondary:hover {
    border-color: var(--accent-ring);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}
.dsb-kpi-secondary.dsb-kpi-red .dsb-kpi-num  { color: var(--red); }
.dsb-kpi-secondary.dsb-kpi-amber .dsb-kpi-num { color: var(--amber); }
.dsb-kpi-secondary.dsb-kpi-warn .dsb-kpi-num  { color: #f97316; }
.dsb-kpi-label {
    font-size: .72rem;
    font-weight: 800;
    color: var(--text-3);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 6px;
}
.dsb-kpi-primary .dsb-kpi-label { color: rgba(255,255,255,.65); }
.dsb-kpi-num {
    font-size: 1.3rem;
    font-weight: 900;
    color: var(--text);
    letter-spacing: -.03em;
    line-height: 1.2;
}
.dsb-kpi-sub {
    font-size: .72rem;
    color: var(--text-3);
    margin-top: 3px;
    font-weight: 500;
}

/* ── Section header ── */
.dsb-section { margin-bottom: 20px; }
.dsb-section-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.dsb-section-title {
    font-size: .95rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -.01em;
}
.dsb-section-sub {
    font-size: .76rem;
    color: var(--text-3);
    font-weight: 600;
}

.dsb-masonry {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 12px;
    grid-auto-flow: row dense;
    align-items: start;
    margin-bottom: 20px;
    max-width: var(--container-lg);
    margin-left: auto;
    margin-right: auto;
    padding: 0 2px;
}
/* Mobile: everything full width */
.dsb-tile { grid-column: span 12; }
.dsb-tile.span-12 { grid-column: span 12; }

/* Tablet 640px+: hero gets 7, companion gets 5 */
@media (min-width: 640px) {
    .dsb-tile.span-8  { grid-column: span 7; }
    .dsb-tile.span-4  { grid-column: span 5; }
    .dsb-tile.span-7  { grid-column: span 7; }
    .dsb-tile.span-5  { grid-column: span 5; }
    .dsb-tile.span-6  { grid-column: span 6; }
}
/* Desktop 900px+: proper 8/4 and 7/5 splits */
@media (min-width: 900px) {
    .dsb-tile.span-8  { grid-column: span 8; }
    .dsb-tile.span-4  { grid-column: span 4; }
    .dsb-tile.span-7  { grid-column: span 7; }
    .dsb-tile.span-5  { grid-column: span 5; }
    .dsb-tile.span-6  { grid-column: span 6; }
}
.dsb-tile.hero-tile { display: flex; align-items: flex-start; justify-content: flex-start; }

.dsb-widget {
    padding: 16px 16px 14px;
    border-radius: 20px !important;
    overflow: hidden;
}
.dsb-widget-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.dsb-widget-title {
    font-size: .88rem;
    font-weight: 950;
    color: var(--text);
    letter-spacing: -.01em;
}
.dsb-widget-sub {
    font-size: .74rem;
    font-weight: 750;
    color: var(--text-3);
    margin-top: 2px;
}

/* ── ATM card shimmer animation ── */
@keyframes dsb-card-shimmer {
    0%   { transform: translateX(-120%) skewX(-20deg); }
    100% { transform: translateX(220%)  skewX(-20deg); }
}
@keyframes dsb-card-pulse {
    0%, 100% { opacity: .5; }
    50%       { opacity: .9; }
}

.dsb-atm-wrap { width: 100%; }
.dsb-atm-card{
    border-radius: 26px !important;
    border: none !important;
    padding: 22px 22px 18px;
    color: #fff;
    width: 100%;
    max-width: 580px;
    min-height: 210px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background: #1a7a52;
    box-shadow:
        0 0 0 1px rgba(255,255,255,.14),
        0 8px 28px -6px rgba(10,60,35,.55),
        0 20px 56px -16px rgba(10,60,35,.4),
        0 0 40px -8px rgba(26,122,82,.6);
    transform: translateZ(0);
    transition: box-shadow .3s ease, transform .2s ease;
}
/* Diagonal hatched grain for depth */
.dsb-atm-card::before{
    content:'';
    position:absolute;
    inset:0;
    background:
        repeating-linear-gradient(
            110deg,
            rgba(255,255,255,.035) 0px,
            rgba(255,255,255,.035) 1px,
            transparent 1px,
            transparent 22px
        );
    pointer-events:none;
    z-index: 0;
}
/* Holographic shimmer sweep */
.dsb-atm-card::after{
    content:'';
    position:absolute;
    inset: 0;
    background: linear-gradient(
        105deg,
        transparent 30%,
        rgba(255,255,255,.10) 45%,
        rgba(255,255,255,.22) 50%,
        rgba(255,255,255,.10) 55%,
        transparent 70%
    );
    pointer-events:none;
    z-index: 1;
    animation: dsb-card-shimmer 5s ease-in-out infinite;
}
.dsb-atm-card:hover {
    box-shadow:
        0 0 0 1px rgba(255,255,255,.2),
        0 14px 36px -6px rgba(10,60,35,.6),
        0 28px 70px -16px rgba(10,60,35,.45),
        0 0 60px -6px rgba(26,122,82,.75);
    transform: translateY(-3px) scale(1.005);
}
.dsb-atm-card:active { transform: translateY(0) scale(1); }

.dsb-atm-top{
    position: relative;
    z-index: 2;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap: 12px;
}
.dsb-atm-brand{display:flex;flex-direction:column;gap:3px;min-width:0;}
.dsb-atm-app{
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: -.03em;
    font-size: 1.05rem;
    line-height: 1.05;
}
.dsb-atm-tag{
    font-size: .68rem;
    font-weight: 850;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.70);
}
.dsb-atm-net{
    font-family: var(--font-display);
    font-weight: 950;
    font-size: 1.08rem;
    letter-spacing: .16em;
    opacity: .92;
    padding-top: 2px;
}
.dsb-atm-net.visa{letter-spacing:.18em;}
.dsb-atm-mark-chip{
    width: 44px;
    height: 34px;
    border-radius: 10px;
    background:
        linear-gradient(135deg, rgba(255,220,120,.95), rgba(255,200,80,.75)),
        linear-gradient(90deg, rgba(0,0,0,.22), transparent 35%, rgba(0,0,0,.18));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.35), inset 0 -1px 0 rgba(0,0,0,.25);
    position: relative;
    opacity: .95;
}
.dsb-atm-mark-chip::before{
    content:'';
    position:absolute;
    inset: 8px 7px;
    border-radius: 7px;
    border: 1px solid rgba(0,0,0,.22);
    background:
        linear-gradient(90deg, rgba(0,0,0,.22) 0 22%, transparent 22% 78%, rgba(0,0,0,.18) 78% 100%),
        linear-gradient(0deg, rgba(0,0,0,.18) 0 18%, transparent 18% 82%, rgba(0,0,0,.16) 82% 100%);
    opacity: .6;
}

.dsb-atm-chiprow{
    position: relative;
    z-index: 1;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 12px;
    margin-top: 16px;
}
.dsb-atm-chip{
    width: 54px;
    height: 44px;
    border-radius: 10px;
    background:
        linear-gradient(135deg, rgba(255,220,120,.95), rgba(255,200,80,.75)),
        linear-gradient(90deg, rgba(0,0,0,.22), transparent 35%, rgba(0,0,0,.18));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.35), inset 0 -1px 0 rgba(0,0,0,.25);
    position: relative;
}
.dsb-atm-chip::before{
    content:'';
    position:absolute;
    inset: 9px 8px;
    border-radius: 7px;
    border: 1px solid rgba(0,0,0,.22);
    background:
        linear-gradient(90deg, rgba(0,0,0,.22) 0 22%, transparent 22% 78%, rgba(0,0,0,.18) 78% 100%),
        linear-gradient(0deg, rgba(0,0,0,.18) 0 18%, transparent 18% 82%, rgba(0,0,0,.16) 82% 100%);
    opacity: .6;
}
.dsb-atm-nfc{
    display:flex;
    align-items:center;
    gap: 4px;
    opacity: .9;
}
.dsb-atm-nfc span{
    display:block;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255,255,255,.80);
    border-left-color: transparent;
    border-bottom-color: transparent;
    border-radius: 14px;
    transform: rotate(45deg);
}
.dsb-atm-nfc span:nth-child(2){width:14px;height:14px;opacity:.78}
.dsb-atm-nfc span:nth-child(3){width:10px;height:10px;opacity:.60}

.dsb-atm-num{
    position: relative;
    z-index: 2;
    font-family: var(--font-mono);
    font-weight: 600;
    letter-spacing: .20em;
    font-size: .98rem;
    margin-top: 16px;
    color: rgba(255,255,255,.75);
    text-shadow: 0 1px 12px rgba(0,0,0,.4);
}
.dsb-atm-balance{
    position: relative;
    z-index: 2;
    margin-top: 12px;
}
.dsb-atm-balance .k{
    font-size: .62rem;
    font-weight: 900;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
    display: flex;
    align-items: center;
    gap: 6px;
}
.dsb-atm-balance .k::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,.12);
    max-width: 48px;
}
.dsb-atm-balance .v{
    font-family: var(--font-display);
    font-weight: 950;
    letter-spacing: -.04em;
    font-size: 2.05rem;
    margin-top: 5px;
    line-height: 1;
    text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.dsb-atm-balance .s{
    margin-top: 7px;
    font-size: .76rem;
    font-weight: 650;
    color: rgba(255,255,255,.65);
    letter-spacing: .01em;
}
.dsb-atm-balance .breakdown {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 5px;
    font-size: .7rem;
    font-weight: 750;
    color: rgba(255,255,255,.5);
}
.dsb-atm-balance .breakdown b { color: rgba(255,255,255,.78); font-weight: 900; }
.dsb-atm-foot{
    position: relative;
    z-index: 2;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.dsb-atm-holder{
    font-size: .77rem;
    font-weight: 900;
    letter-spacing: .10em;
    color: rgba(255,255,255,.85);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    max-width: 65%;
    text-shadow: 0 1px 8px rgba(0,0,0,.3);
}
.dsb-atm-exp{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}
.dsb-atm-exp .t{
    font-size: .55rem;
    font-weight: 950;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(255,255,255,.5);
}
.dsb-atm-exp .d{
    font-family: var(--font-mono);
    font-weight: 800;
    letter-spacing: .10em;
    color: rgba(255,255,255,.88);
    font-size: .84rem;
}

/* ── KPI pill strip ── */
.dsb-atm-kpis{
    margin-top: 12px;
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    max-width: 580px;
}
.dsb-atm-pill{
    border: 1.5px solid var(--border-soft);
    background: var(--surface);
    border-radius: 14px;
    padding: 10px 14px;
    display:flex;
    align-items: center;
    justify-content:space-between;
    gap: 8px;
    box-shadow: var(--shadow-xs);
    cursor: pointer;
    transition: border-color .15s, box-shadow .15s, transform .15s;
    min-width: 0;
    overflow: hidden;
}
.dsb-atm-pill:hover {
    border-color: var(--accent-ring);
    box-shadow: var(--shadow-sm);
    transform: translateY(-1px);
}
.dsb-atm-pill .pill-icon {
    width: 30px;
    height: 30px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .88rem;
    flex-shrink: 0;
}
.dsb-atm-pill .pill-body { flex: 1; min-width: 0; }
.dsb-atm-pill span{
    display: block;
    font-size: .62rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--text-3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dsb-atm-pill b{
    display: block;
    font-size: .78rem;
    font-weight: 950;
    letter-spacing: -.01em;
    color: var(--text);
    margin-top: 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dsb-atm-pill.pill-green .pill-icon { background: rgba(16,185,129,.12); color: #10b981; }
.dsb-atm-pill.pill-blue  .pill-icon { background: rgba(59,130,246,.12); color: #3b82f6; }
.dsb-atm-pill.pill-red   .pill-icon { background: rgba(239,68,68,.10);  color: #ef4444; }
.dsb-atm-pill.pill-amber .pill-icon { background: rgba(245,158,11,.12); color: #f59e0b; }

@media (min-width: 640px) {
    .dsb-atm-kpis { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (min-width: 860px) {
    .dsb-atm-kpis { max-width: 580px; grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .dsb-tile.hero-tile { justify-content: flex-start; }
}
@media (max-width: 420px) {
    .dsb-atm-card { padding: 18px 16px 16px; }
    .dsb-atm-balance .v { font-size: 1.75rem; }
    .dsb-atm-num { font-size: .88rem; letter-spacing: .14em; }
}

.dsb-today .dsb-mini-btn { padding: 6px 9px; }

/* ── Snapshot stacked stats ── */
.dsb-snapshot-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.dsb-snapshot-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border: 1.5px solid var(--border-soft);
    background: var(--surface-3);
    border-radius: 14px;
    cursor: pointer;
    transition: all .14s;
    min-width: 0;
    overflow: hidden;
}
.dsb-snapshot-item:hover {
    border-color: var(--accent-ring);
    box-shadow: var(--shadow-xs);
    transform: translateX(2px);
}
.dsb-snapshot-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .95rem;
    flex-shrink: 0;
}
.dsb-snapshot-icon.green  { background: rgba(16,185,129,.12); color: #10b981; }
.dsb-snapshot-icon.blue   { background: rgba(59,130,246,.12); color: #3b82f6; }
.dsb-snapshot-icon.amber  { background: rgba(245,158,11,.12); color: #f59e0b; }
.dsb-snapshot-icon.red    { background: rgba(239,68,68,.10);  color: #ef4444; }
.dsb-snapshot-icon.violet { background: rgba(139,92,246,.12); color: #8b5cf6; }
.dsb-snapshot-body { flex: 1; min-width: 0; }
.dsb-snapshot-body .k {
    font-size: .62rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--text-3);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dsb-snapshot-body .v {
    font-size: .98rem;
    font-weight: 950;
    color: var(--text);
    letter-spacing: -.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}
.dsb-snapshot-body .s {
    font-size: .70rem;
    font-weight: 650;
    color: var(--text-3);
    margin-top: 1px;
}
.dsb-snapshot-end {
    font-size: .78rem;
    font-weight: 950;
    color: var(--text-2);
    flex-shrink: 0;
    text-align: right;
}

/* Legacy today-item kept for compat */
.dsb-today-grid { display: none; }

.dsb-qa-card {
    padding: 14px 14px 12px;
    border-radius: 20px !important;
}
.dsb-qa-card .dsb-section-hdr { margin-bottom: 10px; }

.dsb-hbars { display: flex; flex-direction: column; gap: 10px; }
.dsb-hbars-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 18px 12px;
    color: var(--text-3);
    font-weight: 850;
}
.dsb-hbar-row { cursor: pointer; }
.dsb-hbar-top {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 6px;
}
.dsb-hbar-left {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    font-weight: 900;
    color: var(--text-2);
    font-size: .82rem;
}
.dsb-hbar-left span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dsb-hbar-left i { color: var(--text-3); }
.dsb-hbar-val { font-weight: 950; font-size: .82rem; color: var(--text); }
.dsb-hbar-track {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    background: var(--surface-3);
    border: 1.5px solid var(--border-soft);
    overflow: hidden;
}
.dsb-hbar-fill { height: 100%; border-radius: 999px; }

.dsb-see-all {
    background: none;
    border: none;
    font-size: .78rem;
    font-weight: 700;
    color: var(--accent-2);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0;
}

.dsb-orders-card { cursor: pointer; }
.dsb-orders-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
}
.dsb-orders-metric {
    border: 1.5px solid var(--border-soft);
    background: var(--surface-3);
    border-radius: 16px;
    padding: 12px 12px;
    min-width: 0;
    transition: all .12s var(--ease);
}
.dsb-orders-card:hover .dsb-orders-metric { border-color: var(--accent-ring); }
.dsb-orders-metric .k {
    font-size: .66rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .10em;
    color: var(--text-3);
}
.dsb-orders-metric .v {
    margin-top: 6px;
    font-size: 1.05rem;
    font-weight: 950;
    color: var(--text);
    letter-spacing: -.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dsb-orders-metric .s {
    margin-top: 4px;
    font-size: .74rem;
    font-weight: 750;
    color: var(--text-3);
}
@media (min-width: 860px) {
    .dsb-orders-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ── Analytics ── */
.dsb-analytics-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
.dsb-analytics-card {
    padding: 14px 14px 12px;
    border-radius: 20px !important;
    overflow: hidden;
}
.dsb-analytics-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.dsb-analytics-title {
    font-size: .88rem;
    font-weight: 900;
    color: var(--text);
    letter-spacing: -.01em;
}
.dsb-seg {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 3px;
    border-radius: 999px;
    border: 1.5px solid var(--border-soft);
    background: var(--surface-3);
}
.dsb-seg button {
    border: none;
    background: transparent;
    color: var(--text-2);
    font-size: .74rem;
    font-weight: 850;
    padding: 6px 10px;
    border-radius: 999px;
    cursor: pointer;
    transition: background .12s, color .12s, transform .12s;
}
.dsb-seg button:active { transform: scale(.98); }
.dsb-seg button.active {
    background: #111827;
    color: #fff;
    box-shadow: var(--shadow-xs);
}
.dsb-mini-btn {
    border: 1.5px solid var(--border-soft);
    background: var(--surface);
    color: var(--text-2);
    padding: 7px 10px;
    border-radius: 12px;
    font-size: .78rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: all .12s;
}
.dsb-mini-btn:hover { border-color: var(--accent-ring); box-shadow: var(--shadow-xs); color: var(--text); }
.dsb-analytics-chart { width: 100%; }
.dsb-analytics-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}
.dsb-stat-chip {
    flex: 1;
    min-width: 130px;
    border-radius: 16px;
    border: 1.5px solid var(--border-soft);
    background: var(--surface-3);
    padding: 10px 10px;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}
.dsb-stat-chip span {
    font-size: .66rem;
    font-weight: 950;
    color: var(--text-3);
    text-transform: uppercase;
    letter-spacing: .09em;
}
.dsb-stat-chip b {
    font-size: .88rem;
    font-weight: 950;
    color: var(--text);
    letter-spacing: -.01em;
}
.dsb-line-svg { width: 100%; height: auto; display: block; }
.dsb-line-empty {
    height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--text-3);
    font-weight: 800;
}
.dsb-line-empty i { font-size: 1.2rem; }

.dsb-analytics-donut { width: 100%; }
.dsb-donut {
    display: flex;
    gap: 12px;
    align-items: center;
}
.dsb-donut-ring {
    width: 132px;
    height: 132px;
    border-radius: 999px;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: inset 0 0 0 1px rgba(148,163,184,.25);
}
.dsb-donut-hole {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    background: var(--surface);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 10px;
    box-shadow: var(--shadow-xs);
}
.dsb-donut-big {
    font-weight: 950;
    font-size: 1.25rem;
    letter-spacing: -.02em;
    color: var(--text);
    line-height: 1.1;
}
.dsb-donut-sub {
    font-size: .72rem;
    font-weight: 800;
    color: var(--text-3);
    margin-top: 4px;
    line-height: 1.15;
}
.dsb-donut-legend {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.dsb-donut-legend-row {
    display: grid;
    grid-template-columns: 12px 1fr auto auto;
    gap: 8px;
    align-items: center;
    font-size: .76rem;
}
.dsb-donut-legend-row .dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
}
.dsb-donut-legend-row .lbl {
    font-weight: 800;
    color: var(--text-2);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dsb-donut-legend-row .pct {
    font-weight: 900;
    color: var(--text-3);
}
.dsb-donut-legend-row .amt {
    font-weight: 950;
    color: var(--text);
}

/* ── Revenue chart ── */
.dsb-chart-card {
    padding: 16px 12px 8px;
    border-radius: 20px !important;
    overflow: hidden;
}
.dsb-chart-bars {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    justify-content: space-between;
    min-height: 160px;
}
.dsb-chart-col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}
.dsb-chart-val {
    font-size: .62rem;
    font-weight: 800;
    color: var(--text-3);
    text-align: center;
    min-height: 14px;
    line-height: 1;
}
.dsb-chart-bar-wrap {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
}
.dsb-chart-bar {
    width: 100%;
    border-radius: 10px 10px 6px 6px;
    position: relative;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    transition: opacity .2s;
}
/* Top bar — solid dark green */
.dsb-chart-bar.top {
    background: #0a2e1a;
}
/* Mid bar — medium green */
.dsb-chart-bar.mid {
    background: #10b981;
}
/* Low bar — diagonal stripe pattern */
.dsb-chart-bar.low {
    background-image: repeating-linear-gradient(
        -45deg,
        rgba(148,163,184,.25) 0px,
        rgba(148,163,184,.25) 3px,
        transparent 3px,
        transparent 9px
    );
    border: 1.5px solid var(--border);
    border-radius: 10px 10px 6px 6px;
}
.dsb-chart-pct {
    font-size: .62rem;
    font-weight: 800;
    color: #fff;
    padding: 3px 0;
}
.dsb-chart-label {
    font-size: .68rem;
    font-weight: 700;
    color: var(--text-3);
    text-align: center;
}

@media (min-width: 860px) {
    .dsb-analytics-grid { grid-template-columns: 1.6fr 1fr; }
}
@media (max-width: 460px) {
    .dsb-donut { flex-direction: column; align-items: stretch; }
    .dsb-donut-ring { margin: 0 auto; }
    .dsb-donut-legend-row { grid-template-columns: 12px 1fr auto; }
    .dsb-donut-legend-row .amt { grid-column: 2 / -1; color: var(--text-2); }
    .dsb-stat-chip { min-width: 0; flex: 1 1 100%; }
}

/* ── Quick actions ── */
.dsb-qa-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    gap: 10px;
}
.dsb-qa-btn {
    background: var(--surface);
    border: 1.5px solid var(--border-soft);
    border-radius: 16px;
    padding: 14px 8px 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: .74rem;
    font-weight: 700;
    color: var(--text-2);
    transition: all .15s;
    box-shadow: var(--shadow-xs);
    min-width: 0;
}
.dsb-qa-btn span { max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dsb-qa-btn:hover {
    border-color: var(--accent-ring);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
    color: var(--text);
}
.dsb-qa-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}
.dsb-qa-icon.green  { background: rgba(16,185,129,.12);  color: #10b981; }
.dsb-qa-icon.blue   { background: rgba(59,130,246,.12);  color: #3b82f6; }
.dsb-qa-icon.amber  { background: rgba(245,158,11,.12);  color: #f59e0b; }
.dsb-qa-icon.violet { background: rgba(139,92,246,.12);  color: #8b5cf6; }
.dsb-qa-icon.teal   { background: rgba(20,184,166,.12);  color: #14b8a6; }
.dsb-qa-icon.indigo { background: rgba(99,102,241,.12);  color: #6366f1; }

/* ── Activity list ── */
.dsb-activity-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.dsb-activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--surface);
    border-radius: 14px;
    cursor: pointer;
    transition: all .15s;
    border: 1px solid transparent;
}
.dsb-activity-item:hover {
    background: var(--surface-hover);
    border-color: var(--border-soft);
}
.dsb-activity-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .78rem;
    font-weight: 800;
    flex-shrink: 0;
    color: #fff;
}
.dsb-av-green  { background: linear-gradient(135deg, #10b981, #059669); }
.dsb-av-blue   { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.dsb-av-amber  { background: linear-gradient(135deg, #f59e0b, #d97706); }
.dsb-av-violet { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.dsb-av-teal   { background: linear-gradient(135deg, #14b8a6, #0d9488); }
.dsb-activity-info {
    flex: 1;
    min-width: 0;
}
.dsb-activity-name {
    font-size: .85rem;
    font-weight: 700;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dsb-activity-sub {
    font-size: .72rem;
    color: var(--text-3);
    margin-top: 1px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dsb-activity-amount {
    font-size: .82rem;
    font-weight: 800;
    color: var(--text);
    text-align: right;
    margin-top: 2px;
}
.dsb-status-badge {
    display: inline-block;
    font-size: .68rem;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 20px;
    text-align: right;
}
.dsb-status-badge.paid       { background: rgba(16,185,129,.12);  color: #059669; }
.dsb-status-badge.inprogress { background: rgba(245,158,11,.12);  color: #d97706; }
.dsb-status-badge.pending    { background: rgba(248,113,113,.12);  color: #dc2626; }

/* ── AI FAB ── */
.dsb-ai-fab {
    position: fixed;
    bottom: calc(var(--bnav-h) + 16px);
    right: 18px;
    z-index: 900;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, #10b981, #0a2e1a);
    border: none;
    cursor: pointer;
    box-shadow: 0 6px 24px rgba(10,46,26,.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.3rem;
    transition: transform .15s, box-shadow .15s;
}
.dsb-ai-fab:hover {
    transform: scale(1.1);
    box-shadow: 0 10px 32px rgba(10,46,26,.4);
}

/* ── Desktop overrides ── */
@media (min-width: 768px) {
    .dsb-kpi-grid { grid-template-columns: 1fr 1fr 1fr; }
    .dsb-kpi-primary { grid-column: span 3; }
    .dsb-qa-grid { grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); }
    .dsb-chart-bars { gap: 10px; }
    .dsb-kpi-big { font-size: 2.4rem; }
}
@media (min-width: 1024px) {
    .dsb-greeting-biz { font-size: 1.6rem; }
    .dsb-kpi-big { font-size: 2.8rem; }
}

/* ============================================================
   COMPREHENSIVE DESIGN OVERHAUL — Mobile-first Donezo aesthetic
   All components refreshed for true app feel
   ============================================================ */

/* ── Override core variables for richer look ── */
:root {
    --bg:              #f4f6fb;
    --surface:         #ffffff;
    --surface-hover:   #f8fafc;
    --border-soft:     #eef0f6;
    --border:          #e3e7f0;
    --topbar-h:        60px;
    --bnav-h:          62px;
    --r-card:          18px;
    --r-item:          14px;
    --r-btn:           12px;
}

/* ── Topbar — cleaner, more native ── */
.topbar {
    height: var(--topbar-h);
    padding: 0 16px;
    background: rgba(255,255,255,.96);
    border-bottom: 1px solid var(--border-soft);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    box-shadow: 0 1px 0 var(--border-soft);
}
.topbar-logo {
    font-size: 1.1rem;
    font-weight: 900;
    letter-spacing: -.03em;
    color: #0a2e1a;
}
.topbar-logo span {
    background: linear-gradient(135deg, #10b981, #059669);
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.topbar-icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    border: 1.5px solid var(--border-soft);
    background: var(--surface);
    color: var(--text-2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    transition: all .15s;
}
.topbar-icon:hover { border-color: var(--accent-ring); color: var(--accent-2); }

.avatar-sm {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, #0a2e1a, #10b981);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .78rem;
    font-weight: 800;
    color: #fff;
    overflow: hidden;
    cursor: pointer;
    border: 2px solid var(--border-soft);
    transition: border-color .15s;
}
.avatar-sm:hover { border-color: var(--accent-ring); }
.avatar-sm img { width: 100%; height: 100%; object-fit: cover; }

/* ── Bottom nav — pill active state ── */
.bottom-nav {
    background: rgba(255,255,255,.97);
    border-top: 1px solid var(--border-soft);
    box-shadow: 0 -1px 0 var(--border-soft), 0 -8px 24px rgba(15,23,42,.06);
}
.bnav-item {
    gap: 2px;
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .01em;
    padding: 6px 8px;
    border-radius: 10px;
    transition: all .18s;
}
.bnav-item i { font-size: 1.2rem; }
.bnav-item.active {
    color: #0a2e1a;
    background: rgba(16,185,129,.1);
    border-radius: 12px;
}
.bnav-item.active i { transform: none; color: #0a2e1a; }
.bnav-item.active::before { display: none; } /* remove old top indicator */

/* ── Page header — section heading style ── */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
    gap: 12px;
}
.page-title {
    font-size: 1.2rem;
    font-weight: 900;
    color: var(--text);
    letter-spacing: -.025em;
    line-height: 1.2;
}
.section-label {
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-3);
    margin-bottom: 10px;
}

/* ── Cards — cleaner mobile cards ── */
.card {
    border-radius: var(--r-card) !important;
    border: 1.5px solid var(--border-soft);
    box-shadow: 0 1px 3px rgba(15,23,42,.04);
}
.card:hover { box-shadow: 0 4px 16px rgba(15,23,42,.07); }

/* ── Stat cards — redesigned ── */
.stat-grid {
    gap: 10px;
    margin-bottom: 20px;
}
.stat-card {
    border-radius: var(--r-card) !important;
    padding: 16px;
    border: 1.5px solid var(--border-soft);
    box-shadow: 0 1px 3px rgba(15,23,42,.04);
    transition: all .15s;
}
.stat-card:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15,23,42,.08); }
.card-title {
    font-size: .7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-3);
    margin-bottom: 8px;
}
.card-value {
    font-size: 1.5rem;
    font-weight: 900;
    letter-spacing: -.03em;
    line-height: 1.1;
    margin-bottom: 4px;
}
.card-sub {
    font-size: .74rem;
    color: var(--text-3);
    font-weight: 500;
    margin-top: 4px;
}

/* ── Data list — better touch targets ── */
.data-list { gap: 6px; }
.data-item {
    border-radius: var(--r-item) !important;
    padding: 13px 14px;
    border: 1.5px solid var(--border-soft);
    box-shadow: none;
    transition: all .14s;
    -webkit-tap-highlight-color: transparent;
}
.data-item:active {
    transform: scale(.99);
    background: var(--surface-hover);
}
.data-item-title {
    font-size: .9rem;
    font-weight: 700;
    color: var(--text);
}
.data-item-sub {
    font-size: .76rem;
    color: var(--text-3);
    margin-top: 2px;
}
.data-item-amount {
    font-size: .95rem;
    font-weight: 800;
    letter-spacing: -.02em;
}

/* ── Badges — pill style ── */
.badge {
    padding: 3px 9px;
    border-radius: 20px;
    font-size: .68rem;
    font-weight: 800;
    border: none !important;
}
.badge-green  { background: rgba(16,185,129,.12); color: #059669; }
.badge-amber  { background: rgba(245,158,11,.12); color: #b45309; }
.badge-red    { background: rgba(239,68,68,.1);   color: #b91c1c; }
.badge-blue   { background: rgba(59,130,246,.1);  color: #1d4ed8; }
.badge-violet { background: rgba(139,92,246,.1);  color: #6d28d9; }

/* ── Buttons — more native feel ── */
.btn {
    border-radius: var(--r-btn) !important;
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: -.01em;
    transition: all .15s;
    -webkit-tap-highlight-color: transparent;
}
.btn:active { transform: scale(.98); }
.btn-primary {
    background: #10b981;
    border: none;
    box-shadow: 0 4px 14px rgba(16,185,129,.22);
}
.btn-primary:hover {
    background: #0ea371;
    box-shadow: 0 6px 20px rgba(16,185,129,.28);
    transform: translateY(-1px);
}
.btn-outline {
    border: 1.5px solid var(--border);
    color: var(--text-2);
    background: var(--surface);
}
.btn-outline:hover { border-color: var(--accent-ring); color: var(--accent-2); }
.btn-sm { border-radius: 10px !important; font-size: .78rem; }

/* ── Forms — better mobile inputs ── */
input[type="text"], input[type="number"], input[type="email"],
input[type="tel"], input[type="password"], input[type="date"],
input[type="search"], input[type="url"], select, textarea {
    border-radius: 12px !important;
    border: 1.5px solid var(--border);
    background: var(--surface);
    font-size: .9rem;
    padding: 11px 14px;
    transition: border-color .15s, box-shadow .15s;
    -webkit-appearance: none;
    appearance: none;
}
input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: #10b981;
    box-shadow: 0 0 0 3px rgba(16,185,129,.12);
}
.input-group label {
    font-size: .78rem;
    font-weight: 700;
    color: var(--text-2);
    margin-bottom: 6px;
}

/* ── Modal — proper bottom sheet ── */
.modal-overlay {
    z-index: 400;
    align-items: flex-end;
}
.modal {
    border-radius: 24px 24px 0 0 !important;
    padding: 0;
    overflow: hidden;
    max-height: 92dvh;
    display: flex;
    flex-direction: column;
}
.modal-handle {
    width: 40px;
    height: 4px;
    background: var(--border);
    border-radius: 2px;
    margin: 12px auto 0;
    flex-shrink: 0;
}
.modal-header {
    padding: 14px 20px 14px;
    border-bottom: 1px solid var(--border-soft);
    position: relative;
    flex-shrink: 0;
}
.modal-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -.02em;
}
.modal-close {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--surface-hover);
    border: 1.5px solid var(--border-soft);
    font-size: .85rem;
}
.modal-body {
    flex: 1;
    overflow-y: auto;
    padding: 18px 20px calc(20px + var(--safe-b));
    -webkit-overflow-scrolling: touch;
}
/* When modal doesn't have an explicit modal-body, apply padding to contents */
.modal > .form-stack,
.modal > div:not(.modal-handle):not(.modal-header):not(.modal-body) {
    padding: 16px 20px calc(20px + var(--safe-b));
    overflow-y: auto;
}
@media (min-width: 768px) {
    .modal { border-radius: 20px !important; max-height: 85dvh; }
    .modal-handle { display: none; }
}

/* ── Skeleton loader — replaces the old spinner ── */
.page-skeleton {
    padding: 4px 0;
    animation: skelPulse 1.4s ease infinite;
}
.skel-header {
    height: 28px;
    width: 55%;
    background: var(--border-soft);
    border-radius: 10px;
    margin-bottom: 20px;
}
.skel-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 16px;
}
.skel-card {
    height: 90px;
    background: var(--border-soft);
    border-radius: 18px;
}
.skel-list { display: flex; flex-direction: column; gap: 8px; }
.skel-row {
    height: 64px;
    background: var(--border-soft);
    border-radius: 14px;
}
.skel-row.short { height: 48px; }
@keyframes skelPulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: .55; }
}

/* ── Info banner — refined ── */
.info-banner {
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(59,130,246,.07), rgba(99,102,241,.04));
    border: 1.5px solid rgba(59,130,246,.15);
    padding: 13px 15px;
    margin-bottom: 16px;
}

/* ── Empty state — more app-like ── */
.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    text-align: center;
}
.empty-state i {
    font-size: 2.8rem;
    color: var(--border);
    margin-bottom: 16px;
    display: block;
}
.empty-state h3 {
    font-size: 1rem;
    font-weight: 800;
    color: var(--text-2);
    margin-bottom: 6px;
}
.empty-state p {
    font-size: .84rem;
    color: var(--text-3);
    line-height: 1.55;
    max-width: 260px;
}

/* ── Tab bar — pill style ── */
.tab-bar {
    display: flex;
    gap: 4px;
    background: var(--border-soft);
    border-radius: 12px;
    padding: 3px;
    margin-bottom: 16px;
}
.tab-bar button {
    flex: 1;
    padding: 7px 10px;
    border-radius: 10px;
    border: none;
    background: transparent;
    font-size: .78rem;
    font-weight: 700;
    color: var(--text-3);
    cursor: pointer;
    transition: all .15s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}
.tab-bar button.active {
    background: var(--surface);
    color: #0a2e1a;
    box-shadow: 0 1px 4px rgba(15,23,42,.1);
}

/* ── Page loader bar — thin top progress ── */
.page-loader-bar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--border-soft);
    z-index: 9999;
}
.page-loader-bar-inner {
    height: 100%;
    background: linear-gradient(90deg, #10b981, #0a2e1a);
    animation: loaderBar 1.2s ease-in-out infinite;
}
@keyframes loaderBar {
    0%   { width: 0%;   margin-left: 0; }
    50%  { width: 60%;  margin-left: 20%; }
    100% { width: 0%;   margin-left: 100%; }
}

/* ── Form stack — better spacing ── */
.form-stack { display: flex; flex-direction: column; gap: 14px; }
.input-group { display: flex; flex-direction: column; gap: 5px; }
.input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.input-row .input-group { min-width: 0; }

/* ── Section header pattern (shared with dsb) ── */
.app-section-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.app-section-title {
    font-size: .95rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -.01em;
}

/* ── Topbar notification dot ── */
.topbar-notif-dot {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 8px;
    height: 8px;
    background: var(--red);
    border-radius: 50%;
    border: 1.5px solid var(--surface);
}

/* ── Toast — more polished ── */
.toast {
    border-radius: 14px !important;
    font-size: .85rem;
    font-weight: 700;
    box-shadow: 0 8px 24px rgba(15,23,42,.16) !important;
    padding: 12px 18px !important;
}

/* ── Quick actions sheet ── */
.qa-item {
    border-radius: 14px;
    padding: 14px 10px;
    border: 1.5px solid var(--border-soft);
    gap: 8px;
}
.qa-item i { font-size: 1.3rem; }

/* ── Page-level back navigation ── */
.page-back-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    color: var(--text-2);
    font-size: .88rem;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    transition: color .15s;
}
.page-back-btn:hover { color: var(--accent-2); }
.page-back-btn i { font-size: 1.1rem; }

/* ── Progress bar component ── */
.progress-bar-wrap {
    height: 6px;
    background: var(--border-soft);
    border-radius: 3px;
    overflow: hidden;
    margin-top: 6px;
}
.progress-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .4s var(--ease-out);
}
.progress-bar-fill.green  { background: linear-gradient(90deg, #10b981, #059669); }
.progress-bar-fill.amber  { background: linear-gradient(90deg, #f59e0b, #d97706); }
.progress-bar-fill.red    { background: linear-gradient(90deg, #ef4444, #dc2626); }

/* ── Sidebar — small refinements ── */
.sidebar { border-right: 1px solid var(--border-soft); }
.nav-item {
    border-radius: 12px;
    padding: 9px 12px;
    font-size: .87rem;
}
.nav-subitem{
    margin-left: 10px;
    padding: 8px 12px 8px 24px;
    font-size: .84rem;
}
.nav-subitem i{
    font-size: .9rem;
    opacity: .55;
}
.nav-item.active {
    background: rgba(16,185,129,.1);
    color: #0a2e1a;
}
.nav-item.active i { color: #0a2e1a; opacity: 1; }
.nav-item.active::before {
    background: linear-gradient(180deg, #10b981, #0a2e1a);
    left: 0;
    border-radius: 0 3px 3px 0;
    width: 3px;
}

/* ── Desktop polish ── */
@media (min-width: 768px) {
    .page-title { font-size: 1.35rem; }
    .card { border-radius: 20px !important; }
    .data-item { border-radius: 16px !important; padding: 14px 18px; }
    .stat-card { padding: 20px; }
    .card-value { font-size: 1.8rem; }
}

/* ---- Product image carousel (marketplace) ---- */
.mp-img-carousel { position: relative; width: 100%; overflow: hidden; background: var(--bg-soft); border-radius: 14px 14px 0 0; }
.mp-img-carousel-track { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; -ms-overflow-style: none; gap: 0; }
.mp-img-carousel-track::-webkit-scrollbar { display: none; }
.mp-carousel-img { flex: 0 0 100%; width: 100%; max-height: 38vw; object-fit: cover; scroll-snap-align: start; cursor: zoom-in; }
.mp-img-dots { display: flex; justify-content: center; gap: 6px; padding: 8px 0 4px; background: var(--bg-soft); }
.mp-img-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--border); cursor: pointer; transition: background .2s; }
.mp-img-dot.active { background: var(--primary); }
.mp-product-img { width: 100%; max-height: 55vw; object-fit: cover; border-radius: 14px 14px 0 0; display: block; }
.mp-product-img-placeholder { height: 30vw; display: flex; align-items: center; justify-content: center; background: var(--bg-soft); border-radius: 14px 14px 0 0; }

@media (min-width: 992px){
    .mp-carousel-img{max-height:300px}
}

/* ══════════════ Marketplace Homepage Redesign ══════════════ */
/* Hero carousel */
.mp-hero-carousel-wrap { position: relative; width: 100%; overflow: hidden; border-radius: 0 0 20px 20px; margin-bottom: 0; background: #1e1b4b; }
.mp-hero-track { position: relative; width: 100%; }
.mp-hero-slide { position: relative; width: 100%; min-height: 260px; display: none; align-items: center; background: linear-gradient(135deg,#1e1b4b,#4338ca); }
.mp-hero-slide.active { display: flex; }
.mp-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.65) 0%, rgba(0,0,0,.2) 60%, transparent 100%); }
.mp-hero-content { position: relative; z-index: 2; padding: 32px 20px 56px; color: #fff; }
.mp-hero-title { font-size: 1.4rem; font-weight: 900; line-height: 1.2; margin-bottom: 8px; font-family: var(--font-display); }
.mp-hero-sub { font-size: .88rem; opacity: .85; margin-bottom: 18px; line-height: 1.5; }
.mp-hero-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(255,255,255,.15); backdrop-filter: blur(6px); padding: 4px 12px; border-radius: 100px; font-size: .78rem; font-weight: 700; margin-bottom: 12px; }
.mp-hero-cta { display: flex; gap: 10px; flex-wrap: wrap; }
.mp-hero-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; background: rgba(255,255,255,.18); backdrop-filter: blur(6px); border: none; color: #fff; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1rem; transition: background .2s; }
.mp-hero-arrow:hover { background: rgba(255,255,255,.35); }
.mp-hero-prev { left: 12px; }
.mp-hero-next { right: 12px; }
.mp-hero-dots { position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; z-index: 10; }
.mp-hero-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; transition: all .2s; }
.mp-hero-dot.active { background: #fff; width: 22px; border-radius: 4px; }

/* Section headers */
.mp-section-hdr { display: flex; justify-content: space-between; align-items: center; padding: 16px 0 8px; font-weight: 800; font-size: .95rem; color: var(--text); }
.mp-section-hdr .btn-link { font-size: .82rem; color: var(--accent); font-weight: 700; background: none; border: none; cursor: pointer; padding: 0; }

/* Horizontal scroll rows */
.mp-hscroll-row { display: flex; gap: 12px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 8px; scrollbar-width: none; -ms-overflow-style: none; }
.mp-hscroll-row::-webkit-scrollbar { display: none; }
.mp-hscroll-skeleton { width: 140px; height: 200px; border-radius: 14px; background: var(--bg-soft); flex-shrink: 0; animation: shimmer 1.2s infinite; }

/* Mini product cards (horizontal scroll) */
.mp-mini-card { flex: 0 0 140px; border-radius: 14px; background: var(--surface); border: 1px solid var(--border-light); overflow: hidden; cursor: pointer; scroll-snap-align: start; transition: box-shadow .15s; }
.mp-mini-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,.1); }
.mp-mini-img { width: 100%; height: 130px; position: relative; background: var(--bg-soft); }
.mp-mini-info { padding: 8px 10px 10px; }
.mp-mini-name { font-size: .8rem; font-weight: 700; line-height: 1.3; color: var(--text); overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.mp-mini-price { font-size: .85rem; font-weight: 800; color: var(--accent); margin-top: 4px; }

/* Store cards (horizontal scroll) */
.mp-store-mini-card { flex: 0 0 150px; border-radius: 14px; background: var(--surface); border: 1px solid var(--border-light); overflow: hidden; cursor: pointer; scroll-snap-align: start; transition: box-shadow .15s; }
.mp-store-mini-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,.1); }
.mp-store-mini-banner { width: 100%; height: 70px; background: var(--bg-soft); }
.mp-store-mini-body { padding: 8px 10px 12px; text-align: center; }
.mp-store-mini-logo { width: 42px; height: 42px; border-radius: 50%; overflow: hidden; margin: -24px auto 6px; border: 2px solid var(--surface); background: var(--bg-soft); display: flex; align-items: center; justify-content: center; }
.mp-store-mini-logo img { width: 100%; height: 100%; object-fit: cover; }
.mp-store-mini-name { font-size: .82rem; font-weight: 800; color: var(--text); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.mp-store-mini-sub { font-size: .74rem; color: var(--text-3); margin-top: 2px; }

/* Category banner */
.mp-cat-banner { width: 100%; height: 120px; border-radius: 14px; margin-bottom: 4px; background: var(--bg-soft); }
.mp-cat-section { margin-bottom: 8px; }

/* Back to top */
.mp-back-top { position: fixed; bottom: 88px; right: 16px; width: 44px; height: 44px; border-radius: 50%; background: var(--primary); color: #fff; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; box-shadow: 0 4px 16px rgba(0,0,0,.2); z-index: 1100; transition: opacity .2s; }
.mp-back-top:hover { opacity: .85; }
