:root{
  --bg:#f4f7fb;--panel:#ffffff;--panel2:#f8fafc;--ink:#0f172a;--muted:#64748b;--line:#e2e8f0;
  --primary:#2563eb;--primary2:#1d4ed8;--success:#16a34a;--warning:#f59e0b;--danger:#dc2626;--dark:#0f172a;
  --radius:20px;--shadow:0 24px 80px rgba(15,23,42,.10)
}
*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
button,input,select,textarea{font:inherit}button{cursor:pointer}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:white;outline:none;color:var(--ink)}textarea{min-height:92px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.12)}label{font-size:13px;font-weight:900;color:#334155}.hidden{display:none!important}.muted{color:var(--muted)}.hint{font-size:13px;color:var(--muted);line-height:1.55}.mobile-only{display:none!important}.text-right{text-align:right}.danger-text{color:var(--danger)}.success-text{color:var(--success)}
.setup-page{min-height:100vh;display:grid;place-items:center;padding:28px;background:linear-gradient(135deg,#06101f,#102e63,#0f6b42)}.setup-card{background:white;border-radius:28px;padding:34px;max-width:620px;box-shadow:var(--shadow)}.setup-card h1{margin:18px 0 8px;font-size:34px;letter-spacing:-1px}.setup-card li{margin:10px 0;color:#334155}
.auth-page{position:relative;min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;padding:42px;overflow:hidden;background:radial-gradient(circle at top left,#164b9e,#081226 50%,#06101f);color:white}.auth-bg-orb{position:absolute;border-radius:999px;filter:blur(6px);opacity:.38}.auth-bg-orb.one{width:340px;height:340px;right:90px;top:-100px;background:#22c55e}.auth-bg-orb.two{width:430px;height:430px;left:-130px;bottom:-120px;background:#2563eb}.auth-hero{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;max-width:780px}.brand-row{display:flex;align-items:center;gap:14px}.brand-row strong{display:block;font-size:20px}.brand-row span{display:block;color:#bfdbfe;font-weight:700;font-size:13px}.logo-badge{width:70px;height:70px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,#22c55e,#2563eb);font-weight:950;letter-spacing:-2px;color:white;box-shadow:0 18px 50px rgba(0,0,0,.22)}.logo-badge.small{width:44px;height:44px;border-radius:15px;font-size:15px;letter-spacing:-1px}.auth-hero h1{font-size:58px;line-height:1.02;margin:28px 0 18px;letter-spacing:-2.4px}.auth-hero p{font-size:20px;line-height:1.65;color:#dbeafe;max-width:680px}.hero-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:26px;max-width:700px}.hero-grid div{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.20);border-radius:20px;padding:18px;backdrop-filter:blur(10px)}.hero-grid b{display:block;font-size:16px;margin-bottom:8px}.hero-grid span{display:block;color:#dbeafe;font-size:13px;line-height:1.55}.auth-panel{position:relative;z-index:1;align-self:center;justify-self:center;width:min(500px,100%);background:rgba(255,255,255,.97);color:var(--ink);padding:28px;border-radius:30px;box-shadow:0 35px 110px rgba(0,0,0,.28)}.auth-title h2{margin:0;font-size:30px;letter-spacing:-1px}.auth-title p{margin:6px 0 18px;color:var(--muted)}.role-switch{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.role-card{border:1px solid var(--line);background:#f8fafc;border-radius:20px;padding:16px;text-align:left;transition:.16s}.role-card span{font-size:28px}.role-card b{display:block;margin:8px 0 3px}.role-card small{color:var(--muted);font-weight:700}.role-card.active{border-color:var(--primary);background:#eff6ff;box-shadow:0 0 0 4px rgba(37,99,235,.10)}.tabs{display:flex;gap:8px;flex-wrap:wrap;background:#f1f5f9;border-radius:16px;padding:6px;margin-bottom:16px}.tab{border:0;border-radius:12px;background:transparent;padding:10px 12px;font-weight:950;color:#475569}.tab.active{background:var(--primary);color:white}.auth-form{display:grid;gap:11px}.link-btn{border:0;background:transparent;color:var(--primary);font-weight:950;padding:6px;text-align:center}
.app-shell{display:flex;min-height:100vh}.sidebar{width:280px;position:fixed;inset:0 auto 0 0;background:#0f172a;color:white;padding:18px;overflow:auto;z-index:60}.sidebar-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.sidebar-brand strong{display:block}.sidebar-brand span{display:block;color:#94a3b8;font-size:12px}.nav-btn{width:100%;display:flex;align-items:center;gap:12px;border:0;background:transparent;color:#cbd5e1;border-radius:15px;padding:12px 13px;margin:4px 0;font-weight:900;text-align:left}.nav-btn:hover,.nav-btn.active{background:#1e293b;color:white}.nav-btn .ico{width:24px;text-align:center;font-size:18px}.sidebar-foot{margin-top:24px;border:1px solid #1e293b;background:#111c2e;border-radius:18px;padding:14px;color:#94a3b8;font-size:12px}.sidebar-foot b{display:block;color:#86efac;margin-top:4px}.main{margin-left:280px;min-height:100vh;flex:1}.topbar{height:86px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 26px;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:25}.topbar h2{margin:0;font-size:25px;letter-spacing:-.6px}.topbar p{margin:4px 0 0}.topbar-actions{display:flex;align-items:center;gap:12px}.user-pill{min-width:150px;border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:9px 12px}.user-pill span{display:block;font-weight:950}.user-pill small{display:block;color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:950}.content{padding:24px;max-width:1500px;margin:0 auto}.grid{display:grid;gap:18px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:white;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card.soft{background:#f8fafc;box-shadow:none}.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.section-head h3{margin:0;font-size:20px;letter-spacing:-.4px}.actions{display:flex;gap:10px;flex-wrap:wrap}.btn{border:0;border-radius:14px;padding:11px 14px;font-weight:950;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.14s}.btn.primary{background:var(--primary);color:white}.btn.primary:hover{background:var(--primary2)}.btn.success{background:var(--success);color:white}.btn.warn{background:var(--warning);color:white}.btn.danger{background:var(--danger);color:white}.btn.ghost{border:1px solid var(--line);background:#f8fafc;color:var(--ink)}.btn.full{width:100%}.btn:disabled{opacity:.55;cursor:not-allowed}.icon-btn{border:0;border-radius:13px;background:#f1f5f9;padding:10px 12px;font-weight:950}.stat-card{position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;right:-34px;top:-44px;width:122px;height:122px;background:rgba(37,99,235,.10);border-radius:999px}.stat-label{font-size:13px;color:var(--muted);font-weight:900}.stat-value{margin-top:8px;font-size:30px;font-weight:950;letter-spacing:-1px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid .full{grid-column:1/-1}.table-wrap{border:1px solid var(--line);border-radius:16px;overflow:auto}table{width:100%;border-collapse:collapse;background:white;min-width:760px}th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{background:#f8fafc;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.05em}td{font-size:14px}tr:hover td{background:#f8fafc}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:950}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.yellow{background:#fef3c7;color:#92400e}.badge.blue{background:#dbeafe;color:#1e40af}.badge.gray{background:#e5e7eb;color:#374151}.empty{border:1px dashed #cbd5e1;background:#f8fafc;border-radius:18px;padding:30px;text-align:center;color:var(--muted);font-weight:800}.search-row{display:grid;grid-template-columns:1.4fr repeat(3,minmax(130px,.6fr));gap:10px;margin-bottom:14px}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;max-height:570px;overflow:auto;padding:2px}.product-card{border:1px solid var(--line);border-radius:18px;padding:14px;background:white;display:grid;gap:8px}.product-card:hover{border-color:var(--primary);box-shadow:0 10px 28px rgba(37,99,235,.10)}.product-card b{line-height:1.3}.cart-list{display:grid;gap:10px;max-height:330px;overflow:auto}.cart-item{display:grid;grid-template-columns:1fr auto;gap:12px;border:1px solid var(--line);border-radius:16px;padding:12px;background:#f8fafc}.qty{display:flex;align-items:center;gap:8px}.qty button{width:32px;height:32px;border:0;border-radius:10px;background:#e2e8f0;font-weight:950}.summary-row{display:flex;align-items:center;justify-content:space-between;margin:9px 0}.summary-row.total{font-size:22px;font-weight:950;border-top:1px solid var(--line);padding-top:12px;margin-top:14px}.chart{display:flex;align-items:end;gap:10px;height:210px;padding:10px;border:1px solid var(--line);border-radius:16px;background:#f8fafc}.bar{flex:1;background:linear-gradient(180deg,#60a5fa,#2563eb);border-radius:12px 12px 5px 5px;min-height:8px;position:relative}.bar span{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);font-size:11px;color:#64748b;font-weight:800}.modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:grid;place-items:center;padding:20px;z-index:200}.modal-card{width:min(780px,100%);max-height:90vh;overflow:auto;background:white;border-radius:24px;box-shadow:0 35px 120px rgba(0,0,0,.35)}.modal-head{position:sticky;top:0;background:white;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 20px;z-index:1}.modal-head h3{margin:0}.modal #modalBody{padding:20px}.toast{position:fixed;right:20px;bottom:20px;z-index:999;background:#0f172a;color:white;border-radius:16px;padding:14px 16px;box-shadow:var(--shadow);transform:translateY(120px);opacity:0;transition:.22s;max-width:460px;font-weight:850}.toast.show{transform:translateY(0);opacity:1}.toast.error{background:#991b1b}.toast.warn{background:#92400e}.toast.success{background:#166534}.camera-box{display:grid;gap:10px}.camera-box video,.camera-box canvas,.selfie-preview{width:100%;max-height:280px;object-fit:cover;border-radius:18px;background:#0f172a}.print-area{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#111827}.hr{height:1px;background:var(--line);margin:16px 0}
@media print{body{background:white}.sidebar,.topbar,.actions,.btn,.modal-head button{display:none!important}.main{margin:0}.content{padding:0}.card{box-shadow:none;border:0}.print-only{display:block!important}}
@media(max-width:1050px){.auth-page{grid-template-columns:1fr}.auth-hero h1{font-size:42px}.auth-panel{justify-self:stretch}.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-2{grid-template-columns:1fr}.sidebar{transform:translateX(-105%);transition:.2s}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.mobile-only{display:inline-flex!important}.topbar{height:auto;padding:14px;flex-wrap:wrap}.topbar-actions{width:100%;justify-content:flex-end}.content{padding:16px}.search-row{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}}
@media(max-width:680px){.auth-page{padding:18px}.auth-hero{display:none}.auth-panel{padding:20px;border-radius:24px}.role-switch{grid-template-columns:1fr}.grid.cols-4,.grid.cols-3{grid-template-columns:1fr}.topbar-actions{align-items:stretch;flex-direction:column}.user-pill{width:100%}.btn{width:100%}.actions .btn{width:auto}.section-head{align-items:flex-start;flex-direction:column}.stat-value{font-size:25px}}

/* Login kuning-putih + preview POS desktop */
.auth-page{grid-template-columns:58% 42%;gap:0;padding:0;background:#fff;color:#171717}.auth-page:before{content:"";position:absolute;inset:0 42% 0 0;background:linear-gradient(145deg,#fbbf24 0%,#f59e0b 58%,#ffd84d 100%);z-index:0}.auth-bg-orb.one{width:380px;height:380px;right:38%;top:-120px;background:rgba(255,255,255,.35);filter:blur(0);opacity:.7}.auth-bg-orb.two{width:520px;height:520px;left:-180px;bottom:-180px;background:rgba(255,255,255,.22);filter:blur(0);opacity:.9}.auth-hero{position:relative;z-index:1;max-width:none;padding:68px 76px 58px;align-items:center;text-align:center;color:white}.auth-page .login-brand{align-self:center;margin-bottom:24px}.auth-page .logo-badge{background:#fff;color:#d97706;box-shadow:0 18px 42px rgba(146,64,14,.18)}.auth-page .brand-row span{color:rgba(255,255,255,.86)}.auth-hero h1{margin:28px 0 8px;font-size:34px;line-height:1.25;letter-spacing:-1px;color:white;text-shadow:0 2px 10px rgba(146,64,14,.12)}.auth-hero p{margin:0 auto;color:rgba(255,255,255,.88);font-size:16px;line-height:1.6;max-width:560px}.desktop-visual{width:min(760px,92%);position:relative;margin-top:14px}.mock-monitor{background:#30323a;border:10px solid #4b4d57;border-radius:18px;box-shadow:0 30px 80px rgba(120,53,15,.30);overflow:hidden;text-align:left}.mock-topbar{height:32px;background:#23252c;display:flex;align-items:center;gap:8px;padding:0 12px;color:#e5e7eb;font-size:11px}.mock-topbar span{width:8px;height:8px;border-radius:99px;background:#fcd34d}.mock-topbar span:nth-child(2){background:#f87171}.mock-topbar span:nth-child(3){background:#34d399}.mock-topbar b{margin-left:auto;font-size:11px}.mock-body{background:#f8fafc;display:grid;grid-template-columns:1.55fr .95fr;gap:12px;padding:14px;min-height:270px}.mock-search{height:24px;border-radius:9px;background:white;border:1px solid #e5e7eb;margin-bottom:9px}.mock-category-row{display:flex;gap:7px;margin-bottom:10px}.mock-category-row i{height:21px;flex:1;border-radius:8px;background:#fff7ed;border:1px solid #fed7aa}.mock-product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.mock-product-grid article{background:white;border:1px solid #e5e7eb;border-radius:13px;padding:8px;display:grid;gap:4px;min-height:82px}.mock-product-grid em{font-style:normal;font-size:22px}.mock-product-grid b{font-size:11px;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mock-product-grid small{font-size:10px;color:#d97706;font-weight:900}.mock-cart{background:white;border:1px solid #e5e7eb;border-radius:16px;padding:13px;box-shadow:0 12px 28px rgba(15,23,42,.08)}.mock-cart h4{margin:0 0 10px;color:#111827}.mock-cart p,.mock-total{display:flex;justify-content:space-between;gap:8px;margin:8px 0;font-size:12px;color:#475569}.mock-total{border-top:1px dashed #e5e7eb;padding-top:12px;margin-top:14px;color:#111827}.mock-total strong{color:#d97706}.mock-cart button{width:100%;border:0;border-radius:11px;background:#f59e0b;color:white;font-weight:950;padding:10px;margin-top:8px}.mock-note{position:absolute;left:-34px;bottom:-28px;width:245px;background:white;color:#111827;border-radius:18px;padding:15px;text-align:left;box-shadow:0 22px 50px rgba(120,53,15,.22);transform:rotate(-6deg)}.mock-note b{display:block;color:#d97706;margin-bottom:6px}.mock-note span{display:block;color:#64748b;font-size:12px;line-height:1.45}.auth-panel{z-index:1;align-self:center;justify-self:center;width:min(420px,calc(100% - 52px));background:#fff;color:#111827;padding:0;box-shadow:none;border-radius:0}.login-title{display:flex;align-items:center;gap:24px;margin-bottom:18px}.mini-app-icon{width:58px;height:58px;border-radius:12px;background:linear-gradient(135deg,#f59e0b,#facc15);color:#fff;display:grid;place-items:center;font-weight:950;box-shadow:0 12px 24px rgba(245,158,11,.25)}.mini-app-icon span{line-height:1}.mini-app-icon small{font-size:10px;letter-spacing:.04em}.auth-title h2{font-size:22px;color:#111827}.auth-title p{font-size:15px;color:#3f3f46;margin-top:10px}.auth-page .role-switch{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:8px 0 16px}.auth-page .role-card{border-color:#e5e7eb;background:#fff;border-radius:14px;padding:10px;text-align:center}.auth-page .role-card span{font-size:20px}.auth-page .role-card b{font-size:12px;margin:4px 0 0}.auth-page .role-card small{display:none}.auth-page .role-card.active{border-color:#f59e0b;background:#fffbeb;box-shadow:0 0 0 4px rgba(245,158,11,.15)}.auth-page input:focus,.auth-page select:focus,.auth-page textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 4px rgba(245,158,11,.12)}.auth-page .btn.primary{background:#f59e0b;color:#fff;box-shadow:0 10px 18px rgba(245,158,11,.25)}.auth-page .btn.primary:hover{background:#d97706}.auth-page .link-btn{color:#d97706;text-align:right;padding:0;margin-top:-4px}.auth-actions{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;flex-wrap:wrap}.auth-actions .tab{background:transparent;color:#52525b;padding:8px 10px}.auth-actions .tab.active{background:#fffbeb;color:#d97706}.auth-page .hint{color:#64748b}.auth-page .btn.ghost{background:#fff7ed;color:#92400e;border-color:#fed7aa}

/* Gambar produk */
.product-line{display:flex;align-items:center;gap:12px}.product-thumb{width:100%;aspect-ratio:1/0.72;border-radius:14px;object-fit:cover;background:#fff7ed;border:1px solid #fed7aa;display:grid;place-items:center;color:#d97706;font-weight:950;overflow:hidden}.product-thumb.card{margin-bottom:4px}.product-thumb.mini{width:56px;height:56px;aspect-ratio:auto;border-radius:14px;flex:0 0 56px}.product-thumb.cart{width:44px;height:44px;aspect-ratio:auto;border-radius:12px;flex:0 0 44px}.product-thumb.placeholder{font-size:18px}.product-card{align-content:start;text-align:left}.product-card strong{color:var(--primary)}.cart-product{display:flex;align-items:center;gap:10px;min-width:0}.image-picker{display:grid;grid-template-columns:140px 1fr;gap:14px;align-items:start;border:1px solid var(--line);border-radius:18px;padding:12px;background:#f8fafc}.image-picker .product-preview{width:140px;height:110px;border-radius:16px;object-fit:cover;background:white;border:1px dashed #cbd5e1}.image-picker .image-placeholder{width:140px;height:110px;border-radius:16px;background:white;border:1px dashed #cbd5e1;display:grid;place-items:center;color:#94a3b8;font-weight:900;text-align:center;padding:12px}.image-picker input[type="file"]{background:white}.image-picker input[type="text"]{margin-top:8px}

@media(max-width:1050px){.auth-page{grid-template-columns:1fr;background:#fff7ed}.auth-page:before{inset:0 0 46% 0}.auth-hero{padding:34px 24px 28px}.auth-panel{width:min(520px,calc(100% - 36px));background:white;border-radius:28px;padding:24px;box-shadow:0 25px 70px rgba(120,53,15,.18);margin:18px auto 34px}.mock-note{display:none}.desktop-visual{width:min(680px,100%)}.auth-hero h1{font-size:28px}.mock-body{min-height:240px}}
@media(max-width:680px){.auth-hero{display:none}.auth-page{display:grid;padding:18px;background:#fff7ed}.auth-page:before,.auth-bg-orb{display:none}.auth-panel{width:100%;margin:0;border-radius:24px;padding:20px}.auth-page .role-switch{grid-template-columns:1fr}.login-title{gap:14px}.image-picker{grid-template-columns:1fr}.image-picker .product-preview,.image-picker .image-placeholder{width:100%;height:180px}.product-line{align-items:flex-start}.product-thumb.mini{width:48px;height:48px;flex-basis:48px}}

/* Penyempurnaan POS profesional + indikator Supabase */
.auth-page .role-switch{grid-template-columns:repeat(2,minmax(0,1fr));}
.login-status-panel{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #fde68a;background:#fffbeb;color:#713f12;border-radius:16px;padding:10px 12px;margin:8px 0 14px;font-size:13px;font-weight:800}.login-status-panel .link-btn{color:#d97706;padding:4px;white-space:nowrap}.status-dot{width:10px;height:10px;border-radius:99px;display:inline-block;background:#ef4444;box-shadow:0 0 0 4px rgba(239,68,68,.12);margin-right:6px}.status-dot.online{background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.14)}.status-dot.offline{background:#ef4444}.connection-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#f8fafc;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:950;color:#64748b}.connection-pill .status-dot{margin:0}.online{color:#15803d!important}.offline{color:#b91c1c!important}.sidebar-foot b.online{color:#86efac!important}.sidebar-foot b.offline{color:#fecaca!important}.connection-card{display:flex;align-items:flex-start;gap:12px;border:1px solid var(--line);border-radius:18px;padding:16px;background:#f8fafc}.connection-card.online{border-color:#bbf7d0;background:#f0fdf4}.connection-card.offline{border-color:#fecaca;background:#fef2f2}.connection-card p{margin:4px 0 0;color:#64748b;font-size:13px;line-height:1.5}.quick-actions{display:grid;gap:10px}.quick-btn{border:1px solid var(--line);background:#fff;border-radius:18px;padding:14px;text-align:left;display:grid;gap:4px;color:var(--ink);box-shadow:0 8px 22px rgba(15,23,42,.05)}.quick-btn.primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-color:#1d4ed8}.quick-btn span{color:#64748b;font-size:12px;font-weight:800}.quick-btn.primary span{color:#dbeafe}.pos-layout{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(420px,.75fr);gap:18px;align-items:start}.cart-panel{position:sticky;top:108px}.pos-toolbar{display:grid;grid-template-columns:1.35fr .65fr .75fr;gap:10px}.product-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.product-meta small{font-size:12px;color:#64748b;font-weight:900}.disabled-product{opacity:.62}.receipt-box{max-width:360px;margin:0 auto;background:white}.receipt-box h2{text-align:center}.receipt-box p{line-height:1.45}.print-area hr{border:0;border-top:1px dashed #94a3b8;margin:10px 0}
@media(max-width:1150px){.pos-layout{grid-template-columns:1fr}.cart-panel{position:static}.pos-toolbar{grid-template-columns:1fr}}
@media(max-width:680px){.connection-pill{width:100%;justify-content:center}.login-status-panel{align-items:flex-start;flex-direction:column}.auth-page .role-switch{grid-template-columns:1fr}.pos-toolbar{grid-template-columns:1fr}}

/* Update v9: login image baru, POS order button, mode hapus Owner, export Excel */
.login-image-stage{width:min(780px,94%);position:relative;margin:10px auto 8px;animation:floatLogin 5.5s ease-in-out infinite}.login-image-stage img{width:100%;display:block;border-radius:34px;box-shadow:0 34px 95px rgba(146,64,14,.26);border:8px solid rgba(255,255,255,.55);background:#fff7ed}.login-image-badge{position:absolute;right:-22px;bottom:28px;width:240px;background:#fff;color:#111827;border-radius:22px;padding:16px;text-align:left;box-shadow:0 22px 60px rgba(120,53,15,.25);border:1px solid #fde68a}.login-image-badge b{display:block;color:#d97706;font-size:16px;margin-bottom:6px}.login-image-badge span{display:block;color:#64748b;font-size:12px;line-height:1.45}.desktop-visual{display:none}@keyframes floatLogin{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.error-page{background:linear-gradient(135deg,#fff7ed,#f59e0b)}.error-card{border:1px solid #fed7aa}.error-actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.error-inline{border-color:#fecaca;background:#fff7f7}.owner-delete-banner{border:1px solid #e5e7eb;background:#f8fafc;border-radius:16px;padding:11px 13px;margin:-4px 0 14px;color:#64748b;font-size:13px;font-weight:800}.owner-delete-banner.active{border-color:#fecaca;background:#fef2f2;color:#991b1b}.hard-delete{box-shadow:0 0 0 3px rgba(220,38,38,.10)}
.pro-pos-layout{grid-template-columns:minmax(0,1.15fr) minmax(260px,.55fr) minmax(390px,.75fr)}.selected-product-panel{position:sticky;top:108px}.order-product-card{position:relative;cursor:pointer;transition:.16s;border-width:1px}.order-product-card.selected{border-color:#f59e0b;box-shadow:0 0 0 4px rgba(245,158,11,.13),0 16px 34px rgba(146,64,14,.12)}.product-order-btn{margin-top:8px;background:#f59e0b!important;color:#fff!important}.product-order-btn:hover{background:#d97706!important}.product-order-btn.big{font-size:16px;padding:14px 16px;margin-top:16px}.selected-product-detail{text-align:center;display:grid;gap:8px}.product-thumb.selected{width:100%;height:160px;aspect-ratio:auto;border-radius:22px;object-fit:cover}.selected-product-detail h3{margin:8px 0 0;font-size:22px}.selected-price{font-size:28px;font-weight:950;color:#d97706}.selected-stock{border:1px solid #fde68a;background:#fffbeb;border-radius:14px;padding:10px;color:#713f12}.order-save-btn{font-size:16px;padding:15px 16px}.report-export-card{background:linear-gradient(135deg,#fff,#fffbeb)}
@media(max-width:1350px){.pro-pos-layout{grid-template-columns:minmax(0,1fr) minmax(370px,.65fr)}.selected-product-panel{position:static;grid-column:1/-1;order:2}.cart-panel{order:3}.selected-product-detail{grid-template-columns:180px 1fr;align-items:center;text-align:left}.product-thumb.selected{height:140px}.selected-product-detail .product-order-btn{grid-column:1/-1}}
@media(max-width:1050px){.login-image-stage{width:min(700px,100%)}.login-image-badge{display:none}.auth-hero{padding-top:28px}}
@media(max-width:680px){.login-image-stage{display:none}.pro-pos-layout{grid-template-columns:1fr}.selected-product-detail{display:grid;text-align:center}.product-thumb.selected{height:190px}.selected-product-detail .product-order-btn{grid-column:auto}}
