:root{--navy:#262b72;--navy2:#14194d;--blue:#0b69d1;--side:#0b3c72;--turq:#22b8b8;--yellow:#ffd23f;--green:#17a84e;--red:#ef4145;--soft:#edf5ff;--line:#d4e4f6;--ink:#062855;--muted:#65718b;--shadow:0 18px 45px rgba(9,44,84,.12)}
*{box-sizing:border-box}body{margin:0;background:#eaf2fb;color:var(--ink);font-family:Calibri,Arial,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.btn{border:0;border-radius:14px;font-weight:900;padding:14px 22px}.btn.blue{background:var(--blue);color:#fff}.btn.yellow{background:var(--yellow);color:#063667}.btn.green{background:var(--green);color:#fff}.btn.red{background:var(--red);color:#fff}.btn.teal{background:var(--turq);color:#fff}.btn.soft{background:#eef4fb;color:#17375e}.btn.outline{background:#fff;color:#009293;border:1.5px solid var(--turq)}.btn.full{width:100%}.btn.big{font-size:20px;padding:18px 38px}.hint{color:var(--muted);font-size:14px;line-height:1.5}.admin-font{font-family:Calibri,Arial,sans-serif!important}.toast{position:fixed;right:25px;bottom:25px;z-index:999;background:#07396e;color:#fff;padding:16px 20px;border-radius:14px;box-shadow:var(--shadow)}
/* customer */
.customer-page{background:#fff;min-height:100vh}.main-header{height:98px;display:grid;grid-template-columns:150px 150px 1fr auto auto auto;gap:18px;align-items:center;padding:14px 24px;background:#fff;border-bottom:1px solid #edf2f8;position:sticky;top:0;z-index:10}.main-logo{width:82px;height:82px;object-fit:contain}.cat-btn,.pill-btn{background:#fff;border:1px solid var(--line);border-radius:999px;padding:14px 20px;color:var(--navy2);font-weight:900;box-shadow:0 10px 24px rgba(18,25,80,.05)}.pill-btn.primary{background:var(--blue);color:#fff}.cart-toggle{position:relative}.cart-toggle b{position:absolute;right:-5px;top:-8px;background:var(--turq);color:#fff;min-width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:12px}.search-box{height:56px;border:1px solid var(--line);border-radius:999px;display:flex;align-items:center;gap:12px;padding:0 18px;background:#fff}.search-box span{font-size:25px}.search-box input{border:0;outline:0;width:100%;font-size:18px}.agent-status{max-width:1500px;margin:12px auto -8px;padding:10px 16px;border-radius:14px;background:#effffa;color:#087b7b;font-weight:900}.hero{max-width:1540px;margin:30px auto;border-radius:26px;background:linear-gradient(130deg,#1d2264,#30377f);overflow:hidden}.hero-auto{display:grid;grid-template-columns:1.15fr .85fr;align-items:center;gap:30px;color:#fff;padding:80px 90px}.eyebrow{letter-spacing:.25em;font-weight:1000;font-size:15px}.hero h1{font-size:88px;letter-spacing:.1em;margin:16px 0 8px;line-height:.9}.hero h2{font-size:40px;letter-spacing:.08em;margin:0 0 24px}.hero-copy p:not(.eyebrow){font-size:23px;line-height:1.45;max-width:760px}.wa-big{display:inline-flex;align-items:center;gap:18px;background:#fff;color:var(--turq);border-radius:16px;padding:18px 28px;font-weight:1000;font-size:34px;text-decoration:none}.hero-benefits{display:flex;gap:25px;flex-wrap:wrap;margin-top:30px;font-weight:900}.hero-img-wrap{display:grid;place-items:center}.hero-img-wrap img{max-width:430px;width:90%;max-height:560px;object-fit:contain;background:#fff}.hero-banner{width:100%;display:block}.shop-filters{max-width:1540px;margin:0 auto 18px;display:flex;gap:12px;flex-wrap:wrap}.shop-filters button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:12px 22px;font-weight:900;color:var(--ink)}.shop-filters button.active{background:var(--navy);color:#fff}.shop-layout{max-width:1540px;margin:0 auto;display:grid;grid-template-columns:1fr 470px;gap:28px;padding-bottom:35px}.section-head{display:flex;justify-content:space-between;align-items:end}.section-head h3{font-size:28px;margin:5px 0}.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.product-card{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}.product-card .media{height:280px;background:#f6f8fb;display:grid;place-items:center;position:relative;overflow:hidden}.product-card img{width:100%;height:100%;object-fit:cover}.placeholder{width:78%;height:78%;border-radius:24px;background:linear-gradient(135deg,#30377e,#23b8ba);display:grid;place-items:center;text-align:center;color:#fff;font-size:26px;font-weight:1000;padding:20px}.stock-pill{position:absolute;right:14px;bottom:14px;background:#d7fffb;color:#078b8d;border-radius:999px;padding:7px 11px;font-weight:900}.product-card .body{padding:18px}.product-card h4{font-size:22px;margin:0 0 10px;text-transform:uppercase}.price-main{font-size:26px;font-weight:1000;color:#12184f}.agent-note{font-size:13px;color:var(--muted);margin:5px 0 14px}.cart-panel{position:sticky;top:120px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}.cart-head{background:var(--navy);color:#fff;padding:26px;font-weight:1000;font-size:25px}.cart-head span{display:inline-grid;place-items:center;background:#fff;color:var(--navy);border-radius:50%;width:34px;height:34px;margin-left:10px}.cart-items{padding:18px 24px}.cart-item{display:grid;grid-template-columns:60px 1fr auto;gap:12px;align-items:center;border-bottom:1px solid #edf0f8;padding:12px 0}.cart-item img,.mini-img{width:60px;height:60px;border-radius:12px;object-fit:cover;background:#edf2f8}.cart-item b{display:block}.cart-item small{color:var(--muted)}.cart-item button{border:0;background:transparent;color:#9aa3b9;font-size:24px}.cart-total{border-top:1px solid #edf0f8;padding:22px 24px;display:flex;align-items:center;justify-content:space-between}.cart-total strong{font-size:31px;color:#151a56}.cart-panel .btn{margin:0 24px 14px;width:calc(100% - 48px)}.cart-trust{border-top:1px solid #edf0f8;color:var(--navy);font-weight:900;font-size:12px;display:flex;justify-content:space-around;padding:17px 10px}.main-footer{background:var(--navy);color:#fff;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:32px 90px}.main-footer div{display:grid;gap:5px}.main-footer b{font-size:18px}.main-footer span{color:#e2e6ff}
/* admin */
.admin-app{display:grid;grid-template-columns:300px 1fr;min-height:100vh}.sidebar{height:100vh;position:sticky;top:0;overflow:auto;background:linear-gradient(180deg,#225f8c,#07356e);color:#fff;padding:18px 12px}.brand-block{text-align:center;margin-bottom:12px}.brand-block b{display:block;font-size:42px;letter-spacing:.16em}.brand-block span{font-size:15px;opacity:.9}.sync{border:0;border-radius:999px;color:#fff;padding:12px 22px;font-weight:900;display:block;margin:0 auto 20px}.sync.good{background:#13bb58}.sync.wait{background:#f3b42b}.admin-card{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);border-radius:18px;padding:16px;margin-bottom:14px}.admin-card small{display:block;color:#a9c8e9;font-weight:1000;letter-spacing:.08em}.admin-card b{font-size:24px;display:block;margin:8px 0}.admin-actions-mini{display:grid;grid-template-columns:1fr 1fr;gap:8px}.admin-actions-mini button{border:0;border-radius:999px;background:var(--yellow);color:#063667;font-weight:900;padding:11px 9px}.bonus-card{border:0;text-align:left;width:100%;background:linear-gradient(135deg,#fff0ad,#fff7cc);color:#07356e;border-radius:18px;padding:18px;margin-bottom:18px}.bonus-card small{display:block}.bonus-card b{display:block;font-size:25px;margin:10px 0}.bonus-card span{background:rgba(141,106,0,.12);padding:7px 12px;border-radius:999px}.bonus-card em{display:block;margin-top:10px;color:#755600}.side-nav{display:grid;gap:10px}.side-nav button{border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.1);color:#fff;text-align:left;border-radius:16px;padding:15px 18px;font-weight:900}.side-nav button.active{background:var(--yellow);color:#07356e}.admin-main{padding:24px;overflow:auto}.admin-page{display:none}.admin-page.active{display:block}.panel{background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;margin-bottom:20px;box-shadow:var(--shadow)}.bar-title{margin:0 0 22px;color:#004386;font-size:30px}.bar-title:before{content:"";display:inline-block;width:10px;height:32px;border-radius:99px;background:var(--blue);margin-right:12px;vertical-align:middle}.bar-title.yellow:before{background:var(--yellow)}.form-grid{display:grid;gap:16px}.form-grid.two{grid-template-columns:1fr 1fr}.form-grid.three{grid-template-columns:1fr 1fr 1fr}.form-grid.four{grid-template-columns:220px 1fr 1fr 260px}label{font-weight:900;color:#30455f;text-transform:uppercase;letter-spacing:.05em}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:16px;padding:16px 20px;outline:0;background:#f9fbfe;color:#001d3d;margin-top:7px}textarea{min-height:95px;resize:vertical}.check{display:flex!important;gap:9px;align-items:center;text-transform:none}.check input{width:auto;margin:0}.in-form{align-self:end;padding:12px 0}.info-box{border:1px dashed #cfe0f4;background:#fbfdff;border-radius:18px;padding:18px;color:#5d6c83}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:20px}table{width:100%;border-collapse:collapse;background:#fff}th{background:#e9f3ff;color:#003c80;text-align:left;padding:15px}td{border-top:1px solid #e7eef8;padding:13px}.row-actions{display:flex;gap:14px;flex-wrap:wrap;margin:20px 0}.right-total{display:flex;justify-content:flex-end;gap:24px;align-items:center;border-top:1px solid var(--line);padding-top:18px;font-size:25px}.right-total b{color:#003c80}.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}.mini-stats div,.report-card{border:1px solid var(--line);border-radius:18px;background:#fbfdff;padding:18px}.mini-stats small,.report-card small{display:block;color:#5d6c83;font-weight:900;text-transform:uppercase}.mini-stats b,.report-card b{font-size:28px;color:#003c80}.answer-box{min-height:140px;font-family:Consolas,monospace;font-size:16px;border-color:#6db3ff}.bulk-grid,.bulk-groups{display:grid;gap:16px;margin:20px 0}.group-box{border:1px solid var(--line);border-radius:18px;padding:16px}.group-box h3{margin:0 0 12px}.group-box.dewasa-pendek h3{color:#075fd3}.group-box.dewasa-panjang h3{color:#e41120}.group-box.anak-pendek h3{color:#0b9a47}.group-box.anak-panjang h3{color:#c07100}.size-row{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.size-cell{border:1px solid var(--line);border-radius:16px;padding:10px;background:#f9fbfe;text-align:center}.size-cell b{font-size:14px}.size-cell input{padding:11px;text-align:center;background:#fff}.size-cell small{display:block;margin-top:6px;color:var(--muted)}.size-cell.empty input{border-color:#ff9f9f;background:#fff5f5}.size-cell.empty small{color:#e33434}.modal{position:fixed;inset:0;background:rgba(3,18,42,.55);z-index:100;display:grid;place-items:center;backdrop-filter:blur(4px)}.modal-box{background:#fff;border-radius:24px;padding:26px;box-shadow:0 30px 80px rgba(0,0,0,.28);position:relative;width:min(760px,94vw);max-height:92vh;overflow:auto}.modal-box.small{width:min(440px,94vw)}.modal-box.large{width:min(980px,96vw)}.modal-box.payment{width:min(440px,94vw);margin-left:auto;margin-right:24px}.close{position:absolute;right:16px;top:14px;border:0;background:#eef4fb;border-radius:50%;width:42px;height:42px;font-size:25px}.pay-line{display:flex;justify-content:space-between;border:1px solid var(--line);border-radius:13px;padding:14px 16px;margin:9px 0;font-weight:900}.pay-line.grand{background:#004386;color:#fff}.pay-line.grand b{color:#ffd13f}.pay-line.danger{background:#fff3f3;color:#d12b2b}.pay-line.lunas{background:#eefff4;color:#05a047}.preview-area{text-align:center}.invoice-box{width:108mm;min-height:185mm;background:#fff;margin:18px auto;padding:7mm 8mm;text-align:left;color:#001d3d;border-radius:12px;box-shadow:var(--shadow)}.inv-top{display:grid;grid-template-columns:1fr auto}.inv-top h1{margin:0;font-size:22px}.inv-mode{text-align:right;font-weight:900}.invoice-box h2{text-align:center;letter-spacing:.25em;font-size:13px;margin:10px 0}.meta-compact{font-size:9.6px;display:grid;grid-template-columns:1fr 1fr;gap:3px 12px;margin-bottom:8px}.meta-compact b{font-size:10.5px}.invoice-box h3{font-size:13px;margin:10px 0 6px;color:#004386}.invoice-box table{font-size:8px}.invoice-box th,.invoice-box td{padding:4px;border-top:1px solid #dce6f2}.inv-total{margin-left:auto;width:58%;display:grid;gap:4px;margin-top:8px}.inv-total div{display:flex;justify-content:space-between;font-size:9.5px;border:1px solid #dce6f2;border-radius:7px;padding:6px}.inv-total .grand{background:#004386;color:#fff;font-weight:900}.inv-total .grand b{color:#ffd13f}.inv-total .lunas{background:#eafff0;color:#079f40}.bank-line{font-size:8px;line-height:1.35}.invoice-note{font-size:7.5px;color:#555}.report-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}.setting-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}.setting-tabs button{border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px 15px;font-weight:900}.setting-tabs button.active{background:var(--blue);color:#fff}.tab{display:none}.tab.active{display:block}.preview-img{height:230px;border:1px dashed var(--line);border-radius:18px;background:#f7fbff;display:grid;place-items:center;margin:12px 0;overflow:hidden}.preview-img img{max-width:100%;max-height:100%;object-fit:contain}.footer-editors{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.footer-edit{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fbfdff}
@media(max-width:1100px){.main-header{grid-template-columns:90px 1fr auto}.cat-btn{display:none}.search-box{grid-column:2/3}.hero-auto{grid-template-columns:1fr;padding:40px}.shop-layout{grid-template-columns:1fr}.cart-panel{position:relative;top:auto}.product-grid{grid-template-columns:repeat(2,1fr)}.admin-app{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.form-grid.four,.form-grid.three,.form-grid.two{grid-template-columns:1fr}.mini-stats,.report-grid,.main-footer{grid-template-columns:repeat(2,1fr)}.size-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:650px){.product-grid,.mini-stats,.report-grid,.main-footer,.footer-editors{grid-template-columns:1fr}.hero h1{font-size:52px}.hero h2{font-size:26px}.main-header{height:auto;grid-template-columns:80px 1fr}.pill-btn{padding:12px}.size-row{grid-template-columns:repeat(2,1fr)}}
@media print{body{background:#fff}.customer-page,.sidebar,.admin-main>.admin-page:not(#page-preview),#printBtn,.hint{display:none!important}.admin-app{display:block}.admin-main{padding:0}.admin-page{display:none!important}#page-preview{display:block!important}.preview-area{text-align:left}.invoice-box{box-shadow:none;border-radius:0;margin:5mm 5mm 0 auto;width:108mm;min-height:185mm;padding:6mm}@page{size:330mm 215mm;margin:0}}

/* final revision patches */
.cat-wrap{position:relative}.category-menu{position:absolute;top:58px;left:0;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:8px;min-width:230px;z-index:50}.category-menu button{display:block;width:100%;text-align:left;border:0;background:#fff;border-radius:12px;padding:12px 14px;font-weight:900;color:var(--ink)}.category-menu button:hover{background:#eef6ff}.promo-btn{background:#fff7db!important;border-color:#ffe08a!important;color:#9a6100!important}.product-card .media{cursor:pointer}.product-card .media img{object-fit:cover}.detail-grid{display:grid;grid-template-columns:380px 1fr;gap:24px}.detail-main-img{height:420px;background:#f7f9fc;border:1px solid var(--line);border-radius:18px;display:grid;place-items:center;overflow:hidden}.detail-main-img img{max-width:100%;max-height:100%;object-fit:contain}.detail-thumbs,.setting-gallery{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}.detail-thumbs button,.setting-gallery img{width:78px;height:78px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:4px;object-fit:contain}.detail-thumbs img{width:100%;height:100%;object-fit:contain}.promo-badge{display:inline-flex;background:#ffefae;color:#8a5700;border-radius:999px;padding:5px 9px;font-weight:1000;font-size:12px}.old-price{text-decoration:line-through;color:#8a93a7;font-size:16px;margin-right:8px}.promo-price{color:#d7202d;font-size:28px;font-weight:1000}.promo-list,.kategori-list{display:grid;gap:10px;margin-top:16px}.promo-item,.kategori-item{border:1px solid var(--line);border-radius:14px;background:#fbfdff;padding:14px}.cart-head,.cart-toggle,.btn,.pill-btn,.cat-btn{font-family:Calibri,Arial,sans-serif}.cart-head{letter-spacing:.01em}.preview-img img{object-fit:contain!important}.setting-gallery img{width:115px;height:115px}.media-btn{border:0;padding:0;background:transparent;width:100%;height:100%;display:grid;place-items:center}.media-btn img{width:100%;height:100%;object-fit:cover}.media-btn .placeholder{width:78%;height:78%}@media(max-width:900px){.detail-grid{grid-template-columns:1fr}.detail-main-img{height:320px}}


/* Fix icon keranjang: SVG inline 1 warna, tidak bergantung emoji/font eksternal */
.cart-icon{width:22px;height:22px;display:inline-block;vertical-align:-5px;margin-right:8px;color:currentColor;flex:0 0 auto}
.btn .cart-icon,.cart-head .cart-icon,.cart-toggle .cart-icon{color:currentColor}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}
.cart-head{display:flex;align-items:center;gap:8px}
.cart-toggle{display:inline-flex;align-items:center;gap:6px}


/* === REVISI SEMENTARA - FIX LAYOUT KERANJANG, PROMO, DETAIL PRODUK === */
body{font-family:Calibri,Arial,sans-serif!important;}
.main-header{
  min-height:98px!important;height:auto!important;
  grid-template-columns:120px 150px minmax(260px,1fr) auto auto auto auto!important;
  gap:14px!important;
}
.cart-toggle{white-space:nowrap;display:inline-flex!important;align-items:center;gap:8px;justify-content:center;}
.cart-icon{width:22px;height:22px;display:inline-block;vertical-align:-4px;color:currentColor;flex:none;}
.btn .cart-icon,.cart-head .cart-icon{width:23px;height:23px;margin-right:8px;vertical-align:-5px;}
.cart-head{display:flex;align-items:center;gap:8px;}
.cart-head span{margin-left:auto!important;}
.shop-layout{align-items:start!important;grid-template-columns:minmax(0,1fr) 470px!important;}
.cart-panel{grid-column:2!important;position:sticky!important;top:118px!important;z-index:2!important;}
.promo-btn{animation:promoPulse 1.8s infinite;}
@keyframes promoPulse{0%{box-shadow:0 0 0 0 rgba(255,209,63,.7)}70%{box-shadow:0 0 0 12px rgba(255,209,63,0)}100%{box-shadow:0 0 0 0 rgba(255,209,63,0)}}
.detail-grid.detail-smart{grid-template-columns:430px 1fr;}
.variant-panel{display:grid;gap:14px;margin:16px 0;}
.option-group{display:grid;gap:8px;}
.option-group b{color:var(--navy2);}
.option-buttons{display:flex;gap:8px;flex-wrap:wrap;}
.option-buttons button{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:10px 15px;font-weight:900;}
.option-buttons button.active{background:var(--blue);color:#fff;border-color:var(--blue);}
.option-buttons button.disabled{opacity:.45;background:#f3f6fb;text-decoration:line-through;cursor:not-allowed;}
.detail-info-line{border:1px solid var(--line);background:#f9fbff;border-radius:14px;padding:12px 14px;color:#30455f;}
.detail-main-img img,.preview-img img,.setting-gallery img{object-fit:contain!important;}
.old-price{display:inline-block;}
@media(max-width:1200px){.main-header{grid-template-columns:90px 140px minmax(180px,1fr) auto auto!important}.promo-btn{display:none}.shop-layout{grid-template-columns:1fr!important}.cart-panel{grid-column:1!important;position:relative!important;top:auto!important}.detail-grid.detail-smart{grid-template-columns:1fr}}
@media(max-width:760px){.main-header{grid-template-columns:70px 1fr auto!important}.cat-wrap{display:none}.search-box{grid-column:2 / -1}.pill-btn{padding:11px 12px}.hero-auto{padding:34px 20px}.cart-toggle{position:fixed;right:14px;bottom:14px;z-index:40;background:#fff!important}.cart-panel{display:block}.product-grid{grid-template-columns:1fr!important}}


/* === Revisi cart compact + filter customer === */
.product-tools{display:flex;justify-content:flex-end;margin:-6px 0 16px;gap:10px}
.product-tools select{border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px 16px;font-weight:900;color:var(--ink);min-width:220px}
.cart-panel{max-height:calc(100vh - 135px)!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}
.cart-head{flex:0 0 auto!important;padding:20px 22px!important;font-size:24px!important}
.cart-items{flex:1 1 auto!important;overflow-y:auto!important;min-height:90px!important;max-height:none!important;padding:14px 18px!important}
.cart-total{flex:0 0 auto!important;padding:16px 20px!important;background:#fff;z-index:2}
.cart-panel .btn{flex:0 0 auto!important;margin:0 20px 10px!important;width:calc(100% - 40px)!important;padding:13px 14px!important}
.cart-trust{flex:0 0 auto!important;font-size:11px!important;padding:12px 8px!important;gap:6px;flex-wrap:wrap}
.cart-group{border-bottom:1px solid #edf0f8;padding:8px 0}
.cart-group-head{display:grid;grid-template-columns:42px 1fr auto;gap:10px;align-items:center;width:100%;border:0;background:#fff;color:var(--ink);text-align:left;padding:6px 0;cursor:pointer}
.cart-group-head img,.cart-group-head .mini-img{width:42px!important;height:42px!important;border-radius:10px;object-fit:cover;background:#edf2f8}
.cart-group-head b{font-size:15px;display:block;line-height:1.1}.cart-group-head small{color:var(--muted);font-size:12px}.cart-group-head strong{font-size:15px;color:var(--navy2);white-space:nowrap}.cart-group-head em{font-style:normal;color:#7d87a3;margin-left:6px}
.cart-group-lines{margin:4px 0 4px 52px;border-left:2px solid #edf0f8;padding-left:10px;display:grid;gap:5px}
.cart-line{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:12px;color:#41506d}.cart-line b{font-size:12px;color:var(--navy2)}.cart-line-actions{display:flex;gap:6px;align-items:center}.mini-action{border:0;border-radius:8px;background:#eef5ff;color:#174c92;font-weight:900;padding:4px 7px;font-size:11px}.mini-action.delete{background:#fff0f0;color:#cf2f35}.cart-empty-compact{padding:16px;color:var(--muted);text-align:center}
@media(max-width:1200px){.cart-panel{max-height:none!important}.cart-items{max-height:360px!important}.product-tools{justify-content:flex-start}}


/* === REVISI LANJUTAN: badge bahan, cart minimize, admin sync icon === */
.material-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:6px 0 10px;color:var(--muted);font-size:14px;font-weight:900}
.material-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:9px;padding:5px 11px;font-size:14px;font-weight:1000;line-height:1;color:#fff;letter-spacing:.04em;box-shadow:0 8px 18px rgba(9,44,84,.08)}
.material-badge.m-24s{background:#e31f2c;color:#fff}.material-badge.m-30s{background:#0aa84f;color:#fff}.material-badge.m-bamboo{background:#8a4bd8;color:#fff}.material-badge.m-default{background:#0b69d1;color:#fff}
.cart-head{display:flex!important;align-items:center!important;gap:12px!important;position:relative!important}.cart-head .cart-title{flex:1}.cart-minimize{margin-left:auto;border:0;background:rgba(255,255,255,.18);color:#fff;width:34px;height:34px;border-radius:50%;font-size:24px;font-weight:1000;line-height:1;display:grid;place-items:center}.cart-minimize:hover{background:rgba(255,255,255,.28)}
.cart-panel.minimized{max-height:76px!important}.cart-panel.minimized .cart-items,.cart-panel.minimized .cart-total,.cart-panel.minimized .btn,.cart-panel.minimized .cart-trust{display:none!important}.cart-panel.minimized .cart-head{border-radius:20px!important}.cart-panel.minimized .cart-minimize{background:#fff;color:var(--navy)}
.cart-group-head b{font-size:17px!important}.cart-group-head small{font-size:13.5px!important}.cart-group-head strong{font-size:17px!important}.cart-line{font-size:13.5px!important}.cart-line b{font-size:13.5px!important}.mini-action{font-size:12px!important;padding:5px 8px!important}.cart-total b{font-size:16px}.cart-total strong{font-size:32px!important}
.sync{width:62px!important;height:62px!important;padding:0!important;border-radius:50%!important;display:grid!important;place-items:center!important;margin:0 auto 20px!important;background:rgba(255,255,255,.12)!important;border:1px solid rgba(255,255,255,.22)!important;box-shadow:0 14px 28px rgba(0,0,0,.14)}
.sync svg{width:30px;height:30px}.sync.good{background:#14bf58!important}.sync.wait{background:#f0aa18!important}.sync.offline{background:#71839c!important}.sync.warn{background:#ffca28!important;color:#07356e!important}.sync .spin{animation:syncSpin 1s linear infinite}@keyframes syncSpin{to{transform:rotate(360deg)}}
.admin-actions-mini{grid-template-columns:72px 1fr!important;align-items:center}.admin-actions-mini button{min-height:60px}.admin-actions-mini #backHomeBtn{border-radius:50%!important;width:62px;height:62px;padding:0!important;display:grid;place-items:center;background:var(--yellow)!important}.admin-actions-mini #backHomeBtn svg{width:29px;height:29px}.admin-actions-mini #logoutAdminBtn{background:#e31f2c!important;color:#fff!important;border-radius:999px!important;font-size:17px!important}
.logout-options{display:grid;gap:12px;margin-top:18px}.logout-options .btn{width:100%;margin:0!important}.logout-note{color:var(--muted);line-height:1.45;margin-top:8px}
@media(max-width:1200px){.cart-panel.minimized{max-height:70px!important}.material-badge{font-size:13px}}


/* === FIX FINAL CART HIDE + PROMO BLINK + HEADER SAFE === */
.main-header{grid-template-columns:120px 160px minmax(280px,1fr) auto auto auto auto!important}
#cartToggleBtn{display:inline-flex!important;align-items:center!important;gap:9px!important;justify-self:end!important;white-space:nowrap!important}
.promo-btn{animation:promoPulseOkaku 1.25s ease-in-out infinite!important;box-shadow:0 0 0 rgba(255,190,0,0)}
@keyframes promoPulseOkaku{0%,100%{filter:brightness(1);box-shadow:0 0 0 0 rgba(255,200,0,0)}50%{filter:brightness(1.08);box-shadow:0 0 0 9px rgba(255,200,0,.18)}}
.shop-layout.cart-hidden{grid-template-columns:1fr!important}
.shop-layout.cart-hidden #cartPanel{display:none!important}
#cartPanel.cart-hidden-panel{display:none!important}
#cartPanel .cart-head{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:14px!important;background:var(--navy)!important;color:#fff!important}
#cartPanel .cart-title{display:block!important;background:transparent!important;color:#fff!important;width:auto!important;height:auto!important;min-width:0!important;border-radius:0!important;margin:0!important;padding:0!important;place-items:unset!important;flex:1!important}
#cartPanel #cartCount{display:inline-grid!important;place-items:center!important;background:#fff!important;color:var(--navy)!important;border-radius:50%!important;min-width:40px!important;height:40px!important;width:auto!important;padding:0 8px!important;margin-left:8px!important;font-size:22px!important;font-weight:1000!important}
#cartMinimizeBtn,.cart-minimize{border:0!important;background:rgba(255,255,255,.18)!important;color:#fff!important;width:38px!important;height:38px!important;border-radius:50%!important;font-size:25px!important;font-weight:1000!important;display:grid!important;place-items:center!important;line-height:1!important;cursor:pointer!important;margin-left:2px!important}
#cartMinimizeBtn:hover,.cart-minimize:hover{background:rgba(255,255,255,.28)!important}
@media(max-width:1100px){.main-header{grid-template-columns:80px 1fr auto auto!important}.search-box{grid-column:2/5}.cat-wrap{display:none}.shop-layout.cart-hidden{grid-template-columns:1fr!important}}

/* === REVISI: MANAGER & ADMIN DINAMIS === */
.admin-manage-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 18px}.admin-manage-toolbar .info-box{margin:0;flex:1}.admin-manage-list{display:grid;gap:18px}.admin-manage-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:22px;box-shadow:var(--shadow)}.admin-manage-card.manager{border-color:#1dbf73;background:linear-gradient(180deg,#f5fff9,#fff)}.admin-manage-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.admin-manage-head h3{margin:0;color:#062855;font-size:24px}.role-badge{display:inline-flex;align-items:center;border-radius:999px;padding:7px 12px;font-weight:1000;font-size:12px;letter-spacing:.05em;color:#fff}.role-badge.manager{background:#10a64f}.role-badge.admin{background:#0b69d1}.role-badge.off{background:#9aa3b9}.admin-card-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.manager-only-note{font-size:13px;color:#65718b;margin-top:6px}.side-nav button[data-page="setting"].locked{display:none!important}

/* === REVISI KATALOG: gambar 1:1, full image, 4 kolom saat keranjang disembunyikan === */
.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important;align-items:start!important}.shop-layout.cart-hidden .product-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}.product-card{cursor:pointer}.product-card .media{height:auto!important;aspect-ratio:1/1!important;background:#f6f8fb!important}.product-card .media img,.media-btn img{width:100%!important;height:100%!important;object-fit:contain!important;background:#f6f8fb!important}.media-btn{cursor:pointer}.product-card .placeholder{width:86%!important;height:86%!important}.product-card .body{min-height:230px}.shop-layout.cart-hidden .product-card .body{min-height:220px}@media(max-width:1400px){.shop-layout.cart-hidden .product-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}}@media(max-width:900px){.product-grid,.shop-layout.cart-hidden .product-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}}@media(max-width:560px){.product-grid,.shop-layout.cart-hidden .product-grid{grid-template-columns:1fr!important}}

/* === REVISI BARANG MASUK/KELUAR: PREVIEW GAMBAR PRODUK === */
.movement-preview{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center;margin:18px 0 22px;padding:16px;border:1px solid var(--line);border-radius:20px;background:#f9fcff}.movement-preview-img{width:150px;height:150px;border-radius:18px;border:1px solid #dbe8f7;background:#fff;display:grid;place-items:center;overflow:hidden}.movement-preview-img img{max-width:100%;max-height:100%;object-fit:contain}.movement-preview-placeholder{width:100%;height:100%;display:grid;place-items:center;text-align:center;color:#8a96aa;background:#eef4fb;font-weight:900;padding:12px}.movement-preview-info h3{margin:0 0 6px;color:#062855}.movement-preview-info p{margin:4px 0;color:#65718b}.movement-preview-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.file-btn{position:relative;overflow:hidden;display:inline-flex}.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}.movement-preview .tag{display:inline-flex;border-radius:999px;background:#e9f4ff;color:#0b69d1;padding:5px 10px;font-weight:900;font-size:12px;margin-right:6px}.movement-preview.warning{background:#fffaf0;border-color:#ffe1a2}.movement-preview.ok{background:#f4fff8;border-color:#c8f3d8}@media(max-width:700px){.movement-preview{grid-template-columns:1fr}.movement-preview-img{width:100%;height:220px}}

/* === LAPORAN BULANAN PRINT F4 === */
.monthly-report-print{background:#fff;border:1px solid var(--line);border-radius:22px;margin-top:20px;padding:24px;box-shadow:var(--shadow);color:#10284f}.report-print-head{display:flex;justify-content:space-between;gap:20px;border-bottom:3px solid #1f2a6d;padding-bottom:14px;margin-bottom:18px}.report-print-head h1{margin:0;color:#1f2a6d;font-size:28px}.report-print-head small{color:#65718b;font-weight:900}.report-print-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}.report-print-card{border:1px solid #dce8f6;border-radius:14px;padding:12px;background:#f8fbff}.report-print-card small{display:block;color:#65718b;font-weight:900;text-transform:uppercase}.report-print-card b{font-size:22px;color:#0b3c72}.report-section-title{margin:22px 0 10px;padding:8px 12px;border-radius:10px;background:#1f2a6d;color:#fff;font-size:16px}.report-table{width:100%;border-collapse:collapse;font-size:11px}.report-table th{background:#e9f3ff;color:#003c80;padding:7px;border:1px solid #d6e6f7}.report-table td{padding:6px;border:1px solid #e1ebf6}.report-sign{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:30px}.report-sign div{height:90px;border-top:1px solid #7b8799;text-align:center;padding-top:8px;color:#65718b}@page{size:330mm 215mm;margin:8mm}@media print{body.print-report *{visibility:hidden!important}body.print-report #monthlyReportPrint,body.print-report #monthlyReportPrint *{visibility:visible!important}body.print-report #monthlyReportPrint{position:absolute;left:0;top:0;width:100%;max-width:none;border:0!important;box-shadow:none!important;border-radius:0!important;padding:0!important;margin:0!important}.report-print-grid{grid-template-columns:repeat(4,1fr)!important}.report-table{font-size:9px!important}.report-section-title{font-size:13px!important;margin:12px 0 6px!important}.report-print-head h1{font-size:20px!important}}

/* === REVISI FILTER BAHAN + STOK HABIS === */
.material-filters{display:flex;gap:9px;flex-wrap:wrap;margin:-6px 0 16px}.material-filters button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 15px;font-weight:1000;color:#16345f;box-shadow:0 8px 18px rgba(9,44,84,.06)}.material-filters button.active{background:#1f2a6d;color:#fff;border-color:#1f2a6d}.product-card.is-empty{background:#f2f4f7!important;opacity:.72;filter:grayscale(.35)}.product-card.is-empty .media img{opacity:.45}.stock-empty-label{position:absolute;left:14px;top:14px;background:rgba(38,43,114,.82);color:#fff;border-radius:999px;padding:8px 12px;font-weight:1000;font-size:12px;letter-spacing:.04em}.product-card.is-empty .btn{background:#c7cbd3!important;color:#5c6472!important;cursor:not-allowed!important}.product-card.is-empty .price-main{color:#7a8290!important}.product-card.is-empty .material-row{color:#7a8290!important}

/* === FIX BUG: badge bahan pasti solid merah/hijau === */
.material-badge.m-24s{background:#e31f2c!important;color:#fff!important}.material-badge.m-30s{background:#0aa84f!important;color:#fff!important}.material-badge.m-bamboo{background:#8a4bd8!important;color:#fff!important}


/* === CEK PAKET WARNA === */
.stock-tab-buttons{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 18px}
.stock-tab-buttons button{border:1px solid var(--line);background:#fff;color:#07356e;border-radius:999px;padding:12px 18px;font-weight:1000;box-shadow:0 8px 18px rgba(0,0,0,.04)}
.stock-tab-buttons button.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.stock-tab-content{display:none}
.stock-tab-content.active{display:block}
.package-parsed{margin:16px 0}
.package-result{display:grid;gap:14px;margin-top:16px}
.package-section-title{font-size:20px;margin:18px 0 8px;color:#07356e}
.package-card{border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 12px 28px rgba(12,35,74,.06);padding:16px}
.package-card.complete{border-color:#9be7bc;background:#f3fff7}
.package-card.partial{border-color:#ffd5a3;background:#fffaf1}
.package-card h3{margin:0 0 8px;font-size:22px;color:#07356e;display:flex;justify-content:space-between;gap:10px}
.package-card h3 span{font-size:13px;border-radius:999px;padding:6px 10px;background:#0aa84f;color:#fff;white-space:nowrap}
.package-card.partial h3 span{background:#ef8a00}
.package-lines{display:grid;gap:5px;font-size:14px;color:#30455f}
.package-lines div{display:flex;justify-content:space-between;gap:10px;border-top:1px dashed #dde8f5;padding-top:5px}
.package-lines b{color:#07356e}
.package-missing{color:#d12b2b;font-weight:900}
@media(max-width:700px){.stock-tab-buttons button{flex:1}.package-card h3{font-size:18px;display:block}.package-card h3 span{display:inline-block;margin-top:6px}}


/* === GRID INPUT CEK PAKET WARNA === */
.package-size-grid{display:grid;gap:16px;margin:16px 0}
.pkg-group{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fff}
.pkg-group h3{margin:0 0 14px;font-size:16px;font-weight:1000;letter-spacing:.3px}
.pkg-group.dewasa-pendek h3{color:#0b66c3}
.pkg-group.dewasa-panjang h3{color:#e00000}
.pkg-group.anak-pendek h3{color:#069b28}
.pkg-group.anak-panjang h3{color:#c97800}
.pkg-grid{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));gap:10px}
.pkg-size-card{border:1px solid #d8e6f6;border-radius:14px;background:#f8fbff;padding:12px;text-align:center}
.pkg-size-card.empty{background:#fff7f7;border-color:#ffd1d1}
.pkg-size-card b{display:block;font-size:12px;margin-bottom:8px;color:#071f44}
.pkg-size-card input{width:100%;border:1px solid #cfe0f2;border-radius:12px;padding:10px;text-align:center;font-size:16px;background:#fff}
.pkg-size-card.empty input{border-color:#ff9f9f;background:#fff9f9}
.pkg-size-card small{display:block;margin-top:8px;color:#637189}
.pkg-size-card.empty small{color:#e31b1b;font-weight:900}
.package-paste-box{margin:12px 0 16px;border:1px dashed #cfe0f2;border-radius:16px;background:#fbfdff;padding:12px}
.package-paste-box summary{font-weight:1000;color:#07356e;cursor:pointer}
.package-paste-box .form-grid{margin-top:12px}
@media(max-width:1100px){.pkg-grid{grid-template-columns:repeat(4,minmax(120px,1fr))}}
@media(max-width:700px){.pkg-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}.pkg-group{padding:12px}}


/* === FINAL BATCH: branding sidebar, promo pindah bawah, cart buttons, compact results === */
:root{--okaku-logo-blue:#262b72;}
#promoBtn{display:none!important}
.sidebar{background:var(--okaku-logo-blue)!important;color:#fff!important}
.admin-card{padding:10px 12px!important;border-radius:15px!important;margin-bottom:10px!important}
.admin-card small{font-size:10px!important}
.admin-card b{font-size:18px!important;margin:5px 0!important}
.admin-actions-mini button{padding:8px 8px!important;font-size:12px!important}
.bonus-card{padding:12px 14px!important;border-radius:15px!important;margin-bottom:12px!important}
.bonus-card small{font-size:11px!important}
.bonus-card b{font-size:20px!important;margin:6px 0!important}
.bonus-card span{padding:5px 10px!important;font-size:12px!important}
.bonus-card em{font-size:12px!important;margin-top:6px!important}
.promo-filter-btn{background:linear-gradient(135deg,#ffdd44,#ff9f1a)!important;color:#5b3200!important;border-color:#ffd060!important;font-weight:1000!important;box-shadow:0 10px 24px rgba(255,165,0,.2)}
.promo-filter-btn.active{background:linear-gradient(135deg,#ff8a00,#ffcf32)!important;color:#fff!important;border-color:#ff8a00!important}
.product-card .promo-badge{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff3b30,#ff9f1a);color:#fff;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:1000;letter-spacing:.04em;width:max-content;box-shadow:0 8px 18px rgba(255,75,43,.22)}
.product-card .promo-price{color:#e00000}
.product-card .old-price{text-decoration:line-through;color:#8993a6;font-size:15px;margin-right:8px}
.package-result{grid-template-columns:repeat(auto-fit,minmax(330px,560px));align-items:start;gap:14px 18px}
.package-section-title{grid-column:1/-1;margin:12px 0 2px}
.package-card{max-width:560px;padding:14px!important}
.package-card h3{font-size:19px!important;margin-bottom:6px!important}
.package-lines div{justify-content:flex-start!important;gap:18px!important}
.package-lines b{min-width:120px;text-align:left}
.cart-trust{font-size:12px}
@media(max-width:900px){.package-result{grid-template-columns:1fr}.package-card{max-width:none}}


/* === REVISI 1-4 FINAL === */
.bar-title:before{background:var(--blue)!important}
.payment .pay-extra-actions{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 12px}
.payment .pay-extra.hidden{display:none!important}
.payment input::placeholder,.size-cell input::placeholder{color:#8b98aa}
.size-cell input{transition:.18s ease}
.size-cell.filled{border-color:#0b69d1!important;background:#eef7ff!important;box-shadow:0 0 0 2px rgba(11,105,209,.09)}
.size-cell.filled input{border-color:#0b69d1!important;background:#fff!important;font-weight:1000;color:#003b77}
.product-slot-gallery{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:14px;margin:14px 0}
.product-slot-card{border:1px solid var(--line);border-radius:18px;background:#fbfdff;padding:14px}
.product-slot-card.is-cover{border-color:#0b69d1;box-shadow:0 0 0 2px rgba(11,105,209,.12)}
.product-slot-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}
.product-slot-title{font-weight:1000;color:#07356e}
.product-slot-preview{min-height:260px;border:1px dashed var(--line);border-radius:16px;background:#fff;display:grid;place-items:center;overflow:auto;margin-bottom:10px;padding:8px}
.product-slot-preview img{max-width:100%;height:auto;max-height:none;object-fit:contain;display:block}
.product-slot-actions{display:flex;gap:8px;flex-wrap:wrap}
.product-slot-actions input{display:none}
.cover-radio{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:#0b69d1}
.invoice-box{position:relative}
.inv-logo{max-width:92px;max-height:48px;object-fit:contain;display:block}
.inv-brand-sub{font-size:9px;letter-spacing:.02em;margin-top:4px}
.inv-mode{color:#262b72!important;font-size:12px!important;line-height:1.15}
.inv-mode small{font-size:9px!important;color:#262b72!important}
.invoice-box h2.invoice-title{font-size:16px!important;letter-spacing:.34em!important;margin:12px 0 12px!important}
.inv-made-by{position:absolute;right:8mm;bottom:5mm;color:#8a8f9c;font-size:7.8px;text-align:right}
@media(max-width:760px){.product-slot-gallery{grid-template-columns:1fr}}
@media print{.inv-made-by{right:6mm;bottom:5mm}.inv-logo{max-width:86px;max-height:42px}.invoice-box h2.invoice-title{font-size:15px!important}}


/* === BUGFIX PELAN-PELAN: subkategori, promo kedip, sidebar menu box, slot upload === */
@keyframes okakuPromoPulse{
  0%,100%{transform:translateY(0);box-shadow:0 8px 18px rgba(255,159,26,.16)}
  50%{transform:translateY(-2px);box-shadow:0 14px 30px rgba(255,95,0,.32)}
}
.promo-filter-btn{animation:okakuPromoPulse 1.25s ease-in-out infinite!important}
.side-nav button:not(.active){background:#0b69d1!important;border-color:rgba(255,255,255,.2)!important;color:#fff!important}
.side-nav button:not(.active):hover{filter:brightness(1.05)}
.product-slot-card input[type="file"]{display:block!important;width:100%;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;margin:8px 0}
.product-slot-actions .btn{padding:10px 14px}
.product-slot-preview{max-height:360px}
.product-slot-preview img{max-width:100%;height:auto!important;object-fit:contain!important}
.pay-extra-actions .btn{font-size:13px;padding:10px 12px}

/* === COLOR TUNE: side menu + admin card closer to OKAKU blue === */
:root{--okaku-box-blue:#334692;}
.side-nav button:not(.active){background:var(--okaku-box-blue)!important;border-color:rgba(255,255,255,.16)!important;color:#fff!important;box-shadow:0 10px 22px rgba(8,18,60,.10)!important}
.side-nav button:not(.active):hover{filter:brightness(1.04)!important}
.admin-card{background:var(--okaku-box-blue)!important;border-color:rgba(255,255,255,.18)!important;box-shadow:0 10px 22px rgba(8,18,60,.10)!important}
.admin-card small{color:#d7e2ff!important}




/* === Kategori dashboard editable === */
.kategori-manager-head{display:grid;gap:10px;margin-bottom:14px}
.kategori-toggle{display:flex!important;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:16px 18px;margin:12px 0;text-transform:none;letter-spacing:0;cursor:pointer}
.kategori-toggle input{width:20px;height:20px;margin:0}
.kategori-toggle span{display:grid;gap:4px;flex:1}
.kategori-toggle span b{font-size:17px;color:#062855}
.kategori-toggle span small{font-size:13px;color:#65718b}
.kategori-toggle em{font-style:normal;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:1000}
.kategori-toggle.on{border-color:#b9d4ff;background:#f8fbff}
.kategori-toggle.on em{background:#e6f1ff;color:#0b69d1}
.kategori-toggle.off{opacity:.72;background:#f5f7fa}
.kategori-toggle.off em{background:#eceff4;color:#65718b}





/* === setting kategori: filter khusus + bahan === */
.setting-section-title{font-size:20px;color:#062855;margin:24px 0 10px}
.kategori-manager-head + .setting-section-title{margin-top:8px}
.kategori-toggle.off{filter:grayscale(.1)}





/* === Cek Paket Warna dengan gambar === */
.package-card.with-image{display:grid!important;grid-template-columns:116px minmax(0,1fr);gap:14px;align-items:start}
.package-card-img{width:116px;height:116px;border-radius:16px;border:1px solid #d9e7f7;background:#fff;display:grid;place-items:center;overflow:hidden}
.package-card-img img{width:100%;height:100%;object-fit:contain}
.package-no-img{width:100%;height:100%;display:grid;place-items:center;text-align:center;padding:10px;background:linear-gradient(135deg,#334692,#22b8b8);color:#fff;font-weight:1000;font-size:13px}
.package-card-info{min-width:0}
@media(max-width:650px){.package-card.with-image{grid-template-columns:86px 1fr}.package-card-img{width:86px;height:86px}}





/* === Status stok berwarna === */
.stock-status{display:inline-flex;align-items:center;justify-content:center;min-width:92px;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:1000;letter-spacing:.04em}
.stock-status.kosong{background:#ffe4e4;color:#d71920}
.stock-status.kritis{background:#ffd6dc;color:#b90016}
.stock-status.limit{background:#fff1c2;color:#a76a00}
.stock-status.aman{background:#e7fff0;color:#07883d}
.stock-status.melimpah{background:#e2eeff;color:#0b4aaa}





/* === Deskripsi produk otomatis tampil rapi === */
.detail-grid p,.detail-smart p{white-space:pre-line;line-height:1.55}
#setProdDesc{white-space:pre-line;min-height:260px}
#autoDescBtn{margin:10px 0 18px}





/* === Template Deskripsi === */
.big-textarea{min-height:360px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;line-height:1.55}
.desc-template-preview{white-space:pre-wrap;background:#f6fbff;border:1px solid #d6e7ff;border-radius:18px;padding:18px;min-height:260px;color:#062855;font-size:14px;line-height:1.55;overflow:auto}
.info-box.small{font-size:14px}





/* === Barang Masuk: Produk Baru === */
.row-actions.compact{margin:0 0 16px}
.new-product-modal .bulk-groups{margin-top:14px}
.new-product-modal .size-cell input.filled{background:#eafff3!important;border-color:#14a44d!important;box-shadow:0 0 0 3px rgba(20,164,77,.12)}
.new-prod-preview{margin-top:16px}
#newProdManualRows{min-height:120px}





/* === Autocomplete warna di Setting Gambar Produk === */
.warna-autocomplete-wrap{display:flex;flex-direction:column;gap:6px}
#setImgWarnaSearch{width:100%;padding:18px 18px;border:1px solid #d6e4f7;border-radius:16px;background:#f8fbff;font-weight:900;color:#062855}
#setImgWarnaSearch:focus{outline:none;border-color:#1268d6;box-shadow:0 0 0 4px rgba(18,104,214,.12);background:#fff}
.legacy-hidden-select{display:none!important}





/* === Public Cek Stok Widget === */
.public-stock-widget{position:fixed;right:22px;bottom:22px;z-index:1200;font-family:inherit}
.public-stock-toggle{border:0;border-radius:999px;background:#ffcc26;color:#062855;font-weight:1000;padding:14px 18px;box-shadow:0 12px 30px rgba(0,0,0,.22);cursor:pointer}
.public-stock-choice{position:absolute;right:0;bottom:62px;width:285px;background:#fff;border:1px solid #d8e7f5;border-radius:22px;box-shadow:0 22px 50px rgba(0,0,0,.24);padding:12px;display:grid;gap:10px}
.public-stock-choice button{border:0;text-align:left;border-radius:18px;background:#f4f9ff;padding:14px;cursor:pointer;color:#062855}
.public-stock-choice button:hover{background:#e7f2ff}
.public-stock-choice b{display:block;font-size:16px}
.public-stock-choice span{display:block;font-size:13px;line-height:1.35;color:#5d6b7a;margin-top:3px}
.public-stock-modal-box{max-width:1120px}
.public-stock-box{display:none}
.public-stock-box.active{display:block}
.public-tabs{margin:12px 0 18px}
.public-package-grid .size-cell input.filled{background:#eafff3!important;border-color:#14a44d!important}
@media(max-width:650px){
  .public-stock-widget{right:14px;bottom:14px}
  .public-stock-choice{width:270px}
}





/* === Revisi popup cek stok: tombol paket di bawah input === */
.public-stock-modal-box .bar-title{font-size:30px}
.public-package-action-bottom{margin:18px 0 10px;justify-content:flex-end}
.public-package-action-bottom .btn{min-width:260px}
@media(max-width:650px){.public-package-action-bottom .btn{width:100%}}





/* === Riwayat: Edit Invoice === */
.hist-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.edited-label{display:inline-block;margin-top:4px;color:#1268d6;font-weight:900}
.edit-invoice-banner{border-color:#ffd25b!important;background:#fff8d9!important;color:#062855!important}





/* === Detail Produk: tombol keranjang dekat + sticky === */
.detail-grid-v2{align-items:start}
.detail-info-col{position:relative;padding-bottom:84px}
.detail-buy-box{border:1px solid #dce8f6;background:#f8fbff;border-radius:18px;padding:14px;margin:12px 0 14px}
.detail-selected-info{border:1px solid #d8e8f8;background:#fff;border-radius:14px;padding:10px 12px;margin:8px 0 10px;font-size:13px;line-height:1.45;color:#062855}
.detail-top-cart-btn{margin-top:8px}
.detail-accordion{border:1px solid #e0ebf7;border-radius:16px;background:#fff;margin-top:12px;overflow:hidden}
.detail-accordion summary{cursor:pointer;padding:14px 16px;font-weight:1000;color:#062855;background:#f4f9ff}
.detail-desc-text{padding:14px 16px;line-height:1.55;font-size:13px;color:#062855;max-height:300px;overflow:auto}
.detail-sticky-cart{position:sticky;bottom:-26px;z-index:5;background:#fff;border:1px solid #d5e6f8;border-radius:18px 18px 0 0;box-shadow:0 -12px 28px rgba(0,0,0,.12);padding:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px}
.detail-sticky-cart small{display:block;color:#6b7890;font-weight:700}
.detail-sticky-cart b{font-size:18px;color:#062855}
.detail-sticky-cart .btn{min-width:210px}

/* === Invoice print adjustment === */
.invoice-box h2.invoice-title{font-size:18px!important;letter-spacing:.34em!important;margin:14px 0 14px!important}
.invoice-note{font-size:9.3px!important;line-height:1.55!important;color:#333!important;font-weight:700!important}
.inv-made-by{bottom:-5mm!important;right:6mm!important;font-size:7.8px!important}
@media print{
  .invoice-box{margin:5mm .5mm 0 auto!important;width:108mm!important;min-height:185mm!important;padding:6mm!important}
  .invoice-box h2.invoice-title{font-size:17px!important}
  .invoice-note{font-size:9px!important;line-height:1.5!important}
  .inv-made-by{right:6mm!important;bottom:-5mm!important}
}
@media(max-width:760px){
  .detail-sticky-cart{bottom:-26px}
  .detail-sticky-cart{flex-direction:column;align-items:stretch}
  .detail-sticky-cart .btn{width:100%;min-width:0}
}





/* === Fix detail UI setelah sticky: pakai tombol varian lama === */
.detail-smart .option-buttons button.disabled{opacity:.55;text-decoration:line-through;cursor:pointer}
.detail-smart .option-buttons button.active{background:#1268d6!important;color:#fff!important;border-color:#1268d6!important}
.detail-smart .variant-panel{margin-top:12px}
.detail-smart .detail-accordion{margin-top:16px}





/* === FIX Detail Produk & Panduan Ukuran lebih besar === */
.detail-accordion summary{
  font-size:18px!important;
  padding:18px 20px!important;
  letter-spacing:.02em!important;
}
.detail-desc-text{
  font-size:15.5px!important;
  line-height:1.7!important;
  padding:18px 20px!important;
  color:#062855!important;
}
.detail-desc-text b,
.detail-desc-text strong{
  font-size:16px!important;
}
@media(max-width:760px){
  .detail-accordion summary{font-size:17px!important}
  .detail-desc-text{font-size:15px!important}
}





/* === Detail Layout V3 sesuai arahan: deskripsi di bawah === */
.detail-layout-v3{display:block}
.detail-grid-v3{grid-template-columns:minmax(360px,1fr) minmax(420px,1.05fr)!important;gap:34px!important;align-items:start}
.detail-buy-col-v3 h2{text-transform:none;font-size:26px!important;margin:8px 0 14px}
.detail-buy-col-v3>p{font-size:17px!important;margin-bottom:16px}
.detail-buy-col-v3 .detail-price{font-size:30px!important;margin:8px 0 16px}
.detail-buy-col-v3 .detail-buy-box{padding:18px 20px!important;border-radius:20px!important}
.detail-sku-info{font-size:15px!important;line-height:1.55!important;background:#fff!important}
.detail-sku-info .stock-red{color:#e21d2f!important;font-weight:1000!important;font-size:17px!important}
.detail-qty-line{display:flex;align-items:end;gap:14px;margin:12px 0 14px}
.detail-qty-line label{max-width:150px;margin:0!important}
.detail-qty-line input{width:125px!important;text-align:center;font-weight:1000}
.detail-v3-total{font-weight:1000;color:#062855;padding:13px 16px;background:#fff;border:1px solid #d8e8f8;border-radius:14px;min-width:170px}
.detail-bottom-desc{margin-top:28px!important;border-radius:0!important;border-left:0!important;border-right:0!important;border-bottom:0!important;background:#f7fbff!important}
.detail-bottom-desc summary{font-size:20px!important;padding:18px 20px!important}
.detail-bottom-desc .detail-desc-text{max-height:none!important;overflow:visible!important;font-size:16px!important;line-height:1.75!important;padding:28px 20px!important;background:#fff!important}
.detail-info-col{padding-bottom:0!important}
@media(max-width:900px){
  .detail-grid-v3{grid-template-columns:1fr!important}
  .detail-qty-line{align-items:stretch;flex-direction:column}
  .detail-qty-line label,.detail-qty-line input{max-width:100%!important;width:100%!important}
}



.detail-inline-row{display:grid;grid-template-columns:150px minmax(0,1fr);gap:16px;align-items:end;margin-top:10px}.detail-qty-wrap{display:flex;flex-direction:column;gap:8px;font-weight:800;color:#0b3779;font-size:14px;letter-spacing:.2px}.detail-qty-wrap input{width:100%;height:56px;padding:10px 14px;border-radius:16px;font-size:28px;font-weight:900;text-align:center}.detail-sku-stock{min-width:0;background:#f8fbff;border:1px solid #dbe9f7;padding:12px 14px;border-radius:14px;font-size:14px;line-height:1.45;color:#153a6d;display:flex;flex-direction:column;justify-content:center;min-height:56px}.detail-sku-stock b:first-child{display:block;font-size:19px;line-height:1.25;color:#082b63;word-break:break-word;margin-bottom:4px}.detail-stock-red{color:#e53935;font-size:18px}.variant-panel label{display:block}@media(max-width:760px){.detail-inline-row{grid-template-columns:1fr;gap:12px}.detail-qty-wrap{max-width:160px}.detail-sku-stock{padding:12px}.detail-sku-stock b:first-child{font-size:16px}.detail-stock-red{font-size:17px}}



/* === FINAL DETAIL PRODUK: rapi sesuai contoh user === */
.detail-layout-final{display:block}
.detail-grid-final{grid-template-columns:minmax(360px,1fr) minmax(430px,1.05fr)!important;gap:34px!important;align-items:start}
.detail-buy-col-final h2{font-size:28px!important;line-height:1.15;margin:8px 0 12px!important;text-transform:none}
.detail-material-line{font-size:17px!important;margin:0 0 16px!important}
.detail-price-main{font-size:32px!important;margin:6px 0 16px!important}
.detail-buy-box-final{border:1px solid #d7e6f6!important;background:#f8fbff!important;border-radius:20px!important;padding:18px 20px!important}
.detail-buy-box-final .option-group{margin-bottom:16px}
.detail-buy-box-final .option-group>b{display:block;font-size:16px!important;letter-spacing:.03em;margin-bottom:9px;color:#062855}
.detail-buy-box-final .option-buttons{display:flex;flex-wrap:wrap;gap:10px}
.detail-buy-box-final .option-buttons button{min-width:78px;padding:12px 18px;border-radius:999px;font-weight:1000}
.detail-buy-box-final .option-buttons button.active{background:#1268d6!important;color:#fff!important;border-color:#1268d6!important}
.detail-buy-box-final .option-buttons button.disabled,
.detail-buy-box-final .option-buttons button:disabled{opacity:.5;text-decoration:line-through;cursor:not-allowed}
.detail-bottom-row-final{display:grid;grid-template-columns:150px minmax(0,1fr);gap:16px;align-items:end;margin:8px 0 16px}
.detail-qty-final{display:flex!important;flex-direction:column;gap:8px;font-size:16px!important;font-weight:1000!important;letter-spacing:.08em;color:#0a2b5e!important;margin:0!important}
.detail-qty-final input{width:100%!important;height:56px!important;text-align:center!important;font-size:24px!important;font-weight:1000!important;border-radius:16px!important}
.detail-code-stock-final{min-width:0;background:#fff;border:1px solid #dce9f7;border-radius:14px;padding:12px 16px;min-height:56px;display:flex;flex-direction:column;justify-content:center}
.detail-code-final{font-size:16px;font-weight:1000;color:#062855;line-height:1.3;word-break:break-word}
.detail-stock-final{margin-top:4px;font-size:17px;font-weight:1000;color:#1d2d44;letter-spacing:.02em}
.detail-stock-final b{color:#e21d2f!important;font-size:21px!important}
.detail-add-btn-final{height:58px!important;font-size:18px!important;border-radius:16px!important;margin-top:4px!important}
.detail-desc-bottom-final{margin-top:28px!important;border-radius:18px!important;overflow:hidden;background:#fff!important;border:1px solid #dce9f7!important}
.detail-desc-bottom-final summary{font-size:21px!important;font-weight:1000!important;padding:18px 22px!important;background:#f4f9ff!important;color:#062855!important}
.detail-desc-readable{max-height:none!important;overflow:visible!important;padding:24px 28px!important;background:#fff!important;font-size:16px!important;line-height:1.78!important;color:#062855!important}
.okaku-desc-heading{font-weight:1000!important;font-size:18px!important;margin:18px 0 8px!important;color:#004386!important;letter-spacing:.04em}
.okaku-desc-heading:first-child{margin-top:0!important}
.okaku-desc-line{margin:6px 0!important}
.okaku-desc-line b{font-weight:1000!important;color:#001d3d!important}
@media(max-width:900px){
  .detail-grid-final{grid-template-columns:1fr!important}
  .detail-bottom-row-final{grid-template-columns:1fr!important}
  .detail-qty-final{max-width:170px}
  .detail-code-final{font-size:14px}
  .detail-desc-readable{font-size:15px!important;padding:20px!important}
}




/* === COMPACT DETAIL MODAL: tombol keranjang terlihat dalam 1 layar === */
@media (min-width: 901px){
  .modal .modal-card,
  #productModal .modal-card,
  .product-modal .modal-card{
    max-width: 1060px !important;
    width: calc(100vw - 64px) !important;
    max-height: 88vh !important;
    overflow-y: auto !important;
  }

  .detail-grid-final{
    grid-template-columns: minmax(350px, 0.95fr) minmax(360px, 0.9fr) !important;
    gap: 18px !important;
  }

  .detail-main-img{
    max-height: 450px !important;
    overflow: hidden !important;
    border-radius: 18px !important;
  }
  .detail-main-img img{
    width: 100% !important;
    height: 450px !important;
    object-fit: cover !important;
  }

  .detail-thumbs{
    margin-top: 10px !important;
    gap: 8px !important;
  }
  .detail-thumbs button{
    width: 72px !important;
    height: 72px !important;
    padding: 4px !important;
    border-radius: 12px !important;
  }
  .detail-thumbs button img{
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 8px !important;
  }

  .detail-buy-col-final h2{
    font-size: 24px !important;
    margin: 4px 0 8px !important;
  }
  .detail-material-line{
    font-size: 15px !important;
    margin: 0 0 8px !important;
  }
  .detail-price-main{
    font-size: 28px !important;
    margin: 2px 0 10px !important;
  }

  .detail-buy-box-final{
    padding: 14px 16px !important;
    border-radius: 16px !important;
  }

  .detail-buy-box-final .option-group{
    margin-bottom: 10px !important;
  }
  .detail-buy-box-final .option-group > b{
    font-size: 15px !important;
    margin-bottom: 6px !important;
  }
  .detail-buy-box-final .option-buttons{
    gap: 8px !important;
  }
  .detail-buy-box-final .option-buttons button{
    min-width: 70px !important;
    padding: 9px 14px !important;
    font-size: 15px !important;
    line-height: 1.15 !important;
  }

  .detail-bottom-row-final{
    grid-template-columns: 136px minmax(0,1fr) !important;
    gap: 12px !important;
    margin: 6px 0 12px !important;
    align-items: end !important;
  }

  .detail-qty-final{
    gap: 6px !important;
    font-size: 14px !important;
  }
  .detail-qty-final input{
    height: 48px !important;
    font-size: 21px !important;
    border-radius: 14px !important;
  }

  .detail-code-stock-final{
    min-height: 48px !important;
    padding: 10px 14px !important;
    border-radius: 12px !important;
  }
  .detail-code-final{
    font-size: 14px !important;
    line-height: 1.25 !important;
  }
  .detail-stock-final{
    margin-top: 2px !important;
    font-size: 15px !important;
  }
  .detail-stock-final b{
    font-size: 18px !important;
  }

  .detail-add-btn-final{
    height: 50px !important;
    font-size: 17px !important;
    border-radius: 14px !important;
    margin-top: 0 !important;
  }

  .detail-desc-bottom-final{
    margin-top: 18px !important;
  }
  .detail-desc-bottom-final summary{
    font-size: 18px !important;
    padding: 14px 18px !important;
  }
  .detail-desc-readable{
    padding: 18px 20px !important;
    font-size: 15px !important;
    line-height: 1.65 !important;
  }
  .okaku-desc-heading{
    font-size: 17px !important;
    margin: 12px 0 6px !important;
  }
  .okaku-desc-line{
    margin: 4px 0 !important;
  }
}



/* === EXTRA COMPACT DETAIL MODAL v2 === */
@media (min-width: 901px){
  .modal .modal-card,
  #productModal .modal-card,
  .product-modal .modal-card{
    max-width: 1080px !important;
    width: calc(100vw - 56px) !important;
    max-height: 90vh !important;
    overflow-y: auto !important;
  }

  .detail-grid-final{
    grid-template-columns: minmax(330px, 0.88fr) minmax(340px, 0.92fr) !important;
    gap: 14px !important;
    align-items: start !important;
  }

  .detail-main-img{
    min-height: 0 !important;
    height: auto !important;
    max-height: none !important;
    padding: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
  }
  .detail-main-img img{
    width: 100% !important;
    height: auto !important;
    max-height: 355px !important;
    object-fit: contain !important;
    display: block !important;
  }

  .detail-thumbs{
    margin-top: 8px !important;
    gap: 6px !important;
  }
  .detail-thumbs button{
    width: 64px !important;
    height: 64px !important;
    padding: 4px !important;
  }
  .detail-thumbs button img{
    object-fit: contain !important;
  }

  .detail-buy-col-final h2{
    font-size: 22px !important;
    line-height: 1.1 !important;
    margin: 2px 0 6px !important;
  }
  .detail-material-line{
    font-size: 14px !important;
    margin: 0 0 6px !important;
  }
  .detail-price-main{
    font-size: 24px !important;
    margin: 0 0 8px !important;
  }

  .detail-buy-box-final{
    padding: 12px 14px !important;
    border-radius: 16px !important;
  }
  .detail-buy-box-final .option-group{
    margin-bottom: 8px !important;
  }
  .detail-buy-box-final .option-group > b{
    font-size: 14px !important;
    margin-bottom: 4px !important;
  }
  .detail-buy-box-final .option-buttons{
    gap: 6px !important;
  }
  .detail-buy-box-final .option-buttons button{
    min-width: 66px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
  }

  .detail-bottom-row-final{
    grid-template-columns: 120px minmax(0,1fr) !important;
    gap: 10px !important;
    margin: 4px 0 10px !important;
  }
  .detail-qty-final{
    gap: 4px !important;
    font-size: 13px !important;
  }
  .detail-qty-final input{
    height: 44px !important;
    font-size: 20px !important;
    border-radius: 12px !important;
  }
  .detail-code-stock-final{
    min-height: 44px !important;
    padding: 8px 12px !important;
    border-radius: 12px !important;
  }
  .detail-code-final{
    font-size: 13px !important;
    line-height: 1.2 !important;
  }
  .detail-stock-final{
    margin-top: 2px !important;
    font-size: 14px !important;
  }
  .detail-stock-final b{
    font-size: 17px !important;
  }
  .detail-add-btn-final{
    height: 46px !important;
    font-size: 16px !important;
    border-radius: 13px !important;
  }

  .detail-desc-bottom-final{
    margin-top: 12px !important;
  }
  .detail-desc-bottom-final summary{
    font-size: 17px !important;
    padding: 12px 16px !important;
  }
  .detail-desc-readable{
    padding: 14px 16px !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
  }
  .okaku-desc-heading{
    font-size: 16px !important;
    margin: 10px 0 4px !important;
  }
  .okaku-desc-line{
    margin: 3px 0 !important;
  }
}

/* === FINAL FIX: invoice preview/print aman untuk F4 potong 3 + made-by di dalam area === */
.preview-area .invoice-box,
.invoice-box{
  box-sizing:border-box !important;
}
.preview-area .invoice-box{
  width:102mm !important;
  min-height:183mm !important;
  padding:5mm 4.2mm 9mm !important;
  margin:0 auto !important;
  overflow:hidden !important;
}
.preview-area .invoice-box table,
.invoice-box table{
  width:100% !important;
  table-layout:fixed !important;
}
.preview-area .invoice-box th,
.preview-area .invoice-box td,
.invoice-box th,
.invoice-box td{
  font-size:8.6px !important;
  padding:4px 3px !important;
  word-break:break-word !important;
}
.preview-area .invoice-box .meta-compact,
.invoice-box .meta-compact{
  gap:6px 10px !important;
  font-size:9px !important;
}
.preview-area .invoice-box .invoice-title,
.invoice-box .invoice-title{
  font-size:17px !important;
  letter-spacing:.30em !important;
  margin:10px 0 10px !important;
}
.preview-area .invoice-box h3,
.invoice-box h3{
  font-size:12px !important;
  margin:10px 0 6px !important;
}
.preview-area .invoice-box .inv-logo,
.invoice-box .inv-logo{
  max-width:78px !important;
  max-height:38px !important;
}
.preview-area .invoice-box .inv-brand-sub,
.invoice-box .inv-brand-sub{
  font-size:8px !important;
}
.preview-area .invoice-box .inv-mode,
.invoice-box .inv-mode{
  font-size:11px !important;
}
.preview-area .invoice-box .bank-line,
.invoice-box .bank-line{
  font-size:8.2px !important;
  line-height:1.4 !important;
}
.preview-area .invoice-box .invoice-note,
.invoice-box .invoice-note{
  font-size:9.8px !important;
  line-height:1.45 !important;
  font-weight:700 !important;
  margin:10px 0 0 !important;
}
.preview-area .invoice-box .inv-total,
.invoice-box .inv-total{
  width:60mm !important;
  margin-left:auto !important;
}
.preview-area .invoice-box .inv-made-by,
.invoice-box .inv-made-by{
  position:absolute !important;
  right:4mm !important;
  bottom:3.5mm !important;
  max-width:58mm !important;
  color:#8a8f9c !important;
  font-size:7.2px !important;
  text-align:right !important;
  white-space:nowrap !important;
}
@media print{
  @page{size:330mm 215mm;margin:0}
  .preview-area{padding:0 !important}
  .invoice-box{
    width:102mm !important;
    min-height:183mm !important;
    padding:5mm 4mm 8mm !important;
    margin:4mm 3mm 0 auto !important;
    box-shadow:none !important;
    border-radius:0 !important;
    overflow:hidden !important;
  }
  .invoice-box th,
  .invoice-box td{
    font-size:8.4px !important;
    padding:4px 3px !important;
  }
  .invoice-box .meta-compact{
    font-size:8.8px !important;
  }
  .invoice-box .invoice-title{
    font-size:16px !important;
    letter-spacing:.28em !important;
  }
  .invoice-box .invoice-note{
    font-size:9.5px !important;
    line-height:1.42 !important;
  }
  .invoice-box .inv-made-by{
    right:4mm !important;
    bottom:3.5mm !important;
    font-size:7px !important;
  }
}




/* === FINAL PRINT F4 POTONG 3: rata kanan 0.5cm + tabel lebih lega === */
.preview-area .invoice-box{
  width:102mm!important;
  min-height:183mm!important;
  padding:5mm 4.5mm 9mm!important;
  margin-left:auto!important;
  margin-right:5mm!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
}

.invoice-box table{
  width:100%!important;
  table-layout:fixed!important;
  border-collapse:collapse!important;
}
.invoice-box table th,
.invoice-box table td{
  font-size:7.4pt!important;
  line-height:1.22!important;
  padding:3.2px 2.6px!important;
  vertical-align:top!important;
  word-break:normal!important;
  overflow-wrap:break-word!important;
}
.invoice-box table th:nth-child(1),
.invoice-box table td:nth-child(1){width:5%!important;text-align:center!important}
.invoice-box table th:nth-child(2),
.invoice-box table td:nth-child(2){width:30%!important}
.invoice-box table th:nth-child(3),
.invoice-box table td:nth-child(3){width:13%!important}
.invoice-box table th:nth-child(4),
.invoice-box table td:nth-child(4){width:18%!important}
.invoice-box table th:nth-child(5),
.invoice-box table td:nth-child(5){width:6%!important;text-align:center!important}
.invoice-box table th:nth-child(6),
.invoice-box table td:nth-child(6){width:13%!important;text-align:right!important}
.invoice-box table th:nth-child(7),
.invoice-box table td:nth-child(7){width:15%!important;text-align:right!important}

.invoice-box .meta-compact{
  font-size:9.3px!important;
  gap:5px 9px!important;
}
.invoice-box .invoice-title{
  font-size:16.5px!important;
  letter-spacing:.28em!important;
  margin:9px 0 10px!important;
}
.invoice-box h3{
  font-size:12.5px!important;
  margin:9px 0 5px!important;
}
.invoice-box .inv-total{
  width:58mm!important;
  margin-left:auto!important;
}
.invoice-box .bank-line{
  font-size:8.5px!important;
  line-height:1.34!important;
}
.invoice-box .invoice-note{
  font-size:9.8px!important;
  line-height:1.42!important;
}
.invoice-box .inv-made-by{
  position:absolute!important;
  right:4.5mm!important;
  bottom:4mm!important;
  max-width:58mm!important;
  white-space:nowrap!important;
  font-size:7.1px!important;
  color:#8a8f9c!important;
}

@media print{
  @page{size:330mm 215mm;margin:0}
  .invoice-box{
    width:102mm!important;
    min-height:183mm!important;
    padding:5mm 4.5mm 8.5mm!important;
    margin-top:4mm!important;
    margin-right:5mm!important;
    margin-left:auto!important;
    margin-bottom:0!important;
    overflow:hidden!important;
    box-shadow:none!important;
    border-radius:0!important;
  }
  .invoice-box table th,
  .invoice-box table td{
    font-size:7.4pt!important;
    line-height:1.2!important;
    padding:3.1px 2.5px!important;
  }
  .invoice-box .inv-made-by{
    right:4.5mm!important;
    bottom:4mm!important;
  }
}





/* === FINAL FIX: preview tetap tengah, print tetap rata kanan === */
@media screen{
  .preview-area .invoice-box{
    margin-left:auto!important;
    margin-right:auto!important;
  }
}



/* === FINAL GABUNGAN REVISI UI/PDF === */
.compact-cart-item{align-items:start!important}
.compact-cart-item small{display:block;margin-top:2px}
.compact-cart-item .cart-variant-line{font-size:12px;color:#66738b;margin-top:3px}

/* Preview invoice dibesarkan, tetap di tengah layar */
@media screen{
  .preview-area{
    display:grid!important;
    justify-items:center!important;
  }
  .preview-area .invoice-box{
    width:170mm!important;
    min-height:192mm!important;
    padding:7mm 7mm 9mm!important;
    margin-left:auto!important;
    margin-right:auto!important;
    box-shadow:0 12px 30px rgba(6,25,74,.12)!important;
  }
}

/* Print tetap F4 potong 3 rata kanan */
@media print{
  .invoice-box{
    width:102mm!important;
    min-height:183mm!important;
    padding:5mm 4.5mm 8.5mm!important;
    margin-top:4mm!important;
    margin-right:5mm!important;
    margin-left:auto!important;
    margin-bottom:0!important;
  }
}

.invoice-box .inv-top{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:10px!important;
}
.invoice-box .inv-top-right{
  display:grid!important;
  justify-items:end!important;
  gap:2px!important;
  text-align:right!important;
}
.invoice-box .inv-mode{
  font-size:12px!important;
  font-weight:1000!important;
  line-height:1.05!important;
}
.invoice-box .inv-top-sub{
  font-size:8.8px!important;
  color:#76809a!important;
  font-weight:700!important;
  line-height:1.25!important;
}
.invoice-box .inv-top-qty b{color:#0f2f76!important}
.invoice-box .inv-made-by{display:none!important}
.invoice-box .meta-compact{
  font-size:10.2px!important;
  gap:6px 12px!important;
}
.invoice-box .invoice-title{
  font-size:17.5px!important;
  letter-spacing:.34em!important;
  margin:10px 0 10px!important;
}
.invoice-box h3{
  font-size:13px!important;
  margin:9px 0 5px!important;
}
.invoice-box table{
  width:100%!important;
  table-layout:fixed!important;
}
.invoice-box table th,
.invoice-box table td{
  font-size:8pt!important;
  line-height:1.24!important;
  padding:3.4px 2.8px!important;
  vertical-align:top!important;
  word-break:normal!important;
  overflow-wrap:break-word!important;
}
.invoice-box table th:nth-child(1),
.invoice-box table td:nth-child(1){width:6%!important;min-width:20px!important;text-align:center!important;white-space:nowrap!important}
.invoice-box table th:nth-child(2),
.invoice-box table td:nth-child(2){width:33%!important}
.invoice-box table th:nth-child(3),
.invoice-box table td:nth-child(3){width:12%!important}
.invoice-box table th:nth-child(4),
.invoice-box table td:nth-child(4){width:15%!important}
.invoice-box table th:nth-child(5),
.invoice-box table td:nth-child(5){width:6%!important;text-align:center!important}
.invoice-box table th:nth-child(6),
.invoice-box table td:nth-child(6){width:13%!important;text-align:right!important}
.invoice-box table th:nth-child(7),
.invoice-box table td:nth-child(7){width:15%!important;text-align:right!important}
.invoice-box .inv-total{width:60mm!important;margin-left:auto!important}
.invoice-box .bank-line{font-size:8.8px!important;line-height:1.36!important}
.invoice-box .invoice-note{font-size:10.1px!important;line-height:1.45!important}

@media print{
  .invoice-box .meta-compact{font-size:9.7px!important}
  .invoice-box .invoice-title{font-size:16.8px!important}
  .invoice-box h3{font-size:12.6px!important}
  .invoice-box table th,
  .invoice-box table td{font-size:8pt!important;line-height:1.22!important}
  .invoice-box .bank-line{font-size:8.6px!important}
  .invoice-box .invoice-note{font-size:9.8px!important}
  .invoice-box .inv-top-sub{font-size:8.2px!important}
}


/* === HOTFIX: preview lebih besar + kolom No lebih lega === */
.invoice-box table th:first-child,
.invoice-box table td:first-child{
  white-space:nowrap!important;
  word-break:keep-all!important;
  overflow-wrap:normal!important;
  text-align:center!important;
}
.preview-area .invoice-box table th:first-child,
.preview-area .invoice-box table td:first-child{
  padding-left:4px!important;
  padding-right:4px!important;
}


/* === REVISI BARANG KELUAR: tombol, riwayat, print cek === */
.out-action-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin:14px 0 4px;
}
.out-action-row .btn{
  min-width:170px;
}
.out-history-card{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fbfdff;
  margin:12px 0;
  overflow:hidden;
}
.out-history-card summary{
  padding:14px 16px;
  cursor:pointer;
  color:#062855;
}
.out-history-meta{
  padding:0 16px 12px;
  color:#65718b;
  font-size:13px;
  font-weight:700;
}
#outPrintArea{
  display:none;
}
.barang-keluar-print-box .invoice-title{
  letter-spacing:.25em!important;
}
.barang-keluar-print-box .barang-keluar-meta{
  margin-bottom:8px!important;
}
.barang-keluar-table th:first-child,
.barang-keluar-table td:first-child{
  width:6%!important;
  white-space:nowrap!important;
  text-align:center!important;
}
.barang-keluar-table th:nth-child(2),
.barang-keluar-table td:nth-child(2){width:30%!important}
.barang-keluar-table th:nth-child(3),
.barang-keluar-table td:nth-child(3){width:14%!important}
.barang-keluar-table th:nth-child(4),
.barang-keluar-table td:nth-child(4){width:20%!important}
.barang-keluar-table th:nth-child(5),
.barang-keluar-table td:nth-child(5){width:8%!important;text-align:center!important}
.barang-keluar-table th:nth-child(6),
.barang-keluar-table td:nth-child(6){width:11%!important;text-align:center!important}
.barang-keluar-table th:nth-child(7),
.barang-keluar-table td:nth-child(7){width:11%!important;text-align:center!important}
@media print{
  body.print-outdoc > *:not(#outPrintArea){
    display:none!important;
  }
  body.print-outdoc #outPrintArea{
    display:block!important;
  }
  body.print-outdoc #outPrintArea .invoice-box{
    width:102mm!important;
    min-height:183mm!important;
    padding:5mm 4.5mm 8.5mm!important;
    margin-top:4mm!important;
    margin-right:5mm!important;
    margin-left:auto!important;
    margin-bottom:0!important;
    box-shadow:none!important;
    border-radius:0!important;
    overflow:hidden!important;
    background:#fff!important;
  }
  body.print-outdoc #outPrintArea .invoice-box table th,
  body.print-outdoc #outPrintArea .invoice-box table td{
    font-size:8pt!important;
    line-height:1.22!important;
    padding:3.1px 2.5px!important;
  }
}


/* === REVISI DETAIL PRODUK: preview 1:1, thumbnail 1:5, popup full gambar === */
.detail-media-col{
  min-width:0!important;
}
.detail-main-img{
  width:100%!important;
  aspect-ratio:1 / 1!important;
  height:auto!important;
  min-height:0!important;
  max-height:none!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  background:#f3f6fa!important;
  border-radius:18px!important;
}
.detail-main-img img{
  width:100%!important;
  height:100%!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center!important;
  display:block!important;
  cursor:zoom-in!important;
}
.detail-thumbs{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  margin-top:10px!important;
}
.detail-thumbs button{
  flex:0 0 calc((100% - 40px) / 5)!important;
  width:auto!important;
  height:auto!important;
  aspect-ratio:1 / 1!important;
  min-width:70px!important;
  max-width:96px!important;
  padding:5px!important;
  border-radius:12px!important;
  overflow:hidden!important;
}
.detail-thumbs button img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  display:block!important;
  border-radius:8px!important;
}
.okaku-image-lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(4,12,28,.86);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
}
.okaku-image-lightbox.hidden{display:none!important}
.okaku-image-lightbox img{
  max-width:96vw;
  max-height:92vh;
  width:auto;
  height:auto;
  object-fit:contain;
  background:#fff;
  border-radius:18px;
  box-shadow:0 24px 80px rgba(0,0,0,.45);
}
.okaku-lightbox-close{
  position:fixed;
  top:18px;
  right:22px;
  width:48px;
  height:48px;
  border:0;
  border-radius:50%;
  background:#fff;
  color:#001d3d;
  font-size:30px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
@media(max-width:900px){
  .detail-thumbs button{
    flex-basis:calc((100% - 32px) / 4)!important;
  }
}


/* === STABLE PATCH ONLY: tombol detail, beli sekarang, cart qty stepper === */
.product-card .detail-open-btn{
  font-weight:1000!important;
  letter-spacing:.02em!important;
}
.detail-action-row{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:12px!important;
  margin-top:6px!important;
}
.detail-action-row .btn{
  margin:0!important;
  height:56px!important;
  border-radius:16px!important;
  font-size:17px!important;
  font-weight:1000!important;
}
.detail-buy-now-btn{
  background:#f6c433!important;
  color:#08224a!important;
  border:1px solid #e2b320!important;
}
.enhanced-cart-item{
  grid-template-columns:72px 1fr auto!important;
  align-items:start!important;
  gap:14px!important;
  padding:16px 0!important;
}
.enhanced-cart-item img,
.enhanced-cart-item .mini-img{
  width:72px!important;
  height:72px!important;
  border-radius:16px!important;
  object-fit:cover!important;
}
.enhanced-cart-item .cart-main-info{
  display:flex!important;
  flex-direction:column!important;
  gap:4px!important;
}
.enhanced-cart-item .cart-title-row{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  flex-wrap:wrap!important;
}
.enhanced-cart-item .cart-title-row b{
  font-size:17px!important;
  color:var(--navy2)!important;
  text-transform:uppercase!important;
}
.enhanced-cart-item .cart-qty-pill{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:62px!important;
  height:28px!important;
  padding:0 10px!important;
  border-radius:999px!important;
  background:#eef6ff!important;
  color:#1560c2!important;
  font-weight:1000!important;
  font-size:13px!important;
}
.enhanced-cart-item .cart-product-line{
  font-size:15px!important;
  color:#5c6882!important;
}
.enhanced-cart-item .cart-variant-line.strong{
  font-size:15px!important;
  color:#1d2e57!important;
  font-weight:900!important;
}
.enhanced-cart-item .cart-qty-editor{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  flex-wrap:wrap!important;
  margin-top:4px!important;
}
.enhanced-cart-item .cart-qty-label{
  font-size:12px!important;
  color:#74819a!important;
  font-weight:900!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
}
.enhanced-cart-item .cart-stepper{
  display:inline-flex!important;
  align-items:center!important;
  border:1px solid #dbe7f8!important;
  border-radius:12px!important;
  overflow:hidden!important;
  background:#fff!important;
}
.enhanced-cart-item .step-btn{
  width:34px!important;
  height:34px!important;
  border:0!important;
  background:#eef5ff!important;
  color:#13498f!important;
  font-size:20px!important;
  font-weight:1000!important;
  cursor:pointer!important;
}
.enhanced-cart-item .step-btn.plus{
  background:#e6f8f7!important;
  color:#0e8b8b!important;
}
.enhanced-cart-item .step-value{
  min-width:42px!important;
  text-align:center!important;
  font-size:16px!important;
  font-weight:1000!important;
  color:var(--navy2)!important;
  padding:0 8px!important;
}
.enhanced-cart-item .cart-side-info{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-end!important;
  gap:8px!important;
}
.enhanced-cart-item .cart-side-info b{
  font-size:16px!important;
  color:var(--navy2)!important;
  text-align:right!important;
}
.enhanced-cart-item .cart-remove-btn{
  border:0!important;
  background:#fff0f0!important;
  color:#d53a3f!important;
  font-size:13px!important;
  font-weight:1000!important;
  border-radius:10px!important;
  padding:8px 12px!important;
  line-height:1!important;
}
@media(max-width:760px){
  .detail-action-row{grid-template-columns:1fr!important}
  .enhanced-cart-item{grid-template-columns:64px 1fr!important}
  .enhanced-cart-item .cart-side-info{grid-column:2/3!important;align-items:flex-start!important}
}


/* === PATCH KECIL: tombol detail dibalik + keranjang grup warna === */
.detail-action-row-fixed,
.detail-action-row{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:12px!important;
}
.detail-add-cart-left,
.detail-buy-now-right{
  height:58px!important;
  margin:0!important;
  border-radius:16px!important;
  font-weight:1000!important;
  font-size:16px!important;
}
.detail-add-cart-left{
  background:#1268d6!important;
  color:#fff!important;
}
.detail-buy-now-right{
  background:#f6c433!important;
  color:#08224a!important;
  border:1px solid #e2b320!important;
}
.cart-color-group{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:14px;
  padding:16px 0;
  border-bottom:1px solid #edf0f8;
}
.cart-color-img{
  width:72px!important;
  height:72px!important;
  border-radius:16px!important;
  object-fit:cover!important;
  background:#edf2f8!important;
}
.cart-color-body{
  min-width:0;
}
.cart-color-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:10px;
}
.cart-color-head b{
  display:block;
  font-size:18px!important;
  color:var(--navy2);
  text-transform:uppercase;
  line-height:1.1;
}
.cart-color-head small{
  display:block;
  margin-top:3px;
  font-size:14px!important;
  color:#62708b!important;
}
.cart-color-head strong{
  color:var(--navy2);
  font-size:17px!important;
  white-space:nowrap;
}
.cart-color-lines{
  display:grid;
  gap:8px;
  border-left:2px solid #e8eef8;
  padding-left:12px;
}
.cart-group-line{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto auto;
  align-items:center;
  gap:8px;
  font-size:13px;
}
.cart-group-line-main b{
  display:block;
  font-size:14px!important;
  color:#1d2e57;
}
.cart-group-line-main small{
  display:block;
  margin-top:2px;
  color:#74819a!important;
}
.cart-stepper{
  display:inline-flex!important;
  align-items:center!important;
  border:1px solid #dbe7f8!important;
  border-radius:12px!important;
  overflow:hidden!important;
  background:#fff!important;
}
.step-btn{
  width:32px!important;
  height:32px!important;
  border:0!important;
  background:#eef5ff!important;
  color:#13498f!important;
  font-size:19px!important;
  font-weight:1000!important;
  cursor:pointer!important;
}
.step-btn.plus{
  background:#e6f8f7!important;
  color:#0e8b8b!important;
}
.step-value{
  min-width:38px!important;
  text-align:center!important;
  font-size:15px!important;
  font-weight:1000!important;
  color:var(--navy2)!important;
  padding:0 8px!important;
}
.cart-remove-btn{
  border:0!important;
  background:#fff0f0!important;
  color:#d53a3f!important;
  font-size:12px!important;
  font-weight:1000!important;
  border-radius:9px!important;
  padding:7px 10px!important;
}
@media(max-width:760px){
  .detail-action-row-fixed,
  .detail-action-row{grid-template-columns:1fr!important}
  .cart-color-group{grid-template-columns:58px 1fr}
  .cart-color-img{width:58px!important;height:58px!important}
  .cart-group-line{grid-template-columns:1fr auto;align-items:start}
  .cart-group-line strong,.cart-group-line .cart-remove-btn{grid-column:2}
}


/* === PATCH: pesan stok dekat QTY + qty mentok === */
.inline-stock-warning{
  display:none;
  color:#e1252f;
  font-size:12px;
  font-weight:1000;
  line-height:1.25;
  margin-top:5px;
}
.inline-stock-warning.show{
  display:block;
}
.detail-qty-final .inline-stock-warning{
  width:100%;
  letter-spacing:0;
  text-transform:none;
}
.cart-step-wrap{
  display:grid;
  justify-items:center;
  gap:4px;
}
.cart-stock-warning{
  text-align:center;
  max-width:115px;
}


/* === PATCH BARANG KELUAR: pesan stok dekat input cell === */
#outBulkGrid .size-cell{
  position:relative;
}
#outBulkGrid .out-stock-warning{
  display:none;
  color:#e1252f;
  font-size:12px;
  font-weight:1000;
  line-height:1.25;
  margin-top:6px;
  text-align:center;
}
#outBulkGrid .out-stock-warning.show{
  display:block;
}
#outBulkGrid .size-cell input:focus{
  border-color:#1268d6!important;
}


/* === PATCH TRANSAKSI: pesan stok dekat QTY === */
#bulkSaleGrid .size-cell{position:relative}
#bulkSaleGrid .trans-stock-warning{
  display:none;
  color:#e1252f;
  font-size:12px;
  font-weight:1000;
  line-height:1.25;
  margin-top:6px;
  text-align:center;
}
#bulkSaleGrid .trans-stock-warning.show{display:block}
.sale-qty-cell{
  min-width:120px;
}
.sale-stepper{
  display:inline-flex;
  align-items:center;
  border:1px solid #dbe7f8;
  border-radius:10px;
  overflow:hidden;
  background:#fff;
}
.sale-stepper button{
  width:30px;
  height:30px;
  border:0;
  background:#eef5ff;
  color:#13498f;
  font-weight:1000;
  font-size:18px;
}
.sale-stepper span{
  min-width:36px;
  text-align:center;
  font-weight:1000;
}
.sale-stock-warning{
  display:none;
  color:#e1252f;
  font-size:11px;
  font-weight:1000;
  margin-top:4px;
}
.sale-stock-warning.show{display:block}


/* === REVISI BESAR BARANG KELUAR === */
.out-history-card .row-actions.compact{
  margin:10px 16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.invoice-box .invoice-title{
  text-transform:uppercase;
}


/* === PATCH: Riwayat Barang Keluar di menu Riwayat === */
.out-riwayat-panel{
  margin-top:18px;
}
.out-riwayat-panel .row-actions.compact{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:10px 0 14px;
}
.out-riwayat-table th,
.out-riwayat-table td{
  white-space:nowrap;
}
.out-riwayat-table .btn.mini{
  padding:7px 10px!important;
  font-size:12px!important;
  border-radius:9px!important;
}


/* === PATCH: tampilan preview kosong setelah print === */
.preview-empty-after-print{
  min-height:360px;
  display:grid;
  place-items:center;
  text-align:center;
  color:#5e6f88;
  border:2px dashed #d9e5f5;
  border-radius:22px;
  background:#f8fbff;
  padding:40px;
}
.preview-empty-after-print h2{
  margin:0 0 8px;
  color:#0b4f96;
}
.preview-empty-after-print p{
  margin:0;
  font-size:15px;
}


/* === PATCH PROMO: size checklist + preview pojok kanan bawah === */
.promo-size-checklist{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:10px;
  border:1px solid #dbe7f8;
  border-radius:16px;
  background:#f8fbff;
  min-height:58px;
  align-items:center;
}
.promo-size-check{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:9px 12px;
  border:1px solid #d7e5f8;
  border-radius:999px;
  background:#fff;
  font-weight:900;
  color:#15345b;
  cursor:pointer;
  user-select:none;
}
.promo-size-check.checked{
  border-color:#0b68d1;
  background:#eaf4ff;
  color:#0b4f96;
}
.promo-size-check input{
  width:16px;
  height:16px;
}
.promo-list-card{
  position:relative;
  padding-right:150px!important;
}
.promo-on{color:#0a9b50;font-weight:1000}
.promo-off{color:#e1252f;font-weight:1000}
.promo-card-actions{
  position:absolute;
  right:12px;
  top:12px;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.promo-card-actions .btn.mini{
  padding:7px 9px!important;
  font-size:12px!important;
  border-radius:9px!important;
}
.promo-corner-preview{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:9998;
  width:330px;
  max-width:calc(100vw - 44px);
  background:#082b58;
  color:#fff;
  border-radius:22px;
  box-shadow:0 18px 40px rgba(0,0,0,.22);
  padding:16px;
  border:1px solid rgba(255,255,255,.18);
}
.promo-corner-preview.hidden{display:none}
.promo-corner-title{
  font-weight:1000;
  font-size:17px;
  margin-bottom:9px;
  color:#ffd34a;
}
.promo-corner-item{
  background:rgba(255,255,255,.09);
  border-radius:14px;
  padding:10px;
  margin-top:8px;
  line-height:1.35;
}
.promo-corner-item b{
  color:#fff;
}
.promo-corner-item span{
  color:#d9e8ff;
}
.promo-corner-item small{
  color:#ffd34a;
  font-weight:900;
}
.promo-corner-more{
  margin-top:9px;
  color:#d9e8ff;
  font-size:13px;
  font-weight:900;
}
@media(max-width:760px){
  .promo-card-actions{position:static;margin-top:10px;justify-content:flex-start}
  .promo-list-card{padding-right:14px!important}
  .promo-corner-preview{left:14px;right:14px;bottom:14px;width:auto}
}


/* === PATCH RIWAYAT: satu tombol Export Data Excel === */
#exportHistBtn.btn.green{
  background:#13a85a!important;
  color:#fff!important;
  font-weight:1000!important;
}
#exportOutHistoryExcelBtn{
  display:none!important;
}


/* === PATCH: tombol X preview dari riwayat === */
#page-preview.history-preview-mode{
  position:relative;
}
.history-preview-close{
  position:absolute;
  top:18px;
  right:20px;
  z-index:50;
  width:44px;
  height:44px;
  border:0;
  border-radius:999px;
  background:#ef3340;
  color:#fff;
  font-size:28px;
  line-height:1;
  font-weight:1000;
  cursor:pointer;
  box-shadow:0 10px 25px rgba(0,0,0,.18);
}
.history-preview-close:hover{
  transform:scale(1.04);
}


/* === PATCH PREVIEW: BATAL + PRINT TERMAL === */
.preview-action-bar{
  display:flex;
  gap:12px;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  margin:18px auto 0;
}
.preview-action-bar .btn{
  min-width:170px;
  min-height:54px;
  border-radius:16px;
  font-size:16px;
  font-weight:1000;
}
.btn.orange{
  background:#ff8a00!important;
  color:#fff!important;
}
.btn.soft-red{
  background:#ffecee!important;
  color:#c9333a!important;
  border:1px solid #ffc8ce!important;
}
.thermal-modal-box{
  max-width:520px!important;
}
.thermal-paper-select{
  display:block;
  font-weight:900;
  margin-bottom:12px;
}
.thermal-paper-select select{
  margin-top:6px;
}
.thermal-receipt{
  white-space:pre-wrap;
  font-family:"Courier New",monospace;
  font-size:12px;
  line-height:1.25;
  background:#fff;
  color:#000;
  border:1px solid #ddd;
  padding:12px;
  border-radius:12px;
  width:58mm;
  max-width:100%;
  min-height:300px;
  margin:0 auto 14px;
}
.thermal-80 .thermal-receipt{
  width:80mm;
}
.thermal-actions,
.cancel-preview-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}
.thermal-actions .btn,
.cancel-preview-actions .btn{
  min-width:135px;
  min-height:48px;
}
@media(max-width:760px){
  .preview-action-bar{
    display:grid;
    grid-template-columns:1fr;
    padding:0 12px;
  }
  .preview-action-bar .btn{
    width:100%;
    min-width:0;
  }
}
@media print{
  body.thermal-printing *{
    visibility:hidden!important;
  }
  body.thermal-printing #thermalReceiptPrintArea,
  body.thermal-printing #thermalReceiptPrintArea *{
    visibility:visible!important;
  }
  body.thermal-printing #thermalReceiptPrintArea{
    position:absolute!important;
    left:0!important;
    top:0!important;
    width:58mm!important;
    max-width:58mm!important;
    min-height:0!important;
    margin:0!important;
    padding:2mm!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    font-family:"Courier New",monospace!important;
    font-size:10px!important;
    line-height:1.22!important;
    background:#fff!important;
    color:#000!important;
    white-space:pre-wrap!important;
  }
  body.thermal-printing.thermal-80 #thermalReceiptPrintArea{
    width:80mm!important;
    max-width:80mm!important;
  }
}


/* === PATCH UI PREVIEW: invoice layar besar, tajam untuk screenshot === */
@media screen{
  #page-preview .preview-area{
    width:100%!important;
    min-height:100vh!important;
    padding:24px 20px 90px!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:flex-start!important;
    text-align:center!important;
    box-sizing:border-box!important;
  }
  #page-preview .preview-area .invoice-box{
    width:95%!important;
    max-width:1220px!important;
    min-height:auto!important;
    margin:0 auto!important;
    padding:34px 42px 56px!important;
    transform:none!important;
    zoom:1!important;
    overflow:visible!important;
    border-radius:18px!important;
    box-shadow:0 18px 46px rgba(17,38,76,.10)!important;
    -webkit-font-smoothing:antialiased!important;
    text-rendering:geometricPrecision!important;
  }
  #page-preview .invoice-box .inv-logo{
    max-width:110px!important;
    max-height:60px!important;
  }
  #page-preview .invoice-box .inv-brand-sub{
    font-size:11px!important;
    letter-spacing:.03em!important;
  }
  #page-preview .invoice-box .inv-mode{
    font-size:14px!important;
  }
  #page-preview .invoice-box h2.invoice-title,
  #page-preview .invoice-box .invoice-title{
    font-size:22px!important;
    letter-spacing:.34em!important;
    margin:22px 0 18px!important;
  }
  #page-preview .invoice-box .meta-compact{
    font-size:12px!important;
    gap:8px 26px!important;
    margin-bottom:14px!important;
  }
  #page-preview .invoice-box .meta-compact b{
    font-size:13px!important;
  }
  #page-preview .invoice-box h3{
    font-size:16px!important;
    margin:18px 0 10px!important;
  }
  #page-preview .invoice-box table{
    width:100%!important;
    table-layout:fixed!important;
    border-collapse:collapse!important;
    font-size:12px!important;
  }
  #page-preview .invoice-box th,
  #page-preview .invoice-box td{
    font-size:12px!important;
    line-height:1.35!important;
    padding:9px 10px!important;
    word-break:break-word!important;
  }
  #page-preview .invoice-box .inv-total{
    width:min(420px,50%)!important;
    margin-top:18px!important;
    gap:8px!important;
  }
  #page-preview .invoice-box .inv-total div{
    font-size:13px!important;
    padding:10px 12px!important;
    border-radius:9px!important;
  }
  #page-preview .invoice-box .bank-line{
    font-size:11px!important;
    line-height:1.55!important;
  }
  #page-preview .invoice-box .invoice-note{
    font-size:12px!important;
    line-height:1.55!important;
    font-weight:700!important;
    color:#2c3444!important;
  }
  #page-preview .invoice-box .inv-made-by{
    font-size:10px!important;
    right:22px!important;
    bottom:18px!important;
  }
  #page-preview .preview-action-bar{
    margin-top:28px!important;
    margin-bottom:14px!important;
  }
  #page-preview .hint{
    margin-top:10px!important;
  }
  #exitScreenshotModeBtn{
    display:none!important;
  }
  .btn.purple{
    background:#6338d8!important;
    color:#fff!important;
  }
}

/* MODE SCREENSHOT */
@media screen{
  body.okaku-screenshot-mode{
    overflow:auto!important;
    background:#eaf1f8!important;
  }
  body.okaku-screenshot-mode .sidebar{
    display:none!important;
  }
  body.okaku-screenshot-mode .admin-app{
    display:block!important;
    grid-template-columns:none!important;
  }
  body.okaku-screenshot-mode .admin-main{
    width:100vw!important;
    max-width:none!important;
    margin:0!important;
    padding:18px!important;
  }
  body.okaku-screenshot-mode .admin-page{
    display:none!important;
  }
  body.okaku-screenshot-mode #page-preview{
    display:block!important;
    width:100%!important;
  }
  body.okaku-screenshot-mode #page-preview .preview-area{
    width:100vw!important;
    min-height:100vh!important;
    padding:22px 16px 90px!important;
  }
  body.okaku-screenshot-mode #page-preview .invoice-box{
    width:96vw!important;
    max-width:1280px!important;
    padding:38px 46px 62px!important;
    margin:0 auto!important;
  }
  body.okaku-screenshot-mode #page-preview .hint{
    display:none!important;
  }
  body.okaku-screenshot-mode #cancelInvoicePreviewBtn,
  body.okaku-screenshot-mode #thermalPrintBtn,
  body.okaku-screenshot-mode #screenshotModeBtn{
    display:none!important;
  }
  body.okaku-screenshot-mode #exitScreenshotModeBtn{
    display:inline-flex!important;
  }
}

/* RESPONSIVE HP */
@media screen and (max-width:760px){
  #page-preview .preview-area{
    padding:12px 8px 80px!important;
  }
  #page-preview .preview-area .invoice-box{
    width:100%!important;
    max-width:100%!important;
    padding:18px 14px 34px!important;
    border-radius:14px!important;
  }
  #page-preview .invoice-box h2.invoice-title,
  #page-preview .invoice-box .invoice-title{
    font-size:17px!important;
    letter-spacing:.24em!important;
  }
  #page-preview .invoice-box .meta-compact{
    grid-template-columns:1fr!important;
    font-size:11px!important;
  }
  #page-preview .invoice-box th,
  #page-preview .invoice-box td{
    font-size:10px!important;
    padding:7px 5px!important;
  }
  #page-preview .invoice-box .inv-total{
    width:100%!important;
  }
  body.okaku-screenshot-mode #page-preview .invoice-box{
    width:100%!important;
    padding:18px 14px 34px!important;
  }
}


/* === PATCH UI PREVIEW: tombol screenshot atas + teks invoice lebih jelas === */
@media screen{
  #screenshotModeBtn.screenshot-toggle-btn{
    position:fixed!important;
    top:16px!important;
    right:20px!important;
    z-index:9999!important;
    min-width:auto!important;
    min-height:auto!important;
    width:auto!important;
    padding:11px 17px!important;
    border-radius:13px!important;
    font-size:13px!important;
    line-height:1!important;
    font-weight:1000!important;
    box-shadow:0 10px 25px rgba(0,0,0,.16)!important;
  }
  #previewActionBar #screenshotModeBtn.screenshot-toggle-btn{
    margin:0!important;
  }
  #exitScreenshotModeBtn{
    display:none!important;
  }
  body.okaku-screenshot-mode #screenshotModeBtn.screenshot-toggle-btn{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    background:#ef3340!important;
    color:#fff!important;
  }
  body.okaku-screenshot-mode #exitScreenshotModeBtn{
    display:none!important;
  }

  /* Perbesar teks layar saja, print/PDF tidak disentuh */
  #page-preview .invoice-box{
    font-size:14px!important;
    line-height:1.45!important;
  }
  #page-preview .invoice-box h2.invoice-title,
  #page-preview .invoice-box .invoice-title{
    font-size:27px!important;
    letter-spacing:.36em!important;
    font-weight:1000!important;
  }
  #page-preview .invoice-box .meta-compact{
    font-size:14px!important;
    line-height:1.45!important;
  }
  #page-preview .invoice-box .meta-compact b{
    font-size:14px!important;
  }
  #page-preview .invoice-box h3{
    font-size:18px!important;
    line-height:1.35!important;
  }
  #page-preview .invoice-box table{
    font-size:14px!important;
  }
  #page-preview .invoice-box th{
    font-size:14px!important;
    font-weight:1000!important;
    line-height:1.35!important;
  }
  #page-preview .invoice-box td{
    font-size:14px!important;
    line-height:1.38!important;
  }
  #page-preview .invoice-box .inv-total div{
    font-size:15px!important;
    line-height:1.35!important;
  }
  #page-preview .invoice-box .bank-line{
    font-size:13px!important;
    line-height:1.6!important;
  }
  #page-preview .invoice-box .invoice-note{
    font-size:13px!important;
    line-height:1.6!important;
  }
  #page-preview .invoice-box .inv-mode{
    font-size:15px!important;
  }
  #page-preview .invoice-box .inv-brand-sub{
    font-size:12px!important;
  }
}

@media screen and (max-width:760px){
  #screenshotModeBtn.screenshot-toggle-btn{
    top:10px!important;
    right:10px!important;
    padding:10px 12px!important;
    font-size:12px!important;
  }
  #page-preview .invoice-box th,
  #page-preview .invoice-box td{
    font-size:11.5px!important;
  }
  #page-preview .invoice-box .meta-compact,
  #page-preview .invoice-box .invoice-note,
  #page-preview .invoice-box .bank-line{
    font-size:11.5px!important;
  }
}


/* === PATCH PROMO: edit list + preview produk bawah === */
#promoCornerPreview{
  display:none!important;
}
.promo-list-card.editing{
  border:2px solid #0b69d1!important;
  background:#eef7ff!important;
}
#cancelEditPromoBtn{
  margin-left:8px;
}
.promo-product-preview-block{
  margin-top:18px;
  border:1px solid #dbe7f8;
  border-radius:20px;
  background:#f8fbff;
  padding:18px;
}
.promo-preview-title{
  margin:0 0 14px;
  color:#082b58;
  font-size:20px;
  font-weight:1000;
}
.promo-product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;
}
.promo-product-card{
  background:#fff;
  border:1px solid #dbe7f8;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 20px rgba(21,49,91,.06);
}
.promo-product-img{
  height:160px;
  background:#eef4fb;
  display:grid;
  place-items:center;
  color:#0b4f96;
  font-weight:1000;
}
.promo-product-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.promo-product-info{
  padding:14px;
}
.promo-product-info b{
  display:block;
  color:#082b58;
  font-size:16px;
  margin:6px 0 4px;
}
.promo-product-info small{
  display:block;
  color:#64748b;
  line-height:1.35;
  margin-bottom:8px;
}
.promo-badge-small{
  display:inline-flex;
  background:#ff8a00;
  color:#fff;
  font-size:11px;
  font-weight:1000;
  border-radius:999px;
  padding:5px 8px;
}
.promo-price-line{
  font-size:14px;
  color:#1d2e57;
  margin-top:4px;
}
.promo-price-line b{
  display:inline;
  color:#0b69d1;
  font-size:14px;
}
.promo-product-info em{
  display:block;
  margin-top:8px;
  font-size:12px;
  color:#7a8699;
}
@media(max-width:760px){
  .promo-product-grid{
    grid-template-columns:1fr;
  }
}


/* === OKAKU ONLINE DATABASE SETTING === */
.gs-db-panel label{
  display:block;
  margin-bottom:14px;
}
.gs-db-panel input{
  width:100%;
}
.gs-db-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:12px 0;
}
.gs-db-actions .btn{
  min-height:48px;
}
.gs-db-status.good{
  background:#ecfff4!important;
  color:#087c3a!important;
  border-color:#b8f2cf!important;
}
.gs-db-status.bad{
  background:#fff2f2!important;
  color:#b4232a!important;
  border-color:#ffd1d1!important;
}
@media(max-width:760px){
  .gs-db-actions{
    display:grid;
    grid-template-columns:1fr;
  }
}


/* === BARANG MASUK: Import Excel === */
.import-excel-box{
  margin:14px 0 16px;
  padding:16px;
  border:1px solid #dbe7f8;
  border-radius:18px;
  background:#f8fbff;
}
.import-excel-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.import-excel-head h3{
  margin:0 0 4px;
  color:#082b58;
  font-size:18px;
  font-weight:1000;
}
.import-excel-head p{
  margin:0;
  color:#526177;
}
.import-excel-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.import-excel-actions.bottom{
  margin-top:14px;
}
.import-preview{
  margin-top:14px;
  background:#fff;
  border:1px solid #dbe7f8;
  border-radius:16px;
  padding:14px;
}
.import-summary{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:12px;
}
.import-summary b{
  color:#082b58;
  font-size:17px;
}
.import-summary span{
  display:inline-flex;
  background:#edf6ff;
  color:#0b4f96;
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
}
.import-error{
  background:#fff0f0;
  color:#b4232a;
  border:1px solid #ffd1d1;
  border-radius:12px;
  padding:10px 12px;
  margin-bottom:12px;
  font-weight:900;
}
.import-table-wrap{
  max-height:390px;
  overflow:auto;
}
.import-table th,
.import-table td{
  font-size:12px;
  white-space:nowrap;
}
.import-table tr.bad td{
  background:#fff5f5;
  color:#a10000;
}
@media(max-width:760px){
  .import-excel-actions,
  .import-excel-actions .btn{
    width:100%;
  }
}


/* === PATCH MOBILE MARKETPLACE UX: katalog 2 kolom, cart bottom sheet, modal rapi === */
@media screen and (max-width:760px){
  html,body{
    width:100%;
    overflow-x:hidden!important;
  }
  body{
    padding-bottom:78px!important;
    background:#eef4fb!important;
  }

  /* Header marketplace ala mobile app */
  .customer-page{
    padding:0 0 92px!important;
  }
  .main-header{
    position:sticky!important;
    top:0!important;
    z-index:980!important;
    display:grid!important;
    grid-template-columns:74px 1fr!important;
    gap:10px!important;
    align-items:center!important;
    padding:12px 12px 14px!important;
    background:#fff!important;
    border-radius:0 0 24px 24px!important;
    box-shadow:0 8px 24px rgba(11,31,66,.08)!important;
    height:auto!important;
  }
  .main-logo{
    width:74px!important;
    height:74px!important;
    object-fit:contain!important;
    grid-row:1/3!important;
  }
  .cat-wrap,
  .promo-btn,
  #cartToggleBtn{
    display:none!important;
  }
  .search-box{
    grid-column:2/3!important;
    grid-row:1/2!important;
    min-height:48px!important;
    height:48px!important;
    padding:0 14px!important;
    border-radius:999px!important;
    box-shadow:none!important;
  }
  .search-box input{
    font-size:15px!important;
    min-width:0!important;
  }
  #agentLoginBtn{
    grid-column:1/2!important;
    grid-row:3/4!important;
    min-height:54px!important;
    padding:8px 6px!important;
    border-radius:20px!important;
    font-size:14px!important;
    line-height:1.15!important;
    white-space:normal!important;
  }
  #adminLoginBtn{
    grid-column:2/3!important;
    grid-row:2/4!important;
    min-height:54px!important;
    border-radius:18px!important;
    font-size:14px!important;
    letter-spacing:.10em!important;
  }

  .hero,
  .shop-filters,
  .section-head,
  .product-tools,
  .material-filters{
    margin-left:10px!important;
    margin-right:10px!important;
  }
  .hero{
    display:none!important;
  }
  .shop-filters{
    gap:8px!important;
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    padding:10px 2px 6px!important;
    margin-bottom:8px!important;
  }
  .shop-filters button{
    flex:0 0 auto!important;
    padding:9px 14px!important;
    font-size:13px!important;
  }
  .section-head h3{
    font-size:18px!important;
    margin:10px 0 6px!important;
  }

  /* Produk: 2 kolom compact seperti marketplace */
  .shop-layout,
  .shop-layout.cart-hidden{
    display:block!important;
    padding:0 10px 96px!important;
    max-width:100%!important;
  }
  .product-grid,
  .shop-layout.cart-hidden .product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
    align-items:start!important;
  }
  .product-card{
    border-radius:16px!important;
    overflow:hidden!important;
    box-shadow:0 6px 18px rgba(17,38,76,.08)!important;
  }
  .product-card .media{
    aspect-ratio:1/1!important;
    height:auto!important;
    min-height:0!important;
  }
  .product-card .body{
    padding:10px 10px 12px!important;
    min-height:160px!important;
  }
  .product-card h4{
    font-size:15px!important;
    line-height:1.15!important;
    margin:0 0 7px!important;
    min-height:34px!important;
    display:-webkit-box!important;
    -webkit-line-clamp:2!important;
    -webkit-box-orient:vertical!important;
    overflow:hidden!important;
  }
  .material-badge,
  .product-card .body .material-badge{
    font-size:10px!important;
    padding:5px 8px!important;
    border-radius:8px!important;
    max-width:100%!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }
  .price-main{
    font-size:18px!important;
    line-height:1.1!important;
    margin-top:6px!important;
  }
  .agent-note{
    font-size:11px!important;
    line-height:1.25!important;
    margin:4px 0 8px!important;
  }
  .product-card .btn{
    min-height:40px!important;
    border-radius:12px!important;
    font-size:12px!important;
    padding:10px 8px!important;
  }
  .stock-pill{
    right:8px!important;
    bottom:8px!important;
    padding:5px 8px!important;
    font-size:11px!important;
  }
  .placeholder{
    font-size:15px!important;
    border-radius:14px!important;
    padding:12px!important;
  }

  /* Keranjang mobile: bottom sheet, bukan turun jauh di bawah produk */
  .shop-layout.cart-hidden #cartPanel,
  #cartPanel.cart-hidden-panel,
  #cartPanel{
    display:block!important;
  }
  #cartPanel.cart-panel{
    position:fixed!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    top:auto!important;
    width:100%!important;
    max-width:100%!important;
    max-height:82vh!important;
    z-index:1600!important;
    margin:0!important;
    border-radius:24px 24px 0 0!important;
    border:1px solid #d7e7f7!important;
    box-shadow:0 -18px 40px rgba(8,27,65,.22)!important;
    transform:translateY(calc(100% - 68px))!important;
    transition:transform .25s ease!important;
    overflow:hidden!important;
    background:#fff!important;
  }
  body.mobile-cart-open #cartPanel,
  #cartPanel.mobile-open{
    transform:translateY(0)!important;
  }
  #cartPanel .cart-head{
    height:68px!important;
    min-height:68px!important;
    padding:14px 16px!important;
    border-radius:24px 24px 0 0!important;
    font-size:18px!important;
    cursor:pointer!important;
  }
  #cartPanel .cart-title{
    font-size:18px!important;
    line-height:1.1!important;
  }
  #cartPanel #cartCount{
    width:36px!important;
    height:36px!important;
    min-width:36px!important;
    font-size:16px!important;
    margin-left:6px!important;
  }
  #cartMinimizeBtn,.cart-minimize{
    width:36px!important;
    height:36px!important;
    font-size:23px!important;
  }
  #cartPanel:not(.mobile-open) .cart-items,
  #cartPanel:not(.mobile-open) .cart-total,
  #cartPanel:not(.mobile-open) #buyCartBtn,
  #cartPanel:not(.mobile-open) #copyCartBtn,
  #cartPanel:not(.mobile-open) .cart-trust{
    display:none!important;
  }
  #cartPanel .cart-items{
    max-height:45vh!important;
    overflow:auto!important;
    padding:12px 14px!important;
  }
  .cart-item{
    grid-template-columns:52px 1fr auto!important;
    gap:10px!important;
  }
  .cart-item img,.mini-img{
    width:52px!important;
    height:52px!important;
  }
  .cart-total{
    padding:12px 16px!important;
  }
  .cart-total strong{
    font-size:22px!important;
  }
  #buyCartBtn,#copyCartBtn{
    margin:8px 14px!important;
    width:calc(100% - 28px)!important;
    min-height:46px!important;
    border-radius:14px!important;
  }

  /* Cek stok floating tidak menutupi produk/keranjang */
  .public-stock-widget{
    right:10px!important;
    bottom:82px!important;
    z-index:1450!important;
  }
  body.mobile-cart-open .public-stock-widget{
    display:none!important;
  }
  .public-stock-toggle{
    padding:11px 14px!important;
    font-size:14px!important;
    box-shadow:0 8px 22px rgba(0,0,0,.18)!important;
  }
  .public-stock-choice{
    right:0!important;
    bottom:56px!important;
    width:min(300px,calc(100vw - 22px))!important;
  }

  /* Modal: bottom sheet mobile, gampang ditutup, tidak muncul di bawah halaman */
  .modal{
    position:fixed!important;
    inset:0!important;
    z-index:2200!important;
    display:grid!important;
    place-items:end center!important;
    padding:0!important;
    background:rgba(4,17,38,.45)!important;
    overflow:hidden!important;
  }
  .modal.hidden{
    display:none!important;
  }
  .modal .modal-box,
  .modal .modal-box.large,
  .modal .modal-box.small,
  .public-stock-modal-box{
    width:100%!important;
    max-width:100%!important;
    max-height:92vh!important;
    margin:0!important;
    border-radius:24px 24px 0 0!important;
    overflow:auto!important;
    padding:18px 14px 22px!important;
    box-sizing:border-box!important;
  }
  .modal .close{
    position:sticky!important;
    top:0!important;
    margin-left:auto!important;
    z-index:5!important;
    width:42px!important;
    height:42px!important;
    display:grid!important;
    place-items:center!important;
    background:#fff!important;
    box-shadow:0 6px 18px rgba(0,0,0,.12)!important;
  }
  .public-stock-modal-box .bar-title{
    font-size:21px!important;
    line-height:1.25!important;
    margin-right:48px!important;
  }
  .public-stock-modal-box .form-grid,
  .public-stock-modal-box .form-grid.four{
    grid-template-columns:1fr!important;
  }
  .answer-box{
    min-height:150px!important;
  }

  /* Preview invoice mobile: tetap table, tidak pecah kecil-kecil */
  #page-preview .preview-area{
    padding:12px 8px 90px!important;
  }
  #page-preview .preview-area .invoice-box{
    width:100%!important;
    max-width:100%!important;
    padding:18px 12px 34px!important;
    overflow-x:auto!important;
    border-radius:14px!important;
  }
  #page-preview .invoice-box table{
    min-width:620px!important;
    table-layout:auto!important;
  }
  #page-preview .invoice-box th,
  #page-preview .invoice-box td{
    font-size:11px!important;
    line-height:1.3!important;
    padding:7px 6px!important;
    word-break:normal!important;
  }
  #page-preview .invoice-box .invoice-title{
    font-size:21px!important;
    letter-spacing:.26em!important;
  }
  #page-preview .invoice-box .inv-total{
    width:100%!important;
  }
}


/* === PATCH SECURITY SETTING + WARNA AUTOCOMPLETE === */
.side-nav button.locked,
.side-nav button[data-page="setting"].locked{
  display:none!important;
}
.admin-unsaved-warning{
  background:#fff7dc!important;
  border-color:#ffd25b!important;
  color:#7a5200!important;
}
#saveAdminSetBtn.needs-save{
  background:#ff8a00!important;
  color:#fff!important;
  box-shadow:0 10px 24px rgba(255,138,0,.25)!important;
}
.warna-autocomplete-input{
  width:100%!important;
  min-height:48px!important;
  border:1px solid #d6e4f7!important;
  border-radius:14px!important;
  background:#f8fbff!important;
  color:#062855!important;
  font-weight:900!important;
  padding:12px 14px!important;
  box-sizing:border-box!important;
}
.warna-autocomplete-input:focus{
  outline:none!important;
  border-color:#1268d6!important;
  background:#fff!important;
  box-shadow:0 0 0 4px rgba(18,104,214,.12)!important;
}
label .warna-autocomplete-input + select.legacy-hidden-select,
select.legacy-hidden-select{
  display:none!important;
}
.admin-manage-card input[data-af="pin"]{
  border-color:#ffbf47!important;
  background:#fffaf0!important;
}
.admin-manage-card input[data-af="pin"]:focus{
  border-color:#ff8a00!important;
  box-shadow:0 0 0 4px rgba(255,138,0,.14)!important;
}


/* === MOBILE ADMIN POS: dashboard menu dulu + back button === */
.mobile-admin-topbar{
  display:none;
}
@media screen and (max-width:760px){
  #adminApp.admin-app{
    display:block!important;
    min-height:100vh!important;
    background:#eef4fb!important;
  }
  #adminApp.hidden{
    display:none!important;
  }

  /* Dashboard admin mobile */
  #adminApp .sidebar{
    position:relative!important;
    width:100%!important;
    min-height:100vh!important;
    height:auto!important;
    padding:18px 14px 28px!important;
    border-radius:0!important;
    background:linear-gradient(180deg,#092b5e,#061a3b)!important;
  }
  #adminApp .brand-block{
    display:block!important;
    padding:18px!important;
    border-radius:22px!important;
    background:rgba(255,255,255,.10)!important;
    margin-bottom:14px!important;
  }
  #adminApp .brand-block b{
    font-size:26px!important;
  }
  #adminApp .sync{
    width:100%!important;
    height:48px!important;
    border-radius:16px!important;
    margin:0 0 14px!important;
  }
  #adminApp .admin-card,
  #adminApp .bonus-card{
    border-radius:22px!important;
    padding:18px!important;
    margin-bottom:14px!important;
  }
  #adminApp .side-nav{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:12px!important;
    margin-top:16px!important;
  }
  #adminApp .side-nav button{
    min-height:86px!important;
    border-radius:22px!important;
    padding:14px 10px!important;
    font-size:14px!important;
    line-height:1.2!important;
    text-align:center!important;
    justify-content:center!important;
    background:rgba(255,255,255,.12)!important;
    color:#fff!important;
    border:1px solid rgba(255,255,255,.18)!important;
    box-shadow:0 10px 25px rgba(0,0,0,.12)!important;
  }
  #adminApp .side-nav button.active{
    background:#ffcc26!important;
    color:#062855!important;
  }
  #adminApp .side-nav button.locked{
    display:none!important;
  }

  /* Isi menu disembunyikan saat dashboard */
  #adminApp.mobile-dashboard .admin-main{
    display:none!important;
  }
  #adminApp.mobile-page-open .sidebar{
    display:none!important;
  }
  #adminApp.mobile-page-open .admin-main{
    display:block!important;
    padding:0 10px 90px!important;
    min-height:100vh!important;
    background:#eef4fb!important;
  }

  .mobile-admin-topbar{
    display:flex!important;
    position:sticky!important;
    top:0!important;
    z-index:950!important;
    align-items:center!important;
    gap:10px!important;
    padding:12px 6px 10px!important;
    background:#eef4fb!important;
  }
  .mobile-admin-topbar button{
    border:0!important;
    background:#0b69d1!important;
    color:#fff!important;
    font-weight:1000!important;
    border-radius:999px!important;
    padding:11px 14px!important;
    box-shadow:0 8px 20px rgba(11,105,209,.22)!important;
  }
  .mobile-admin-topbar b{
    flex:1!important;
    text-align:right!important;
    color:#062855!important;
    letter-spacing:.08em!important;
    font-size:15px!important;
  }
  #adminApp.mobile-page-open .admin-page{
    display:none!important;
  }
  #adminApp.mobile-page-open .admin-page.active{
    display:block!important;
  }
  #adminApp.mobile-page-open .panel{
    border-radius:18px!important;
    padding:16px!important;
    margin:10px 0!important;
  }
  #adminApp.mobile-page-open .bar-title{
    font-size:21px!important;
    line-height:1.2!important;
  }
  #adminApp.mobile-page-open .table-wrap{
    overflow-x:auto!important;
  }
  #adminApp.mobile-page-open table{
    min-width:680px!important;
  }
}


/* === WARNA AUTOCOMPLETE PREFIX MODE === */
.warna-autocomplete-input.prefix-mode{
  background:#fff!important;
  border-color:#bcd5f3!important;
}
.warna-autocomplete-input.prefix-mode::placeholder{
  color:#8a97aa!important;
  font-weight:700!important;
}


/* === CASCADING SELECT INFO === */
.cascade-note{
  font-size:12px;
  color:#65718b;
}

/* === Warna kosong setelah produk/jenis berubah === */
.warna-autocomplete-input.prefix-mode:placeholder-shown{
  color:#8a97aa!important;
}


/* === Warna benar-benar kosong, select asli disembunyikan === */
.force-hidden-warna-select,
#bulkWarna,#inWarna,#outWarna,#setImgWarna,#setPromoWarna,#descTplWarna{
  display:none!important;
}
.warna-autocomplete-input.direct-blank-warna{
  display:block!important;
  width:100%!important;
  min-height:58px!important;
  background:#fff!important;
  color:#062855!important;
  font-weight:900!important;
}
.warna-autocomplete-input.direct-blank-warna::placeholder{
  color:transparent!important;
}


/* === Single input warna, tidak ada kotak dobel === */
input.single-warna-input{
  display:block!important;
  width:100%!important;
  min-height:58px!important;
  border:1px solid #cfe0f5!important;
  border-radius:16px!important;
  background:#fff!important;
  color:#062855!important;
  font-weight:900!important;
  padding:14px 16px!important;
  box-sizing:border-box!important;
}
select.force-hidden-warna-select,
#bulkWarna,#inWarna,#outWarna,#setImgWarna,#setPromoWarna,#descTplWarna{
  display:none!important;
  visibility:hidden!important;
  width:0!important;
  height:0!important;
  position:absolute!important;
  pointer-events:none!important;
}


/* === Stable warna input: value pilihan tetap terlihat === */
input.stable-warna-input{
  display:block!important;
  width:100%!important;
  min-height:58px!important;
  background:#fff!important;
  border:1px solid #c7dcf5!important;
  border-radius:16px!important;
  color:#062855!important;
  font-weight:900!important;
}
