:root{
    --bg:#eef4f7;
    --bg-2:#f8fbff;
    --ink:#07111f;
    --text:#101827;
    --muted:#667085;
    --soft:#eef2f6;
    --line:rgba(15,23,42,.105);
    --line-strong:rgba(15,23,42,.16);
    --card:rgba(255,255,255,.84);
    --card-solid:#ffffff;
    --nav:#071323;
    --nav-2:#0d2038;
    --nav-3:#102a49;
    --green:#16c784;
    --green-2:#0f9f6e;
    --emerald:#047857;
    --blue:#2563eb;
    --blue-2:#0ea5e9;
    --gold:#d9a441;
    --gold-2:#f5c76b;
    --red:#ef4444;
    --orange:#f59e0b;
    --purple:#7c3aed;
    --radius:26px;
    --radius-md:20px;
    --radius-sm:14px;
    --shadow:0 26px 80px rgba(15,23,42,.13);
    --shadow-soft:0 14px 36px rgba(15,23,42,.085);
    --shadow-hover:0 30px 80px rgba(15,23,42,.17);
    --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    min-height:100vh;
    color:var(--text);
    font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
    background:
        radial-gradient(circle at 88% 5%, rgba(22,199,132,.22), transparent 28%),
        radial-gradient(circle at 27% -5%, rgba(217,164,65,.17), transparent 32%),
        radial-gradient(circle at 12% 92%, rgba(37,99,235,.10), transparent 30%),
        linear-gradient(135deg,#f8fbff 0%,#eef6f2 47%,#eef4ff 100%);
    overflow-x:hidden;
}
body:before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    opacity:.46;
    background-image:
        linear-gradient(rgba(15,23,42,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15,23,42,.03) 1px, transparent 1px);
    background-size:44px 44px;
    mask-image:linear-gradient(to bottom, rgba(0,0,0,.95), transparent 84%);
}

a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
::selection{background:rgba(22,199,132,.24)}
.muted{color:var(--muted)!important;font-weight:700}.small{font-size:12px}.strong{font-weight:950}.hide-print{}

.app-shell{display:flex;min-height:100vh;position:relative;z-index:1}
.sidebar{
    position:fixed;
    inset:0 auto 0 0;
    width:300px;
    z-index:40;
    padding:22px 18px;
    color:#eaf3ff;
    background:
        radial-gradient(circle at 8% 0%, rgba(22,199,132,.31), transparent 34%),
        radial-gradient(circle at 105% 20%, rgba(217,164,65,.17), transparent 32%),
        linear-gradient(180deg,rgba(7,19,35,.985),rgba(10,25,49,.985));
    box-shadow:22px 0 70px rgba(6,14,28,.23);
    overflow-y:auto;
    scrollbar-width:thin;
    border-right:1px solid rgba(255,255,255,.085);
}
.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(4,10,20,.48);backdrop-filter:blur(5px);z-index:30}

