:root{--dark:#15100c;--gold:#d9a441;--gold2:#fff1c1;--bg:#f7f3ea;--card:#fff;--text:#201b16;--muted:#786d61;--danger:#b42318;--ok:#067647;--pink:#b93475}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}label{display:block;margin:10px 0 6px;font-weight:800}input,select,textarea{width:100%;border:1px solid #ddd2bf;border-radius:12px;padding:11px;background:#fff;font:inherit}textarea{min-height:78px}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top,#51223b,#15100c 62%)}.login-card{width:min(430px,92vw);background:#fff;border-radius:26px;padding:34px;box-shadow:0 28px 90px #0008}.brand-badge{display:inline-block;background:linear-gradient(135deg,var(--pink),var(--gold));color:#fff;padding:10px 18px;border-radius:999px;font-weight:900}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:12px;padding:10px 14px;background:#ede3d1;color:#2a2118;font-weight:900;cursor:pointer}.btn.primary{background:linear-gradient(135deg,var(--pink),#7b1746);color:#fff}.btn.danger,.alert.danger{background:#fee4e2;color:var(--danger)}.btn.small{padding:7px 10px;font-size:12px}.btn.full{width:100%;margin-top:15px}.alert{padding:12px 14px;border-radius:14px;margin-bottom:15px}.alert.ok{background:#dcfae6;color:var(--ok)}.app{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--dark);color:#fff;padding:22px;position:fixed;inset:0 auto 0 0;overflow:auto}.logo{display:flex;gap:12px;align-items:center;margin-bottom:24px}.logo span{width:48px;height:48px;border-radius:16px;background:var(--gold);display:grid;place-items:center;font-weight:900;color:#17130f}.logo small{display:block;color:var(--gold2)}.sidebar nav{display:grid;gap:6px}.sidebar a{padding:11px 13px;border-radius:14px;color:#fff9}.sidebar a.active,.sidebar a:hover{background:#ffffff16;color:#fff}.sidebar .logout{color:#ffd0ca}.main{margin-left:280px;width:calc(100% - 280px);padding:24px}.topbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:22px}.topbar h2{margin:0}.topbar p{margin:3px 0;color:var(--muted)}.admin-pill{background:#fff;border-radius:999px;padding:10px 16px;box-shadow:0 8px 30px #39230a14}.grid{display:grid;gap:18px}.grid.cards{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.two{grid-template-columns:1fr 1fr}.card{background:var(--card);border-radius:22px;padding:20px;box-shadow:0 10px 40px #39230a12;margin-bottom:18px}.stat small{color:var(--muted);display:block}.stat strong{font-size:26px;margin-top:8px;display:block}.section-head{display:flex;justify-content:space-between;gap:14px;align-items:center}table{width:100%;border-collapse:collapse}th,td{padding:11px;border-bottom:1px solid #eee3d4;text-align:left;vertical-align:top}th{font-size:12px;color:var(--muted);text-transform:uppercase}.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;align-items:end}.form-grid .wide{grid-column:span 2}.two-col{grid-template-columns:1fr 1fr}.check{display:flex;gap:8px;align-items:center}.check input{width:auto}.badge{border-radius:99px;padding:5px 9px;font-size:12px;font-weight:900}.badge.ok{background:#dcfae6;color:var(--ok)}.badge.danger{background:#fee4e2;color:var(--danger)}.inline-form{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.inline-form input,.inline-form select{width:auto}.table-wrap{overflow:auto}.checkout-box{margin-top:18px;background:#fbf7ef;border-radius:18px;padding:16px}.totals{max-width:360px;margin-left:auto}.totals p{display:flex;justify-content:space-between;border-bottom:1px solid #eee;padding:8px 0}.kasir-shell{min-height:100vh}.kasir-top{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;background:#15100c;color:#fff;padding:14px 22px;box-shadow:0 10px 35px #0003}.kasir-top small{display:block;color:#fff1c1}.kasir-top nav{display:flex;gap:8px;flex-wrap:wrap}.kasir-top a{padding:9px 12px;border-radius:999px;color:#fff9}.kasir-top a.active,.kasir-top a:hover{background:#ffffff18;color:#fff}.kasir-main{padding:20px}.pos-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.product-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:15px}.product-card{border:1px solid #eadfce;background:#fff;border-radius:18px;padding:14px;display:grid;gap:7px;text-align:left;cursor:pointer}.product-card:hover{border-color:var(--pink);box-shadow:0 12px 30px #b9347520}.product-card b{font-size:15px}.product-card small{color:var(--muted)}.product-card strong{font-size:18px;color:var(--pink)}.product-card em{font-style:normal;font-size:12px;color:var(--muted)}.category-tabs{display:flex;gap:8px;flex-wrap:wrap}.qty-input{max-width:80px}.receipt-page{background:#eee;padding:20px}.receipt{width:320px;margin:0 auto;background:#fff;padding:16px;font-family:'Courier New',monospace;color:#000}.receipt h2{font-size:17px;margin:0}.receipt p{font-size:12px}.receipt table{font-size:12px}.receipt td{border:0;padding:4px 0}.center{text-align:center}.right{text-align:right}.receipt-actions{text-align:center;margin-top:18px}.receipt-like{max-width:850px}@media(max-width:1100px){.grid.cards,.grid.two,.form-grid,.pos-layout{grid-template-columns:1fr}.product-grid{grid-template-columns:repeat(2,1fr)}.sidebar{position:static;width:100%}.app{display:block}.main{margin-left:0;width:100%}.form-grid .wide{grid-column:auto}.topbar,.section-head{display:block}.inline-form input,.inline-form select{width:100%}}@media(max-width:640px){.product-grid{grid-template-columns:1fr}.kasir-top{display:block}.kasir-top nav{margin-top:10px}.receipt{width:100%}}@media print{.sidebar,.topbar,.no-print,.kasir-top,.receipt-actions{display:none!important}.main,.kasir-main{margin:0;width:100%;padding:0}.card{box-shadow:none;border:1px solid #ddd}.receipt-page{background:#fff;padding:0}.receipt{margin:0;width:80mm}.app{display:block}}

/* =========================
   D'Celup POS V3 - Kasir UI
   ========================= */
.kasir-body{background:linear-gradient(180deg,#fdf7ee 0%,#f5ecdd 100%);}
.kasir-shell{min-height:100vh;}
.kasir-top{
  position:sticky;top:0;z-index:50;
  display:flex!important;align-items:center;justify-content:space-between;gap:14px;
  min-height:64px;padding:10px 18px!important;
  background:rgba(21,16,12,.96)!important;color:#fff!important;
  backdrop-filter:blur(12px);box-shadow:0 10px 28px rgba(0,0,0,.16);
}
.kasir-brand{display:flex;align-items:center;gap:10px;color:#fff!important;font-weight:950;letter-spacing:.2px;white-space:nowrap;}
.brand-mark{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,var(--pink),var(--gold));display:grid;place-items:center;color:#fff;font-weight:950;box-shadow:0 10px 24px rgba(185,52,117,.3)}
.brand-text{font-size:18px;line-height:1;}
.kasir-nav{display:flex!important;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;}
.kasir-nav a{display:inline-flex!important;align-items:center;justify-content:center;min-height:38px;padding:8px 13px!important;border-radius:999px;color:rgba(255,255,255,.82)!important;font-weight:800;font-size:14px;line-height:1;background:transparent;}
.kasir-nav a.active,.kasir-nav a:hover{background:rgba(255,255,255,.14)!important;color:#fff!important;}
.kasir-nav a.logout{background:rgba(185,52,117,.18)!important;color:#ffe7f3!important;}
.kasir-main{padding:18px!important;max-width:1680px;margin:0 auto;}
.pos-layout{display:grid!important;grid-template-columns:minmax(0,1.35fr) minmax(420px,.65fr)!important;gap:18px!important;align-items:start;}
.card.pos-products,.card.pos-cart{border:1px solid rgba(80,48,13,.08);box-shadow:0 18px 55px rgba(57,35,10,.1);border-radius:26px!important;padding:18px!important;margin-bottom:0!important;}
.pos-title-row,.cart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;}
.pos-title-row h2,.cart-head h2{margin:0;font-size:22px;line-height:1.15;}
.pos-title-row p,.cart-head p{margin:4px 0 0;color:var(--muted);font-size:13px;}
.product-counter{background:#fbf3e6;border:1px solid #eadfce;border-radius:999px;padding:8px 12px;font-weight:900;color:#7b1746;white-space:nowrap;}
.search-row{margin-bottom:12px;}
.search-input{height:50px;border-radius:18px!important;border:1px solid #e3d4bf!important;padding:0 16px!important;font-size:16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.8);}
.search-input:focus,input:focus,select:focus,textarea:focus{outline:3px solid rgba(185,52,117,.12);border-color:rgba(185,52,117,.55)!important;}
.category-tabs{display:flex!important;gap:8px!important;flex-wrap:wrap;margin:8px 0 14px;}
.cat-btn{border-radius:999px!important;padding:9px 13px!important;font-size:13px!important;background:#efe3d0!important;color:#3a2b1e!important;border:1px solid transparent!important;box-shadow:none!important;}
.cat-btn.active{background:linear-gradient(135deg,var(--pink),#87194d)!important;color:#fff!important;border-color:transparent!important;}
.product-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(190px,1fr))!important;gap:12px!important;margin-top:0!important;}
.product-card{appearance:none;-webkit-appearance:none;border:1px solid #eadfce!important;background:#fff!important;border-radius:20px!important;height:240px;padding:0!important;text-align:left!important;cursor:pointer!important;display:flex!important;flex-direction:column!important;gap:0!important;box-shadow:0 8px 24px rgba(57,35,10,.06);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;overflow:hidden;}
.product-card.is-hidden{display:none!important}
.product-card:hover{transform:translateY(-2px);border-color:rgba(185,52,117,.65)!important;box-shadow:0 16px 34px rgba(185,52,117,.15)!important;}
.product-card:active{transform:scale(.985);}
.product-card:disabled{cursor:not-allowed!important;opacity:1}
.pc-media{position:relative;width:100%;height:100%;background:linear-gradient(180deg,#f7efe1,#efe3d0);display:flex;align-items:center;justify-content:center;overflow:hidden}
.pc-media.full{height:100%}
.pc-media img{width:100%;height:100%;object-fit:cover;display:block}
.pc-media-fallback{font-size:12px;font-weight:800;color:#7a6a59;letter-spacing:.02em}
.pc-media:not(.no-image) .pc-media-fallback{display:none}
.pc-overlay{position:absolute;inset:0;padding:10px;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto 1fr auto auto;background:linear-gradient(180deg,rgba(0,0,0,.10) 0%,rgba(0,0,0,.12) 40%,rgba(0,0,0,.42) 68%,rgba(0,0,0,.78) 100%);}
.pc-overlay::after{content:'';position:absolute;left:0;right:0;bottom:0;height:46%;background:linear-gradient(180deg,rgba(0,0,0,0) 0%,rgba(0,0,0,.78) 100%);pointer-events:none;z-index:0}
.pc-stock{grid-column:2;grid-row:1;justify-self:end;align-self:start;font-style:normal;font-size:12px;font-weight:900;color:#5f5145;background:#f7efe4;border-radius:999px;padding:5px 8px;white-space:nowrap;position:relative;z-index:1}
.pc-stock.empty{background:#fee4e2;color:#b42318}
.pc-name{grid-column:1 / -1;grid-row:3;align-self:end;display:block;font-size:15px;font-weight:950;line-height:1.2;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.45);padding-right:2px;position:relative;z-index:1}
.pc-cat{grid-column:1;grid-row:4;align-self:end;display:block;font-size:12px;color:#f4e6d0;line-height:1.2;text-shadow:0 1px 4px rgba(0,0,0,.4);padding-right:8px;position:relative;z-index:1}
.pc-price{grid-column:2;grid-row:4;align-self:end;justify-self:end;font-size:15px;font-weight:900;color:#fff;white-space:nowrap;text-shadow:0 2px 8px rgba(0,0,0,.5);position:relative;z-index:1}
.product-card.is-empty .pc-overlay{background:linear-gradient(180deg,rgba(0,0,0,.52) 0%,rgba(0,0,0,.62) 45%,rgba(0,0,0,.78) 100%)}
.product-card.is-empty .pc-overlay::after{display:none}
.pc-empty-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;background:#b42318;color:#fff;border:1px solid #f9b5b0;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:900;letter-spacing:.04em;box-shadow:0 8px 18px rgba(0,0,0,.32)}
.compact-form{gap:10px!important;}
.compact-form label{font-size:13px;margin:6px 0 5px;}
.wide-form{grid-column:span 2;}
.cart-table-wrap{margin-top:14px;border:1px solid #eee3d4;border-radius:18px;overflow:auto;background:#fff;}
.cart-table th,.cart-table td{padding:10px;border-bottom:1px solid #f0e5d7;vertical-align:middle;}
.cart-table th{font-size:11px;letter-spacing:.04em;background:#fbf7ef;position:sticky;top:0;z-index:1;}
.cart-table tbody:empty{display:none;}
.empty-cart{padding:22px;text-align:center;color:var(--muted);font-weight:800;}
.cart-table:has(tbody tr) + .empty-cart{display:none;}
.qty-input{max-width:74px!important;text-align:center;padding:8px!important;border-radius:10px!important;}
.checkout-box{margin-top:14px!important;background:#fbf7ef!important;border:1px solid #eee3d4;border-radius:20px!important;padding:14px!important;}
.total-line{display:grid;grid-template-columns:1fr 192px;gap:12px;align-items:center;margin-bottom:10px;}
.total-line span{font-weight:900;color:#3a2b1e;}
.money-input{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;background:#fff;border:1px solid #d9ccb6;border-radius:14px;padding:8px 10px;min-height:46px;}
.money-input b{font-size:12px;color:#6b5949;font-weight:900;}
.money-input input{border:0!important;outline:0!important;box-shadow:none!important;background:transparent!important;padding:0!important;margin:0!important;text-align:right;font-weight:900;font-size:17px;color:#1f1711;width:100%;}
.money-input.readonly{background:#f8f3ea;}
.total-line.grand{border-top:1px dashed #d8c7b2;border-bottom:1px dashed #d8c7b2;padding:10px 0;margin:10px 0;}
.total-line.grand span{font-size:18px;color:#7b1746;}
.total-line.grand .money-input input{font-size:19px;color:#7b1746;}
.pos-cart{position:sticky;top:82px;}
#saveSaleBtn{height:48px;border-radius:16px!important;font-size:15px;}
@media(max-width:1200px){
  .kasir-main{padding:14px!important}
  .pos-layout{grid-template-columns:minmax(0,1fr) minmax(350px,.72fr)!important;gap:14px!important}
  .card.pos-products,.card.pos-cart{padding:14px!important;border-radius:20px!important}
  .pos-title-row h2,.cart-head h2{font-size:19px}
  .search-input{height:44px;font-size:14px}
  .product-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))!important;gap:10px!important}
  .product-card{height:218px}
  .pc-overlay{padding:9px}
  .pc-name{font-size:14px}
  .pc-cat,.pc-stock{font-size:11px}
  .pc-price{font-size:14px}
  .compact-form{gap:8px!important}
  .compact-form label{font-size:12px}
  .cart-table th,.cart-table td{padding:8px}
  .total-line{grid-template-columns:1fr 170px}
}
@media(max-width:1024px){
  .pos-layout{grid-template-columns:minmax(0,1fr) minmax(330px,.74fr)!important}
}
@media(max-width:980px){.pos-layout{grid-template-columns:1fr!important}.pos-cart{position:static}.product-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))!important}}
@media(max-width:760px){.kasir-top{align-items:flex-start;flex-direction:column;padding:12px!important}.kasir-nav{width:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.kasir-nav a{white-space:nowrap}.kasir-main{padding:12px!important}.card.pos-products,.card.pos-cart{border-radius:20px!important;padding:14px!important}.pos-title-row,.cart-head{align-items:flex-start;flex-direction:column}.product-counter{display:none}.product-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}.product-card{height:214px}.pc-name{font-size:14px}.pc-cat,.pc-stock{font-size:11px}.pc-price{font-size:14px}.two-col,.compact-form{grid-template-columns:1fr!important}.wide-form{grid-column:auto}.total-line{grid-template-columns:1fr 160px}.money-input{min-height:44px;padding:7px 9px}.money-input input{font-size:15px}.table-wrap table{min-width:560px}}
@media(max-width:420px){.product-grid{grid-template-columns:1fr!important}.brand-text{font-size:16px}.total-line{grid-template-columns:1fr}.total-line input{text-align:left}}

.install-btn{margin-top:8px;background:linear-gradient(135deg,#f6c04b,#d9a441)!important;color:#1b140f!important;font-weight:900;border:1px solid #f4d089}
.kasir-install-btn{margin-top:0!important;min-height:36px;white-space:nowrap}