.brand{
    display:flex;align-items:center;gap:14px;
    padding:8px 8px 20px;
    border-bottom:1px solid rgba(255,255,255,.09);
    margin-bottom:18px;
}
.brand-logo{
    width:58px;height:58px;min-width:58px;border-radius:20px;display:grid;place-items:center;overflow:hidden;
    color:white;font-weight:950;font-size:24px;letter-spacing:-.03em;
    background:linear-gradient(135deg,var(--green),#34d399 52%,#0d6f51);
    box-shadow:0 18px 40px rgba(22,199,132,.33), inset 0 1px 0 rgba(255,255,255,.28);
}
.brand-logo img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.brand-text{min-width:0}.brand-text strong{display:block;font-size:21px;line-height:1.08;color:#fff;letter-spacing:-.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-text span{display:block;margin-top:5px;color:#a6f2d1;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-status{display:inline-flex;align-items:center;gap:6px;margin-top:10px;border-radius:999px;padding:5px 9px;background:rgba(22,199,132,.12);color:#b7f7da;font-size:10px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(22,199,132,.22)}.brand-status:before{content:"";width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 4px rgba(52,211,153,.14)}

.nav-section{margin-top:20px}.nav-title{padding:0 14px 8px;color:#8aa1bd;font-size:11px;font-weight:950;letter-spacing:.17em;text-transform:uppercase}.nav-link{
    display:flex;align-items:center;gap:12px;margin:6px 0;padding:12px 14px;border-radius:18px;
    color:#dbe7f8;font-size:14px;font-weight:850;transition:transform .2s var(--ease), color .2s ease, background .2s ease, box-shadow .2s ease;position:relative;isolation:isolate;
}
.nav-link:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(22,199,132,.20),rgba(255,255,255,.075));opacity:0;transition:.22s ease;z-index:-1}.nav-link:after{content:"";position:absolute;left:0;top:50%;width:4px;height:0;border-radius:999px;background:linear-gradient(180deg,var(--green),var(--gold));transform:translateY(-50%);transition:.22s ease}.nav-link .ico{width:32px;height:32px;display:inline-grid;place-items:center;border-radius:12px;font-size:16px;background:rgba(255,255,255,.07);color:#dff7ec;transition:.2s ease}.nav-link:hover{transform:translateX(5px);color:#fff}.nav-link:hover:before,.nav-link.active:before{opacity:1}.nav-link.active{color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.nav-link.active:after{height:26px}.nav-link.active .ico{background:rgba(22,199,132,.18);color:#9ef5ca;box-shadow:inset 0 0 0 1px rgba(22,199,132,.18)}
.user-panel{margin-top:24px;padding:16px;border:1px solid rgba(255,255,255,.105);border-radius:22px;background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.04));box-shadow:inset 0 1px 0 rgba(255,255,255,.09)}.user-panel strong{display:block;color:#fff;font-size:15px}.user-panel span{display:block;color:#95a8c2;margin-top:3px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.09em}.logout-btn,.btn-logout{width:100%;margin-top:12px;border:0;border-radius:15px;padding:12px 14px;background:linear-gradient(135deg,#fb7185,#dc2626);color:white;font-weight:950;box-shadow:0 14px 28px rgba(220,38,38,.22);transition:.2s var(--ease)}.logout-btn:hover,.btn-logout:hover{transform:translateY(-2px);filter:saturate(1.08)}

.main{margin-left:300px;width:calc(100% - 300px);min-height:100vh;padding:28px 32px 52px;position:relative}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:26px;padding:6px 0}.topbar-left{display:flex;align-items:center;gap:13px;min-width:0}.mobile-toggle{display:none;border:1px solid rgba(255,255,255,.7);border-radius:16px;padding:10px 12px;background:rgba(255,255,255,.83);box-shadow:var(--shadow-soft);font-weight:950;color:#0f172a}.page-kicker{font-size:12px;color:var(--emerald);font-weight:950;letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}h1,.page-title{font-size:40px;line-height:1.05;margin:0;color:#071126;letter-spacing:-.06em;font-weight:950}.page-subtitle{margin:8px 0 0;color:var(--muted);font-size:15px;line-height:1.55;font-weight:650}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.pill,.date-pill,.role-pill,.clock-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(15,23,42,.09);border-radius:999px;padding:11px 15px;background:rgba(255,255,255,.76);color:#0f172a;font-weight:950;box-shadow:0 14px 28px rgba(15,23,42,.07);backdrop-filter:blur(14px)}.date-pill{border-color:rgba(22,199,132,.20);background:rgba(220,252,231,.76);color:#047857}.role-pill{background:rgba(255,255,255,.72);color:#0f172a}.clock-pill{color:#334155}.quick-action{padding-inline:16px!important}
.content-area{animation:fadeUp .34s var(--ease) both}@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.card,.panel,.receipt-card{background:var(--card);border:1px solid rgba(255,255,255,.82);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px;margin-bottom:22px;backdrop-filter:blur(18px);transition:box-shadow .24s var(--ease), transform .24s var(--ease), border-color .24s ease}.card:hover,.panel:hover{box-shadow:var(--shadow);border-color:rgba(255,255,255,.94)}.card h2,.card h3,.panel h2,.panel h3{margin-top:0;letter-spacing:-.04em;color:#0b1324}.card h2{font-size:24px}.card h3{font-size:20px}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

.hero-card{position:relative;overflow:hidden;min-height:220px;padding:28px;border-radius:32px;color:white;background:radial-gradient(circle at 78% 18%, rgba(217,164,65,.35), transparent 28%),radial-gradient(circle at 15% 20%, rgba(22,199,132,.35), transparent 31%),linear-gradient(135deg,#071323,#0d2038 55%,#12365a);box-shadow:0 28px 90px rgba(6,18,37,.28);border:1px solid rgba(255,255,255,.12)}.hero-card:before{content:"";position:absolute;right:-80px;bottom:-95px;width:310px;height:310px;border-radius:50%;background:rgba(255,255,255,.065)}.hero-card:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(255,255,255,.12),transparent 35%,rgba(255,255,255,.05));pointer-events:none}.hero-card>*{position:relative;z-index:1}.hero-kicker{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.10);border-radius:999px;padding:8px 12px;color:#bdf7dc;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.12em}.hero-title{font-size:38px;line-height:1.08;margin:18px 0 8px;color:#fff;letter-spacing:-.055em}.hero-subtitle{max-width:720px;margin:0;color:#bad0ea;line-height:1.65;font-weight:700}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.hero-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}.hero-metric{border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:14px;background:rgba(255,255,255,.08);backdrop-filter:blur(12px)}.hero-metric span{display:block;color:#9fb3cc;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.09em}.hero-metric strong{display:block;margin-top:6px;font-size:22px;letter-spacing:-.035em;color:#fff}

.stat,.stat-card{position:relative;overflow:hidden;min-height:120px;padding:22px;border-radius:24px;background:rgba(255,255,255,.88);border:1px solid rgba(255,255,255,.86);box-shadow:var(--shadow-soft);transition:transform .22s var(--ease),box-shadow .22s var(--ease)}.stat:hover,.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}.stat:after,.stat-card:after{content:"";position:absolute;right:-30px;top:-30px;width:112px;height:112px;border-radius:50%;background:linear-gradient(135deg,rgba(22,199,132,.17),rgba(217,164,65,.16));pointer-events:none}.stat-icon{width:43px;height:43px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(22,199,132,.14),rgba(37,99,235,.10));color:#047857;font-size:20px;margin-bottom:12px}.stat-label,.stat span{display:block;color:var(--muted);font-size:13px;font-weight:900;letter-spacing:.02em}.stat-value,.stat strong{display:block;font-size:31px;font-weight:950;letter-spacing:-.055em;margin-top:7px;color:#071126}.stat-note{font-size:12px;color:var(--muted);margin-top:8px;font-weight:750;position:relative;z-index:1}

.toolbar{display:flex!important;align-items:center!important;justify-content:space-between;gap:14px;flex-wrap:wrap}.toolbar .import-box{flex:1 1 430px}.import-box{padding:14px;border-radius:20px;background:rgba(248,250,252,.82);border:1px dashed rgba(100,116,139,.35);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.import-box form{margin:0}.import-box input{margin-bottom:0!important}

.btn,.button,button.btn,a.btn,input[type="submit"].btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;border-radius:15px;padding:11px 17px;background:#e9eef6;color:#0f172a;font-weight:950;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),filter .2s ease,text-decoration .2s ease;text-decoration:none;white-space:nowrap}.btn:hover,.button:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(15,23,42,.14)}.btn-primary,.btn.btn-primary,.btn-success,.btn.btn-success,.btn:not(.btn-danger):not(.btn-warning):not(.btn-secondary):not(.btn-outline):not(.btn-dark):not(.btn-info){background:linear-gradient(135deg,var(--green),var(--green-2));color:white;box-shadow:0 15px 30px rgba(22,199,132,.23)}.btn-danger{background:linear-gradient(135deg,#fb7185,#dc2626);color:white;box-shadow:0 15px 30px rgba(239,68,68,.18)}.btn-warning{background:linear-gradient(135deg,#f7c766,#f59e0b);color:#251800;box-shadow:0 15px 30px rgba(245,158,11,.18)}.btn-secondary{background:linear-gradient(135deg,#fff,#e9eef6);color:#0f172a}.btn-dark{background:linear-gradient(135deg,#334155,#0f172a);color:#fff}.btn-info{background:linear-gradient(135deg,#38bdf8,#2563eb);color:#fff}.btn-outline{background:rgba(255,255,255,.68);color:#0f172a;border:1px solid var(--line)!important}.btn-sm,.actions .btn{min-height:38px;padding:9px 13px!important;border-radius:13px!important;font-size:13px!important}.actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.actions form{display:inline-flex;margin:0}

.alert,.success,.error{border-radius:18px;padding:14px 16px;margin:0 0 18px;border:1px solid rgba(22,163,74,.22);background:rgba(220,252,231,.86);color:#166534;font-weight:850;box-shadow:0 12px 26px rgba(22,163,74,.08)}.error,.alert-danger{background:rgba(254,226,226,.91);border-color:rgba(239,68,68,.25);color:#991b1b}

.table-wrap,.table-responsive{overflow:auto;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.68);box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}table{width:100%;border-collapse:separate;border-spacing:0;background:transparent;overflow:hidden}th,td{padding:15px 16px;text-align:left;border-bottom:1px solid rgba(15,23,42,.075);vertical-align:middle}th{font-size:11px;text-transform:uppercase;letter-spacing:.095em;color:#536073;background:rgba(248,250,252,.78);font-weight:950;white-space:nowrap}td{font-weight:720;color:#172033}tr:last-child td{border-bottom:0}tbody tr{transition:background .16s ease}tbody tr:hover{background:rgba(22,199,132,.048)}td strong{font-weight:950;color:#0f172a}
.badge{display:inline-flex;align-items:center;justify-content:center;gap:5px;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950;background:#e9eef6;color:#334155;line-height:1}.badge-success,.badge-green{background:#dcfce7;color:#047857}.badge-warning,.badge-yellow{background:#fef3c7;color:#92400e}.badge-danger,.badge-red{background:#fee2e2;color:#b91c1c}.badge-info,.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-purple{background:#ede9fe;color:#6d28d9}

label{display:block;font-weight:900;margin:0 0 8px;color:#1a2436}input,select,textarea{width:100%;border:1px solid rgba(15,23,42,.135);border-radius:16px;background:rgba(255,255,255,.88);color:#0f172a;padding:12px 14px;outline:0;transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.72);margin-bottom:15px}textarea{min-height:98px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:rgba(22,199,132,.62);box-shadow:0 0 0 4px rgba(22,199,132,.12),inset 0 1px 0 rgba(255,255,255,.7);background:#fff}input[readonly]{background:rgba(241,245,249,.76);color:#475569}.form-group{min-width:0}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px}.form-grid .full{grid-column:1/-1}small.muted{display:inline-block;margin-top:-6px;margin-bottom:12px}
input[type="file"]{border:1px dashed #cbd5e1!important;background:linear-gradient(135deg,#ffffff,#f8fafc)!important;cursor:pointer}input[type="file"]::file-selector-button{margin-right:12px;border:0;border-radius:12px;padding:9px 13px;background:linear-gradient(135deg,#0f172a,#334155);color:white;font-weight:900;cursor:pointer}

.pos-layout{display:grid;grid-template-columns:minmax(0,1.45fr) 430px;gap:22px;align-items:start}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:14px}.product-card{position:relative;border:1px solid rgba(15,23,42,.10);background:rgba(255,255,255,.82);border-radius:22px;padding:16px;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s ease;overflow:hidden}.product-card:after{content:"";position:absolute;right:-22px;top:-22px;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,rgba(22,199,132,.13),rgba(37,99,235,.10))}.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:rgba(22,199,132,.32)}.product-card strong{display:block;font-size:15px;margin-bottom:8px;position:relative;z-index:1}.product-img{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:grid;place-items:center;margin-bottom:12px;font-size:20px}.product-price{color:#047857;font-weight:950}.cart-panel{position:sticky;top:22px}.cart-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid rgba(15,23,42,.075)}.cart-item:last-child{border-bottom:0}.qty{display:inline-flex;align-items:center;gap:7px}.qty button{border:0;width:30px;height:30px;border-radius:10px;background:#edf2f7;color:#0f172a;font-weight:950}.total-box{border-radius:24px;padding:18px;background:radial-gradient(circle at 90% 18%,rgba(217,164,65,.28),transparent 30%),linear-gradient(135deg,#071323,#123a61);color:white;box-shadow:var(--shadow);margin:18px 0}.total-box .label,.total-box span{display:block;color:#9fb3cc;font-weight:900}.total-box .amount,.total-box strong{display:block;font-size:34px;font-weight:950;letter-spacing:-.055em;margin-top:5px;color:#fff}

.receipt-paper{max-width:360px;background:#fff;color:#000;border-radius:0;padding:18px;margin:auto;font-family:"Courier New",monospace;box-shadow:0 18px 45px rgba(15,23,42,.12)}.receipt-center{text-align:center}.receipt-line,.line{border-top:1px dashed #111;margin:10px 0}.receipt-paper table th,.receipt-paper table td{padding:5px 0;border:0;background:#fff;color:#000;font-size:12px}.receipt-paper h2{font-size:17px;margin:0 0 4px}.receipt-paper p{margin:4px 0;font-size:12px}.row{display:flex;justify-content:space-between;gap:10px}.center{text-align:center}.status-ok{font-weight:950}

.login-page{min-height:100vh;display:grid;place-items:center;padding:30px;background:radial-gradient(circle at 16% 12%,rgba(22,199,132,.30),transparent 30%),radial-gradient(circle at 82% 16%,rgba(217,164,65,.22),transparent 28%),linear-gradient(135deg,#06101d,#0c1d34 53%,#12365b);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;inset:auto -10% -38% auto;width:620px;height:620px;border-radius:50%;background:rgba(255,255,255,.06)}.login-wrap{width:min(100%,1000px);display:grid;grid-template-columns:1.08fr .92fr;border-radius:34px;overflow:hidden;box-shadow:0 34px 110px rgba(0,0,0,.36);border:1px solid rgba(255,255,255,.16);position:relative;z-index:1}.login-showcase{padding:42px;color:#fff;background:radial-gradient(circle at 20% 18%,rgba(22,199,132,.22),transparent 32%),linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.035));backdrop-filter:blur(18px);display:flex;flex-direction:column;justify-content:space-between;min-height:560px}.login-showcase h1{color:#fff;font-size:42px;margin:16px 0 10px}.login-showcase p{color:#bfd0e6;line-height:1.65;font-weight:700;max-width:520px}.login-features{display:grid;gap:12px;margin-top:28px}.login-feature{display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.075);border-radius:18px;padding:13px 14px;color:#eaf3ff;font-weight:850}.login-feature i{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:rgba(22,199,132,.16);color:#a7f3d0}.login-card{width:100%;padding:38px;background:rgba(255,255,255,.94);backdrop-filter:blur(18px)}.login-brand{text-align:center;margin-bottom:24px}.login-brand .brand-logo{margin:0 auto 14px}.login-brand h1{font-size:30px;margin:0}.login-brand p{margin:8px 0 0;color:var(--muted);font-weight:800}.login-store-meta{margin-top:12px;display:grid;gap:7px;color:#64748b;font-size:13px}.login-store-meta span{display:inline-flex;align-items:center;justify-content:center;gap:7px}.login-footer{text-align:center;color:#bfd0e6;margin-top:18px;font-size:12px;font-weight:800;position:relative;z-index:1}.btn-login{min-height:48px!important}

.pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.pagination a,.pagination span{border-radius:12px;padding:8px 12px;background:#fff;border:1px solid var(--line);font-weight:850;color:#0f172a}.pagination .active span{background:var(--green);color:#fff;border-color:transparent}.profile-preview{display:flex;align-items:center;gap:16px;padding:18px;border:1px solid var(--line);border-radius:20px;background:rgba(248,250,252,.74);margin:18px 0}.preview-logo{width:76px;height:76px;border-radius:24px;background:linear-gradient(135deg,#22c55e,#14b8a6);display:grid;place-items:center;color:white;font-weight:950;font-size:34px;overflow:hidden;box-shadow:0 18px 35px rgba(34,197,94,.25)}.preview-logo img{width:100%;height:100%;object-fit:cover}.thermal-preview{width:80mm;max-width:100%;font-family:"Courier New",monospace;background:#fff;color:#000;border:1px solid #e5e7eb;padding:12px;margin-top:16px;box-shadow:0 14px 35px rgba(15,23,42,.08)}

@media (max-width:1180px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.pos-layout{grid-template-columns:1fr}.cart-panel{position:static}.sidebar{width:282px}.main{margin-left:282px;width:calc(100% - 282px);padding:24px}.login-wrap{grid-template-columns:1fr}.login-showcase{min-height:auto}.login-showcase .login-features{grid-template-columns:repeat(3,1fr)}}
@media (max-width:860px){.sidebar{transform:translateX(-100%);transition:transform .28s var(--ease)}.sidebar.open{transform:translateX(0)}.sidebar-overlay.show{display:block}.main{margin-left:0;width:100%;padding:18px}.mobile-toggle{display:inline-flex}.topbar{align-items:flex-start;flex-direction:column}.top-actions{justify-content:flex-start}.grid-2,.grid-3,.grid-4,.form-grid,.hero-metrics{grid-template-columns:1fr}h1,.page-title{font-size:32px}.hero-title{font-size:31px}.card{padding:18px}.product-grid{grid-template-columns:repeat(auto-fill,minmax(135px,1fr))}.login-showcase{display:none}.login-wrap{display:block}.login-card{padding:30px}.toolbar{align-items:stretch!important}.toolbar .btn{width:100%}.import-box{display:grid}.import-box .btn{width:100%}}
@media (max-width:560px){.main{padding:15px}.top-actions .quick-action{width:100%}.role-pill,.date-pill,.clock-pill{width:100%;justify-content:center}.hero-card{padding:22px;border-radius:26px}.stat-value,.stat strong{font-size:27px}.table-wrap,.table-responsive{border-radius:18px}.login-page{padding:18px}.login-card{padding:24px}.btn,.logout-btn{width:100%}.actions .btn,.actions form,.actions button{width:100%}}

@media print{body{background:#fff!important}.sidebar,.topbar,.sidebar-overlay,.no-print,.hide-print,.btn,.actions,button,a.btn{display:none!important}.main{margin:0!important;width:100%!important;padding:0!important}.card,.panel,.receipt-card{box-shadow:none!important;border:0!important;padding:0!important;margin:0!important;background:#fff!important}.receipt-paper{box-shadow:none!important;margin:0!important;width:var(--receipt-width,80mm)!important;max-width:var(--receipt-width,80mm)!important;padding:0 3mm!important}.table-wrap,.table-responsive{border:0!important}table{font-size:12px!important}}
.btn.is-loading{pointer-events:none;opacity:.72}.btn.is-loading:before{content:"";width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================
   MOBILE PREMIUM UX PATCH - optimized for phone usage
   ========================================================= */
:root{
    --safe-bottom: env(safe-area-inset-bottom, 0px);
    --mobile-nav-height: 78px;
}
.mobile-bottom-nav{display:none}
.mobile-only{display:none!important}

@media (max-width:860px){
    body{
        background:
            radial-gradient(circle at 85% 0%, rgba(22,199,132,.18), transparent 30%),
            radial-gradient(circle at 0% 16%, rgba(217,164,65,.13), transparent 28%),
            linear-gradient(180deg,#f8fbff 0%,#eef6f3 48%,#f3f7ff 100%);
        -webkit-tap-highlight-color:transparent;
    }
    body:has(.sidebar.open){overflow:hidden}
    .app-shell{display:block;min-height:100dvh}
    .main{
        padding:14px 14px calc(var(--mobile-nav-height) + var(--safe-bottom) + 26px);
        min-height:100dvh;
    }
    .content-area{padding-bottom:8px}
    .sidebar{
        width:min(86vw,360px);
        padding:18px 15px calc(var(--mobile-nav-height) + 18px);
        border-radius:0 30px 30px 0;
        box-shadow:28px 0 90px rgba(4,10,20,.38);
    }
    .sidebar.open{transform:translateX(0);animation:drawerIn .28s var(--ease) both}
    @keyframes drawerIn{from{filter:blur(2px)}to{filter:blur(0)}}
    .sidebar-overlay.show{display:block;animation:fadeOverlay .2s ease both}
    @keyframes fadeOverlay{from{opacity:0}to{opacity:1}}
    .brand{padding:6px 6px 16px;margin-bottom:12px}
    .brand-logo{width:52px;height:52px;min-width:52px;border-radius:18px}
    .brand-text strong{font-size:18px}
    .brand-status{display:none}
    .nav-section{margin-top:14px}
    .nav-title{font-size:10px;padding-left:10px}
    .nav-link{min-height:48px;border-radius:17px;margin:5px 0;padding:10px 12px;font-size:13.5px}
    .nav-link .ico{width:33px;height:33px}

    .topbar{
        position:sticky;
        top:0;
        z-index:25;
        margin:-14px -14px 14px;
        padding:12px 14px 10px;
        background:linear-gradient(180deg,rgba(248,251,255,.96),rgba(248,251,255,.80));
        border-bottom:1px solid rgba(15,23,42,.075);
        backdrop-filter:blur(18px);
        box-shadow:0 12px 30px rgba(15,23,42,.06);
    }
    .topbar-left{width:100%;align-items:flex-start}
    .mobile-toggle{
        display:inline-flex;
        width:46px;
        height:46px;
        padding:0;
        justify-content:center;
        align-items:center;
        border-radius:16px;
        flex:0 0 auto;
        background:linear-gradient(135deg,#ffffff,#eef4f7);
    }
    .mobile-toggle i{font-size:23px}
    .page-kicker{font-size:10px;margin-bottom:2px;letter-spacing:.11em}
    h1,.page-title{font-size:26px;letter-spacing:-.045em;line-height:1.08}
    .page-subtitle{font-size:12.5px;line-height:1.45;margin-top:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .top-actions{
        width:100%;
        display:flex;
        flex-wrap:nowrap;
        overflow-x:auto;
        justify-content:flex-start;
        gap:8px;
        padding:2px 2px 4px;
        margin-top:2px;
        scrollbar-width:none;
    }
    .top-actions::-webkit-scrollbar{display:none}
    .top-actions .quick-action,
    .role-pill,.date-pill,.clock-pill{
        width:auto!important;
        min-height:38px;
        flex:0 0 auto;
        padding:9px 12px;
        justify-content:center;
        font-size:12px;
        box-shadow:0 9px 18px rgba(15,23,42,.055);
    }

    .mobile-bottom-nav{
        position:fixed;
        left:10px;
        right:10px;
        bottom:calc(10px + var(--safe-bottom));
        z-index:35;
        display:grid;
        grid-template-columns:repeat(5,1fr);
        gap:5px;
        min-height:68px;
        padding:8px;
        border-radius:26px;
        background:rgba(7,19,35,.91);
        border:1px solid rgba(255,255,255,.13);
        box-shadow:0 24px 70px rgba(4,10,20,.34), inset 0 1px 0 rgba(255,255,255,.12);
        backdrop-filter:blur(22px);
    }
    .mobile-nav-item{
        display:flex;
        flex-direction:column;
        align-items:center;
        justify-content:center;
        gap:4px;
        min-width:0;
        border:0;
        border-radius:18px;
        background:transparent;
        color:#9fb3cc;
        font-weight:950;
        font-size:10px;
        line-height:1;
        transition:background .18s ease,color .18s ease, transform .18s var(--ease);
    }
    .mobile-nav-item i{font-size:18px;line-height:1}
    .mobile-nav-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
    .mobile-nav-item.active,
    .mobile-nav-item:hover{
        background:linear-gradient(135deg,rgba(22,199,132,.22),rgba(217,164,65,.11));
        color:#eafff5;
        transform:translateY(-1px);
    }
    .mobile-nav-button{font:inherit;cursor:pointer}

    .card,.panel,.receipt-card{
        border-radius:23px;
        padding:17px;
        margin-bottom:15px;
        box-shadow:0 12px 34px rgba(15,23,42,.075);
    }
    .card:hover,.panel:hover{box-shadow:0 12px 34px rgba(15,23,42,.08)}
    .card h2,.panel h2{font-size:20px;line-height:1.15;margin-bottom:8px}
    .card h3,.panel h3{font-size:17px}

    .hero-card{
        min-height:auto;
        padding:20px;
        border-radius:27px;
        box-shadow:0 20px 60px rgba(6,18,37,.22);
    }
    .hero-kicker{font-size:10px;padding:7px 10px}
    .hero-title{font-size:27px;letter-spacing:-.045em;margin:14px 0 8px}
    .hero-subtitle{font-size:13px;line-height:1.55}
    .hero-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:16px}
    .hero-actions .btn{width:100%;min-height:45px}
    .hero-metrics{display:flex!important;grid-template-columns:none!important;overflow-x:auto;gap:10px;margin-top:17px;scroll-snap-type:x mandatory;padding-bottom:4px;scrollbar-width:none}
    .hero-metrics::-webkit-scrollbar{display:none}
    .hero-metric{min-width:78%;scroll-snap-align:start;border-radius:18px;padding:13px}
    .hero-metric strong{font-size:20px}

    .grid{gap:14px}
    .stat,.stat-card{min-height:auto;padding:17px;border-radius:21px}
    .stat-icon{width:38px;height:38px;border-radius:14px;margin-bottom:10px}
    .stat-value,.stat strong{font-size:26px}
    .stat-label,.stat span{font-size:12px}
    .stat-note{font-size:11.5px}

    .toolbar{
        align-items:stretch!important;
        gap:10px!important;
    }
    .toolbar > div:first-child{min-width:0}
    .toolbar .btn{width:100%;min-height:44px}
    .import-box{
        width:100%;
        display:grid!important;
        grid-template-columns:1fr;
        gap:9px;
        border-radius:18px;
        padding:12px;
    }
    .import-box form{display:grid;gap:9px;width:100%}
    .import-box input[type="file"]{font-size:12px;padding:10px;background:#fff}

    .btn,.button,button.btn,a.btn,input[type="submit"].btn{
        min-height:44px;
        border-radius:15px;
        padding:11px 14px;
        white-space:normal;
        text-align:center;
    }
    .btn-sm,.actions .btn{min-height:40px!important}
    .actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;width:100%}
    .actions form,.actions a,.actions button{width:100%!important}

    label{font-size:13px;margin-bottom:7px}
    input,select,textarea{
        min-height:46px;
        border-radius:15px;
        padding:11px 13px;
        margin-bottom:13px;
        font-size:16px; /* prevent iOS zoom */
    }
    textarea{min-height:88px}
    .form-grid{grid-template-columns:1fr!important;gap:6px}

    .pagination{justify-content:center;gap:6px}.pagination a,.pagination span{padding:8px 10px;font-size:12px}
    .profile-preview{align-items:flex-start;border-radius:18px;padding:14px}.preview-logo{width:62px;height:62px;border-radius:20px;font-size:27px}
}

@media (max-width:640px){
    .main{padding-left:12px;padding-right:12px}
    .topbar{margin-left:-12px;margin-right:-12px;padding-left:12px;padding-right:12px}
    .grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important}

    .table-wrap,.table-responsive{
        overflow:visible;
        border:0;
        background:transparent;
        box-shadow:none;
    }
    table.mobile-card-table,
    table.mobile-card-table tbody,
    table.mobile-card-table tr,
    table.mobile-card-table td{display:block;width:100%}
    table.mobile-card-table thead{display:none}
    table.mobile-card-table tr{
        margin-bottom:12px;
        border:1px solid rgba(15,23,42,.085);
        border-radius:20px;
        background:rgba(255,255,255,.88);
        box-shadow:0 10px 28px rgba(15,23,42,.07);
        overflow:hidden;
    }
    table.mobile-card-table td{
        position:relative;
        min-height:42px;
        padding:12px 13px 12px 118px;
        border-bottom:1px solid rgba(15,23,42,.065);
        font-size:13px;
        line-height:1.4;
        word-break:break-word;
    }
    table.mobile-card-table td:last-child{border-bottom:0}
    table.mobile-card-table td:before{
        content:attr(data-label);
        position:absolute;
        left:13px;
        top:12px;
        width:92px;
        color:#64748b;
        font-size:10px;
        font-weight:950;
        line-height:1.25;
        text-transform:uppercase;
        letter-spacing:.075em;
    }
    table.mobile-card-table td[data-label=""],
    table.mobile-card-table td:not([data-label]){padding-left:13px}
    table.mobile-card-table td[data-label=""]:before,
    table.mobile-card-table td:not([data-label]):before{display:none}
    table.mobile-card-table td:first-child{
        background:linear-gradient(135deg,rgba(22,199,132,.08),rgba(37,99,235,.045));
        font-size:14px;
    }
    table.mobile-card-table .actions{grid-template-columns:1fr 1fr;margin-top:2px}

    .product-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px}
    .product-card{border-radius:19px;padding:12px;min-height:134px}
    .product-card strong{font-size:13px;line-height:1.28;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .product-card .muted{font-size:11px;line-height:1.35}
    .product-img{width:38px;height:38px;border-radius:14px;margin-bottom:9px}
    #searchProduct{position:sticky;top:86px;z-index:15;background:#fff;box-shadow:0 12px 24px rgba(15,23,42,.08)}

    .pos-layout{gap:14px!important}
    #saleForm .pos-layout > .card:last-child{border:1px solid rgba(22,199,132,.15)}
    .cart-item{display:grid;grid-template-columns:1fr;gap:8px;padding:11px 0}
    .qty{justify-content:space-between;width:100%;background:rgba(241,245,249,.75);padding:7px;border-radius:15px}
    .qty button{width:36px;height:36px;border-radius:12px;background:#fff;box-shadow:0 6px 14px rgba(15,23,42,.07)}
    .total-box{border-radius:21px;padding:16px;margin:14px 0}.total-box .amount,.total-box strong{font-size:28px}

    .mobile-sale-bar{
        position:fixed;
        left:10px;
        right:10px;
        bottom:calc(var(--mobile-nav-height) + var(--safe-bottom) + 14px);
        z-index:34;
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:12px;
        padding:11px 12px;
        border-radius:22px;
        color:#fff;
        background:linear-gradient(135deg,#071323,#123a61);
        border:1px solid rgba(255,255,255,.12);
        box-shadow:0 22px 60px rgba(6,18,37,.32);
        transform:translateY(140%);
        opacity:0;
        transition:.24s var(--ease);
    }
    .mobile-sale-bar.show{transform:translateY(0);opacity:1}
    .mobile-sale-bar span{display:block;color:#9fb3cc;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.09em}
    .mobile-sale-bar strong{display:block;font-size:16px;line-height:1.15;letter-spacing:-.025em}
    .mobile-sale-bar button{border:0;border-radius:16px;padding:10px 13px;background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;font-weight:950;white-space:nowrap}

    .login-page{padding:14px;align-items:start;padding-top:8vh}
    .login-wrap{border-radius:28px;box-shadow:0 24px 80px rgba(0,0,0,.32)}
    .login-card{padding:22px;border-radius:28px}.login-brand h1{font-size:25px}.login-store-meta{font-size:12px}
}

@media (max-width:420px){
    .mobile-bottom-nav{left:8px;right:8px;bottom:calc(8px + var(--safe-bottom));padding:7px;min-height:65px;border-radius:23px}
    .mobile-nav-item{border-radius:16px;font-size:9.5px}.mobile-nav-item i{font-size:17px}
    h1,.page-title{font-size:24px}.page-subtitle{font-size:12px}
    .hero-title{font-size:24px}.hero-metric{min-width:86%}
    .product-grid{grid-template-columns:1fr 1fr!important}
    table.mobile-card-table td{padding-left:104px}table.mobile-card-table td:before{width:80px}
}

/* =========================================================
   FINALIZATION PATCH - Database Backup & Restore
   ========================================================= */
.backup-hero h2{max-width:760px;margin:16px 0 10px;font-size:34px;line-height:1.05;letter-spacing:-.055em;color:#fff}
.backup-hero p{max-width:760px;margin:0;color:rgba(238,247,255,.82);font-weight:650;line-height:1.65}
.hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:22px}.hero-actions form{margin:0}.hero-actions .btn{box-shadow:0 14px 32px rgba(0,0,0,.18)}
.section-heading{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}.section-heading h3{margin:3px 0 0}.eyebrow{display:inline-flex;align-items:center;gap:6px;color:var(--emerald);font-size:11px;font-weight:950;letter-spacing:.15em;text-transform:uppercase}.eyebrow.danger{color:#dc2626}.stat-text{font-size:22px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}.backup-summary-grid{margin-bottom:22px}.backup-workspace{align-items:start}.backup-list{display:grid;gap:12px}.backup-item{display:grid;grid-template-columns:52px minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px;border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.78),rgba(248,250,252,.62));border:1px solid rgba(15,23,42,.075);box-shadow:0 14px 30px rgba(15,23,42,.055)}.backup-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(22,199,132,.16),rgba(37,99,235,.09));color:#047857;font-size:24px;border:1px solid rgba(22,199,132,.16)}.backup-info{min-width:0}.backup-info strong{display:block;color:#0f172a;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.backup-info span{display:block;margin-top:5px;color:var(--muted);font-size:12px;font-weight:750}.backup-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.backup-actions form{margin:0}.backup-actions .btn{padding:9px 12px;font-size:12px}.warning-box{padding:15px 16px;margin-bottom:18px;border-radius:20px;background:linear-gradient(135deg,#fff7ed,#fff);border:1px solid rgba(245,158,11,.24);color:#78350f}.warning-box strong{display:block;margin-bottom:5px;color:#92400e}.warning-box p{margin:0;line-height:1.55;font-weight:650}.restore-check{display:flex;align-items:flex-start;gap:10px;margin:14px 0 18px;padding:14px;border-radius:18px;background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.16);font-weight:800;color:#7f1d1d}.restore-check input{margin-top:3px;width:18px;height:18px;accent-color:#dc2626}.empty-state{text-align:center;padding:34px 18px;border-radius:24px;background:rgba(248,250,252,.78);border:1px dashed rgba(15,23,42,.16)}.empty-state i{font-size:42px;color:#64748b}.empty-state strong{display:block;margin-top:10px;color:#0f172a}.empty-state p{margin:8px auto 0;max-width:360px;color:var(--muted);line-height:1.55}.checklist-card{border-color:rgba(22,199,132,.18)}.checklist-grid{gap:14px}.mini-check{display:flex;gap:11px;align-items:flex-start;padding:15px;border-radius:20px;background:rgba(236,253,245,.72);border:1px solid rgba(22,199,132,.16);font-weight:750;color:#164e3b;line-height:1.45}.mini-check i{color:#059669;font-size:19px;flex:0 0 auto}.badge-red{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
@media (max-width:980px){.backup-workspace{grid-template-columns:1fr}.backup-summary-grid,.checklist-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.backup-hero h2{font-size:30px}.backup-item{grid-template-columns:48px minmax(0,1fr);}.backup-actions{grid-column:1/-1;justify-content:flex-start}.backup-actions .btn,.backup-actions form{width:auto!important}}
@media (max-width:560px){.backup-hero h2{font-size:25px}.hero-actions,.hero-actions form,.hero-actions .btn{width:100%}.backup-summary-grid,.checklist-grid{grid-template-columns:1fr}.section-heading{align-items:flex-start;flex-direction:column}.backup-item{grid-template-columns:44px minmax(0,1fr);padding:12px;border-radius:20px}.backup-icon{width:44px;height:44px;border-radius:16px;font-size:21px}.backup-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.backup-actions .btn,.backup-actions form{width:100%!important}.backup-actions form .btn{width:100%!important}.stat-text{font-size:18px!important}.restore-check{font-size:13px}}
