:root{
  --bt-red:#e60012;
  --bt-red-dark:#b9000d;
  --bt-red-soft:#fff1f2;
  --bt-black:#101828;
  --bt-text:#1f2937;
  --bt-muted:#667085;
  --bt-line:#e9edf3;
  --bt-bg:#f7f8fb;
  --bt-card:#ffffff;
  --bt-success:#12b76a;
  --bt-danger:#f04438;
  --bt-warning:#f79009;
  --bt-blue:#2e90fa;
  --bt-purple:#9b5cff;
  --bt-shadow:0 18px 45px rgba(16,24,40,.07);
  --bt-shadow-soft:0 8px 24px rgba(16,24,40,.055);
  --bt-radius:18px;
}
*{box-sizing:border-box}
html{height:100%}
body{min-height:100%;background:var(--bt-bg);color:var(--bt-text);font-size:14px;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,"Segoe UI",sans-serif;letter-spacing:-.01em}
a{color:var(--bt-red);text-decoration:none}a:hover{color:var(--bt-red-dark)}

/* App Shell */
.bt-app-shell{display:flex;min-height:100vh;background:linear-gradient(180deg,#fff 0,#f7f8fb 35%,#f3f5f9 100%)}
.bt-sidebar{width:296px;min-width:296px;background:#fff;border-right:1px solid var(--bt-line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:40;box-shadow:8px 0 30px rgba(16,24,40,.03)}
.bt-sidebar-brand{height:92px;display:flex;align-items:center;padding:18px 26px;border-bottom:1px solid var(--bt-line)}
.bt-logo{display:flex;align-items:center;gap:12px;color:var(--bt-black)}
.bt-logo img{width:210px;max-height:62px;object-fit:contain;object-position:left center;filter:drop-shadow(0 7px 10px rgba(16,24,40,.06))}
.bt-sidebar-menu{padding:18px 18px 12px;overflow-y:auto;flex:1}.bt-sidebar-menu::-webkit-scrollbar{width:6px}.bt-sidebar-menu::-webkit-scrollbar-thumb{background:#d7dce6;border-radius:999px}
.bt-menu-section{font-size:11px;text-transform:uppercase;font-weight:800;letter-spacing:.08em;color:#98a2b3;margin:16px 10px 7px}.bt-menu-section:first-child{margin-top:0}
.bt-nav-link{height:47px;display:flex;align-items:center;gap:13px;padding:0 14px;margin:5px 0;border-radius:12px;color:#344054;font-weight:650;transition:.18s ease;position:relative;white-space:nowrap}
.bt-nav-link .bt-nav-icon{width:23px;height:23px;display:grid;place-items:center;color:#667085;font-size:18px;transition:.18s ease}
.bt-nav-link:hover{background:#fff4f4;color:var(--bt-red);transform:translateX(2px)}.bt-nav-link:hover .bt-nav-icon{color:var(--bt-red)}
.bt-nav-link.active{color:#fff;background:linear-gradient(135deg,var(--bt-red),#f51b2d);box-shadow:0 12px 25px rgba(230,0,18,.25)}.bt-nav-link.active .bt-nav-icon{color:#fff}.bt-nav-link.active .badge{background:#fff!important;color:var(--bt-red)!important}
.bt-help-card{margin:14px 18px 22px;border:1px solid #fee2e2;border-radius:18px;padding:18px;background:linear-gradient(180deg,#fff,#fff8f8);box-shadow:var(--bt-shadow-soft)}
.bt-help-icon{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;background:#fff1f2;color:var(--bt-red);font-size:25px;margin-bottom:12px}.bt-help-card .btn{height:42px;font-weight:750}
.bt-main{flex:1;min-width:0;display:flex;flex-direction:column}
.bt-topbar{height:86px;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--bt-line);display:flex;align-items:center;gap:22px;padding:0 38px;position:sticky;top:0;z-index:30}
.bt-menu-toggle{width:42px;height:42px;border:0;border-radius:12px;background:#fff;color:var(--bt-black);display:grid;place-items:center;font-size:22px;box-shadow:0 1px 0 var(--bt-line)}
.bt-top-search{width:min(460px,42vw);position:relative}.bt-top-search input{height:52px;border:1px solid #d9dee8;border-radius:14px;padding-left:48px;background:#fff;box-shadow:0 2px 12px rgba(16,24,40,.03)}.bt-top-search i{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#667085;font-size:19px}
.bt-top-actions{margin-left:auto;display:flex;align-items:center;gap:16px}.bt-icon-btn{width:42px;height:42px;border:0;border-radius:50%;background:#fff;color:#344054;display:grid;place-items:center;position:relative;font-size:20px}.bt-icon-btn .bt-count{position:absolute;right:-2px;top:-2px;background:var(--bt-red);color:#fff;border-radius:999px;min-width:18px;height:18px;display:grid;place-items:center;font-size:10px;font-weight:800;border:2px solid #fff}.bt-user{display:flex;align-items:center;gap:12px;border-left:1px solid var(--bt-line);padding-left:18px;color:var(--bt-text)}.bt-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#111827,#475467);color:#fff;display:grid;place-items:center;font-weight:800;overflow:hidden}.bt-avatar img{width:100%;height:100%;object-fit:cover}.bt-user-name{font-weight:800;color:#111827;line-height:1.1}.bt-user-role{font-size:12px;color:#667085}
.bt-content{padding:28px 38px 42px;max-width:1680px;width:100%;margin:0 auto}.bt-page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px}.bt-eyebrow{font-size:14px;color:#667085;margin-bottom:6px}.bt-title{font-size:31px;font-weight:850;color:#111827;margin:0;letter-spacing:-.035em}.bt-title-mark{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;margin-left:8px;border:1px solid var(--bt-line);border-radius:50%;font-size:17px;color:#475467;background:#fff}.bt-page-actions{display:flex;align-items:center;gap:12px}.bt-date-pill{height:48px;border:1px solid #d9dee8;border-radius:12px;padding:0 16px;background:#fff;font-weight:750;display:flex;align-items:center;gap:10px;color:#344054}

/* Cards and common Bootstrap restyle */
.card{border:1px solid var(--bt-line);border-radius:var(--bt-radius);box-shadow:var(--bt-shadow-soft);background:#fff}.card-header{background:#fff;border-bottom:1px solid var(--bt-line);border-top-left-radius:var(--bt-radius)!important;border-top-right-radius:var(--bt-radius)!important;font-weight:800;color:#111827;padding:16px 20px}.card-body{padding:20px}.btn{border-radius:12px;font-weight:750}.btn-primary,.btn-danger{background:var(--bt-red);border-color:var(--bt-red);box-shadow:0 12px 24px rgba(230,0,18,.16)}.btn-primary:hover,.btn-danger:hover{background:var(--bt-red-dark);border-color:var(--bt-red-dark)}.btn-warning{background:var(--bt-red);border-color:var(--bt-red);color:#fff;box-shadow:0 12px 24px rgba(230,0,18,.16)}.btn-warning:hover{background:var(--bt-red-dark);border-color:var(--bt-red-dark);color:#fff}.btn-outline-dark{border-color:#d0d5dd;color:#344054}.btn-outline-dark:hover{background:#111827;color:#fff}.btn-outline-danger{border-color:#ffb4bb;color:var(--bt-red)}.form-control,.form-select{border-radius:12px;border-color:#d9dee8;min-height:42px}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .22rem rgba(230,0,18,.10);border-color:#ff7b86}.table{color:#344054}.table thead th{background:#fbfcfe;color:#667085;font-size:12px;text-transform:none;letter-spacing:0;border-bottom:1px solid var(--bt-line);font-weight:800}.table td,.table th{vertical-align:middle}.badge{border-radius:999px;padding:.45em .65em;font-weight:750}.alert{border:0;border-radius:14px;box-shadow:var(--bt-shadow-soft)}

/* Dashboard */
.bt-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(180px,1fr));gap:18px;margin-bottom:26px}.bt-kpi-card{background:#fff;border:1px solid var(--bt-line);border-radius:18px;padding:22px;box-shadow:var(--bt-shadow-soft);display:flex;align-items:center;gap:18px;min-height:136px;position:relative;overflow:hidden}.bt-kpi-card:after{content:"";position:absolute;right:-50px;top:-55px;width:140px;height:140px;border-radius:50%;background:#fff1f2}.bt-kpi-icon{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:#fff1f2;color:var(--bt-red);font-size:30px;border:1px solid #ffe3e6;position:relative;z-index:1}.bt-kpi-title{font-size:14px;color:#667085;margin-bottom:8px}.bt-kpi-value{font-size:28px;font-weight:900;color:#111827;letter-spacing:-.04em;line-height:1}.bt-kpi-trend{font-size:12px;margin-top:10px;color:#667085}.bt-kpi-trend.up strong{color:var(--bt-success)}.bt-kpi-trend.down strong{color:var(--bt-danger)}
.bt-dashboard-grid{display:grid;grid-template-columns:1.35fr .95fr;gap:22px;margin-bottom:22px}.bt-dashboard-row{display:grid;grid-template-columns:1.1fr .58fr .65fr;gap:22px}.bt-chart-card,.bt-table-card{min-height:340px}.bt-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.bt-card-title{font-size:20px;font-weight:900;color:#111827;margin:0}.bt-card-link{font-size:13px;font-weight:850;color:var(--bt-red)}.bt-mini-select{height:38px;border:1px solid var(--bt-line);border-radius:10px;padding:0 12px;background:#fff;color:#475467;font-weight:650}.bt-chart-wrap{height:260px}.bt-stock-progress{height:7px;background:#eceff4;border-radius:999px;overflow:hidden;min-width:90px}.bt-stock-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--bt-red),#ff3445);border-radius:999px}.bt-order-id{font-weight:850;color:var(--bt-red)}.bt-status{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:850}.bt-status.shipped,.bt-status.delivered,.bt-status.qc_passed{background:#dcfae6;color:#079455}.bt-status.processing,.bt-status.ready_picking,.bt-status.new_order{background:#eaf3ff;color:#1570ef}.bt-status.picked{background:#f4ebff;color:#7a2ee6}.bt-status.packed,.bt-status.ready_shipment{background:#fff4df;color:#dc6803}.bt-status.pending{background:#f2f4f7;color:#667085}.bt-status.cancelled,.bt-status.returned,.bt-status.qc_rejected{background:#fee4e2;color:#d92d20}.bt-donut-area{display:flex;gap:22px;align-items:center}.bt-donut-wrap{width:176px;height:176px;position:relative;flex:0 0 auto}.bt-donut-wrap canvas{width:176px!important;height:176px!important}.bt-donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center;pointer-events:none}.bt-donut-center b{font-size:26px;color:#111827}.bt-donut-center span{font-size:12px;color:#667085}.bt-donut-legend{display:grid;gap:12px;min-width:0}.bt-dot{width:10px;height:10px;border-radius:999px;display:inline-block;margin-right:8px}.bt-activity{display:grid;gap:16px}.bt-activity-item{display:grid;grid-template-columns:46px 1fr;gap:13px;align-items:flex-start}.bt-activity-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:20px}.bt-activity-icon.green{background:#dcfae6;color:#079455}.bt-activity-icon.blue{background:#eaf3ff;color:#1570ef}.bt-activity-icon.purple{background:#f4ebff;color:#7a2ee6}.bt-activity-icon.red{background:#fee4e2;color:#d92d20}.bt-product-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.bt-product-mini{border:1px solid var(--bt-line);border-radius:16px;display:flex;gap:12px;align-items:center;padding:12px;background:#fff;min-width:0}.bt-product-mini img{width:62px;height:62px;border-radius:14px;object-fit:cover;background:#f8fafc;border:1px solid #edf0f5}.bt-product-mini b,.text-truncate{min-width:0}.kpi{position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;width:90px;height:90px;border-radius:999px;background:rgba(230,0,18,.10);right:-25px;top:-25px}

/* Login */
.login-page{min-height:100vh;background:#fff;color:#111827;overflow:hidden}.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(520px,47%) 1fr}.login-left{padding:52px 7vw 42px 7vw;display:flex;flex-direction:column;justify-content:center;position:relative;background:#fff}.login-logo{width:230px;margin-bottom:28px}.login-logo img{width:100%;height:auto;object-fit:contain;object-position:left center}.login-card{width:min(100%,640px);border:1px solid var(--bt-line);border-radius:24px;padding:50px 46px;background:rgba(255,255,255,.92);box-shadow:0 24px 80px rgba(16,24,40,.10);backdrop-filter:blur(10px)}.login-card h1{font-size:42px;font-weight:900;letter-spacing:-.04em;margin:0 0 10px}.login-red{color:var(--bt-red);font-weight:850}.login-input{position:relative}.login-input i{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#98a2b3;font-size:19px}.login-input .form-control{height:58px;padding-left:50px;border-radius:13px}.login-btn{height:58px;border:0;border-radius:12px;background:linear-gradient(135deg,var(--bt-red),#c90010);box-shadow:0 16px 28px rgba(230,0,18,.25);color:#fff;font-weight:850;font-size:17px}.login-divider{display:flex;align-items:center;gap:16px;color:#98a2b3;font-size:13px;margin:24px 0}.login-divider:before,.login-divider:after{content:"";height:1px;background:#e4e7ec;flex:1}.login-sso{display:grid;grid-template-columns:1fr 1fr;gap:14px}.login-sso .btn{height:52px;background:#fff;border-color:#d9dee8;color:#344054}.login-help{display:flex;align-items:center;gap:18px;margin:34px auto 0;width:min(100%,520px)}.login-help-icon{width:62px;height:62px;border-radius:50%;background:#fff1f2;color:#111827;display:grid;place-items:center;font-size:30px}.login-hero{position:relative;display:flex;flex-direction:column;justify-content:center;padding:70px;overflow:hidden;background:linear-gradient(135deg,#fff,#fff6f6)}.login-hero:before{content:"";position:absolute;inset:0;background:url('images/login-warehouse.svg') center/cover no-repeat;opacity:.98}.login-hero-content{position:relative;z-index:1;max-width:820px}.login-hero h2{font-size:38px;font-weight:950;color:#0f172a;letter-spacing:-.04em;margin-bottom:12px}.login-underline{width:60px;height:8px;background:var(--bt-red);border-radius:999px;margin-bottom:16px}.login-floating{position:relative;z-index:1}.login-metric{position:absolute;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border:1px solid #f2d5d7;border-radius:18px;padding:18px 22px;min-width:190px;box-shadow:var(--bt-shadow)}.login-metric.one{right:150px;top:145px}.login-metric.two{left:170px;top:300px}.login-metric.three{right:220px;bottom:240px}.login-metric small{display:block;color:#667085;font-weight:700}.login-metric b{font-size:26px;color:#111827}.login-features{position:absolute;z-index:1;left:70px;right:70px;bottom:48px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.login-feature{display:flex;gap:12px;align-items:center}.login-feature i{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#fff1f2;color:var(--bt-red);font-size:22px}.login-feature b{display:block;font-size:13px}.login-feature span{font-size:12px;color:#667085}.login-footer{font-size:12px;color:#667085;margin-top:24px}.login-footer a{font-weight:800}

/* Images and scanner */
.product-thumb{width:54px;height:54px;object-fit:cover;border-radius:12px;border:1px solid #e2e8f0;background:#f8fafc;cursor:zoom-in}.product-thumb-lg{width:120px;height:120px;object-fit:cover;border-radius:18px;border:1px solid #e2e8f0;background:#f8fafc}.product-image-card{border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 6px 18px rgba(15,23,42,.04)}.product-image-dashboard{width:100%;height:150px;object-fit:cover;background:#f8fafc;display:block;cursor:zoom-in}.product-preview-large{max-height:75vh;object-fit:contain;border-radius:14px;background:#f8fafc}.barcode-preview{font-family:"Courier New",monospace;letter-spacing:3px;background:#fff;border:1px dashed #cbd5e1;padding:8px 12px;border-radius:10px;display:inline-block}.scan-box{border:2px dashed #cbd5e1;background:#fff;border-radius:18px;padding:18px}.scan-box input:focus,.scan-box select:focus,.scan-box textarea:focus{box-shadow:0 0 0 .2rem rgba(230,0,18,.12);border-color:#ff7b86}.small-muted{font-size:12px;color:#667085}
.print-only{display:none}

@media (max-width:1400px){.bt-kpi-grid{grid-template-columns:repeat(3,1fr)}.bt-dashboard-grid,.bt-dashboard-row{grid-template-columns:1fr}.bt-product-strip{grid-template-columns:repeat(2,1fr)}.login-features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:992px){.bt-app-shell{display:block}.bt-sidebar{position:relative;width:100%;min-width:0;height:auto}.bt-sidebar-brand{height:auto}.bt-sidebar-menu{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.bt-help-card{display:none}.bt-topbar{position:relative;padding:16px;height:auto;flex-wrap:wrap}.bt-top-search{width:100%}.bt-content{padding:22px 16px}.bt-kpi-grid{grid-template-columns:repeat(2,1fr)}.login-shell{display:block}.login-left{padding:34px 22px}.login-card{padding:34px 24px}.login-hero{min-height:620px;padding:38px 22px}.login-metric{display:none}.login-features{left:22px;right:22px;bottom:28px}}
@media (max-width:576px){.bt-kpi-grid,.bt-product-strip,.login-sso{grid-template-columns:1fr}.bt-title{font-size:25px}.bt-page-head{display:block}.bt-page-actions{margin-top:16px;flex-wrap:wrap}.login-card h1{font-size:34px}.bt-sidebar-menu{grid-template-columns:1fr}.bt-user{display:none}}
@media print{.no-print,.bt-sidebar,.bt-topbar{display:none!important}.print-only{display:block}.bt-content{padding:0}.card{box-shadow:none;border:1px solid #ddd}}

/* ===== V8 REDESIGN: BYMON TILA premium dashboard, sama seperti referensi ===== */
body{background:#f6f7fb!important;color:#111827!important}.bt-app-shell{background:#f6f7fb!important}.bt-sidebar{width:276px;min-width:276px;background:#fff;border-right:1px solid #e7ebf2;box-shadow:10px 0 35px rgba(16,24,40,.035)}.bt-sidebar-brand{height:108px;justify-content:center;padding:18px 16px;border-bottom:1px solid #eef1f6}.bt-logo{justify-content:center;width:100%}.bt-logo img{width:178px;max-width:100%;max-height:88px;object-fit:contain;object-position:center;filter:none}.bt-sidebar-menu{padding:14px 16px 10px}.bt-menu-section{display:none}.bt-nav-link{height:48px;margin:6px 0;padding:0 16px;border-radius:9px;font-size:16px;font-weight:650;color:#27364a}.bt-nav-link .bt-nav-icon{width:24px;height:24px;font-size:18px;color:#526070}.bt-nav-link.active{background:#e90915;box-shadow:0 12px 22px rgba(233,9,21,.22);color:#fff}.bt-nav-link:hover{background:#fff0f1;transform:none}.bt-help-card{margin:20px 20px 24px;padding:18px 20px;border-radius:12px;border-color:#ecedf2;background:#fff;box-shadow:0 12px 28px rgba(16,24,40,.05)}.bt-help-icon{width:48px;height:48px;border-radius:12px}.bt-help-card .btn{border-radius:8px;color:#e90915;background:#fff;height:44px}.bt-topbar{height:84px;background:#fff;border-bottom:1px solid #e7ebf2;box-shadow:0 4px 16px rgba(16,24,40,.035);padding:0 36px}.bt-menu-toggle{box-shadow:none;background:#fff;font-size:24px}.bt-top-search{width:420px}.bt-top-search input{height:50px;border-radius:10px;border-color:#dfe4ee;box-shadow:none;font-size:15px}.bt-icon-btn{background:#fff;font-size:20px}.bt-user{padding-left:18px}.bt-avatar{background:#eef2f7;width:46px;height:46px}.bt-content{padding:28px 36px 42px;max-width:1660px}.bt-page-head{margin-bottom:30px}.bt-eyebrow{font-size:15px;color:#687588}.bt-title{font-size:30px;line-height:1.15}.bt-title-mark{width:32px;height:32px;color:#667085}.bt-date-pill{height:46px;border-radius:9px;background:#fff}.btn-primary,.btn-danger,.btn-warning{background:#e90915!important;border-color:#e90915!important;color:#fff!important;box-shadow:0 10px 20px rgba(233,9,21,.18)}.btn-primary:hover,.btn-danger:hover,.btn-warning:hover{background:#c9000c!important;border-color:#c9000c!important}.bt-kpi-grid{gap:20px;margin-bottom:26px}.bt-kpi-card{min-height:136px;padding:24px 24px;border-radius:16px;border-color:#e7ebf2;box-shadow:0 10px 24px rgba(16,24,40,.045);gap:22px}.bt-kpi-card:after{display:none}.bt-kpi-icon{width:68px;height:68px;background:#fff0f1;border-color:#ffe1e4;color:#e90915;font-size:30px}.bt-kpi-title{font-size:14px;color:#59677a}.bt-kpi-value{font-size:28px;color:#0f172a}.bt-dashboard-grid{grid-template-columns:1.02fr 1.1fr;gap:24px;margin-bottom:24px}.bt-dashboard-row{grid-template-columns:1.1fr .55fr .67fr;gap:24px}.card{border-radius:16px!important;border-color:#e7ebf2!important;box-shadow:0 12px 28px rgba(16,24,40,.045)!important}.card-body{padding:22px!important}.bt-card-title{font-size:20px}.bt-card-link{color:#e90915;font-weight:850}.bt-chart-card,.bt-table-card{min-height:340px}.bt-chart-wrap{height:260px;position:relative}.bt-chart-wrap canvas,.bt-donut-wrap canvas{position:absolute;inset:0;z-index:2}.bt-chart-fallback{position:absolute;inset:0;z-index:1}.bt-chart-wrap.chart-loaded .bt-chart-fallback{display:none}.bt-chart-fallback svg{width:100%;height:100%;display:block}.bt-mini-select{border-color:#dfe4ee;border-radius:8px}.bt-stock-progress{height:7px;background:#edf0f5}.bt-stock-progress span{background:#e90915}.table thead th{background:#fbfcfe;color:#526070;padding-top:12px;padding-bottom:12px}.table td{padding-top:14px;padding-bottom:14px}.bt-order-id{color:#e90915}.bt-donut-wrap{width:174px;height:174px}.bt-donut-fallback{position:absolute;inset:0;border-radius:50%;background:conic-gradient(#12b76a 0 42%, #2e90fa 42% 67%, #f6b100 67% 80%, #9b5cff 80% 88%, #98a2b3 88% 100%);z-index:1}.bt-donut-fallback:after{content:"";position:absolute;inset:34px;background:#fff;border-radius:50%;box-shadow:inset 0 0 0 1px #eef1f6}.bt-donut-wrap.chart-loaded .bt-donut-fallback{display:none}.bt-donut-center{z-index:3}.bt-product-strip{grid-template-columns:repeat(4,minmax(0,1fr))}.bt-product-mini{border-radius:14px}.product-thumb{transition:.15s ease}.product-thumb:hover,.product-image-dashboard:hover{transform:scale(1.03);box-shadow:0 12px 24px rgba(16,24,40,.12)}
/* memastikan halaman selain dashboard ikut rapi seperti template */
.bt-content>h1,.bt-content>.page-title,h1:not(.bt-title):not(.login-card h1){font-weight:900;color:#0f172a;letter-spacing:-.035em}.bt-content>.card,.bt-content>.row,.bt-content>form,.bt-content>.table-responsive{margin-bottom:22px}.card-header{font-size:16px}.btn{min-height:40px}.btn-sm{min-height:34px}.form-control,.form-select{border-radius:10px}.barcode-preview{background:#fff;border-color:#cfd7e6;color:#111827}
@media(max-width:1400px){.bt-dashboard-grid,.bt-dashboard-row{grid-template-columns:1fr}.bt-sidebar{width:255px;min-width:255px}.bt-nav-link{font-size:14px}.bt-top-search{width:min(420px,45vw)}}

/* ===== V9: hapus help card, sidebar bisa minimize dan resize ===== */
.bt-sidebar{
  width:var(--bt-sidebar-width,276px)!important;
  min-width:var(--bt-sidebar-width,276px)!important;
  max-width:440px;
  transition:width .18s ease,min-width .18s ease;
  position:sticky;
}
.bt-help-card{display:none!important}
.bt-sidebar-resizer{
  position:absolute;
  top:0;
  right:-4px;
  width:8px;
  height:100%;
  cursor:col-resize;
  z-index:60;
  border-radius:999px;
  transition:background .16s ease, opacity .16s ease;
  opacity:.15;
}
.bt-sidebar-resizer:hover,
body.bt-sidebar-resizing .bt-sidebar-resizer{
  background:#e90915;
  opacity:.55;
}
body.bt-sidebar-resizing{
  cursor:col-resize;
  user-select:none;
}
.bt-sidebar-menu{
  padding-bottom:28px!important;
}
.bt-nav-link{
  white-space:nowrap;
  overflow:hidden;
}
.bt-nav-label{
  overflow:hidden;
  text-overflow:ellipsis;
}
.bt-menu-section{
  font-size:10px!important;
  color:#98a2b3!important;
  letter-spacing:.12em!important;
  margin:18px 16px 8px!important;
}
.bt-nav-link .badge{
  flex:0 0 auto;
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar{
  width:86px!important;
  min-width:86px!important;
  max-width:86px!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar-brand{
  height:86px!important;
  padding:12px!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-logo img{
  width:58px!important;
  max-height:62px!important;
  object-fit:contain!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar-menu{
  padding:12px 10px 24px!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-menu-section,
.bt-app-shell.bt-sidebar-collapsed .bt-nav-label{
  display:none!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-nav-link{
  width:52px;
  height:52px;
  justify-content:center;
  padding:0!important;
  margin:7px auto;
  border-radius:14px;
  overflow:visible;
}
.bt-app-shell.bt-sidebar-collapsed .bt-nav-icon{
  margin:0!important;
  width:28px!important;
  height:28px!important;
  font-size:20px!important;
}
.bt-app-shell.bt-sidebar-collapsed .bt-nav-link .badge{
  position:absolute;
  top:-5px;
  right:-4px;
  min-width:18px;
  height:18px;
  padding:2px 5px;
  font-size:10px;
  border-radius:99px;
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar-resizer{
  display:none;
}
.bt-sidebar-hint{
  display:none;
}
.bt-menu-toggle{
  color:#0f172a!important;
  border:0!important;
}
.bt-menu-toggle:hover{
  background:#fff0f1!important;
  color:#e90915!important;
}
@media(max-width:992px){
  .bt-sidebar{width:100%!important;min-width:0!important;max-width:none!important;position:relative!important;height:auto!important}
  .bt-sidebar-resizer{display:none!important}
  .bt-app-shell.bt-sidebar-collapsed .bt-sidebar{width:100%!important;min-width:0!important;max-width:none!important}
  .bt-app-shell.bt-sidebar-collapsed .bt-nav-label{display:inline!important}
  .bt-app-shell.bt-sidebar-collapsed .bt-menu-section{display:none!important}
  .bt-app-shell.bt-sidebar-collapsed .bt-nav-link{width:auto;height:48px;justify-content:flex-start;padding:0 16px!important;margin:6px 0;border-radius:9px}
  .bt-app-shell.bt-sidebar-collapsed .bt-sidebar-menu{display:none!important}
}


/* ===== V10: tombol simpan modal selalu terlihat jelas ===== */
.modal{padding:12px!important}
.modal-dialog{max-width:min(940px,calc(100vw - 28px));}
.modal-xl{max-width:min(980px,calc(100vw - 28px))!important}
.modal-dialog-scrollable{height:calc(100vh - 32px);display:flex!important;align-items:center;justify-content:center;margin:16px auto!important}
.modal-dialog-scrollable .modal-content{max-height:calc(100vh - 32px);display:flex;flex-direction:column;overflow:hidden}
.modal-dialog-scrollable .modal-body{overflow-y:auto;max-height:calc(100vh - 180px);padding-bottom:18px!important}
.modal-header{flex:0 0 auto;background:#fff;z-index:3}
.modal-footer,.bt-modal-actionbar{
  flex:0 0 auto;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px;
  padding:16px 20px!important;
  border-top:1px solid #e7ebf2!important;
  background:#fff!important;
  box-shadow:0 -12px 26px rgba(16,24,40,.06);
  position:relative;
  z-index:4;
}
.bt-modal-actionbar .btn{min-width:132px;font-weight:850}
.bt-order-modal .modal-body{padding:22px 22px 14px!important}
.bt-order-modal .form-label{font-weight:700;color:#27364a}
.bt-order-modal .form-control,.bt-order-modal .form-select{min-height:48px}
.bt-order-modal textarea.form-control{min-height:82px}
.bt-order-modal #items .row{align-items:center}
.bt-order-modal .modal-title{font-size:20px;font-weight:900}
@media(max-height:760px){
  .modal-dialog-scrollable .modal-body{max-height:calc(100vh - 154px)}
  .bt-order-modal .modal-body{padding:16px 18px 10px!important}
  .modal-footer,.bt-modal-actionbar{padding:12px 18px!important}
}
@media(max-width:768px){
  .modal{padding:6px!important}
  .modal-dialog-scrollable{height:calc(100vh - 12px);margin:6px auto!important}
  .modal-dialog-scrollable .modal-content{max-height:calc(100vh - 12px)}
  .modal-dialog-scrollable .modal-body{max-height:calc(100vh - 158px)}
  .bt-modal-actionbar{align-items:stretch!important;flex-direction:column}
  .bt-modal-actionbar .small-muted{width:100%;margin-bottom:4px}
  .bt-modal-actionbar .btn{width:100%;min-width:0}
}


/* ===== V12: dropdown akun dan logout jelas ===== */
.bt-user-menu{position:relative;display:flex;align-items:center}
.bt-user{border:0;background:transparent;display:flex;align-items:center;gap:12px;border-left:1px solid var(--bt-line,#e7ebf2);padding:6px 0 6px 18px;color:var(--bt-text,#1f2937);cursor:pointer;text-align:left;border-radius:0}
.bt-user:hover .bt-user-name,.bt-user-menu.open .bt-user-name{color:#e90915}
.bt-user-info{min-width:0}
.bt-user-caret{color:#667085;font-size:16px;transition:transform .18s ease}
.bt-user-menu.open .bt-user-caret{transform:rotate(180deg);color:#e90915}
.bt-user-dropdown{position:absolute;right:0;top:calc(100% + 12px);width:250px;background:#fff;border:1px solid #e7ebf2;border-radius:16px;box-shadow:0 22px 50px rgba(16,24,40,.16);padding:10px;z-index:100;display:none}
.bt-user-menu.open .bt-user-dropdown{display:block;animation:btDrop .14s ease}
.bt-user-dropdown:before{content:"";position:absolute;top:-8px;right:28px;width:14px;height:14px;background:#fff;border-left:1px solid #e7ebf2;border-top:1px solid #e7ebf2;transform:rotate(45deg)}
.bt-user-dropdown-head{padding:10px 12px 12px;border-bottom:1px solid #eef1f6;margin-bottom:8px;position:relative;z-index:1}
.bt-user-dropdown-head strong{display:block;color:#0f172a;font-size:14px}
.bt-user-dropdown-head span{display:block;color:#667085;font-size:12px;margin-top:2px}
.bt-user-dropdown-item{position:relative;z-index:1;display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:11px;font-weight:800;color:#27364a!important;text-decoration:none!important}
.bt-user-dropdown-item:hover{background:#fff0f1;color:#e90915!important}
.bt-user-dropdown-item.bt-logout{color:#e90915!important}
@keyframes btDrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:576px){.bt-user-menu{display:none!important}}

/* V16 report export fixes: Excel button visible without Bootstrap CDN/icon font */
.btn-success{
  background:#16a34a!important;
  border-color:#16a34a!important;
  color:#fff!important;
  box-shadow:0 10px 20px rgba(22,163,74,.16)!important;
}
.btn-success:hover{background:#15803d!important;border-color:#15803d!important;color:#fff!important}
.report-export-btn{min-width:96px;gap:.5rem;font-weight:850!important;white-space:nowrap}
.report-export-icon{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 4px;border-radius:6px;border:1px solid currentColor;font-size:10px;font-weight:900;line-height:1;letter-spacing:.01em}
.btn-light .report-export-icon,.btn-outline-dark .report-export-icon{color:inherit}

/* ===== V17: scrollbar sidebar diperbesar dan resizer lebih mudah ditarik ===== */
.bt-sidebar-menu{
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-right:18px!important;
  scrollbar-width:auto;
  scrollbar-color:#aeb8c8 #f4f6fa;
  scrollbar-gutter:stable;
}
.bt-sidebar-menu::-webkit-scrollbar{
  width:14px!important;
}
.bt-sidebar-menu::-webkit-scrollbar-track{
  background:#f4f6fa;
  border-left:1px solid #eef1f6;
  border-radius:999px;
}
.bt-sidebar-menu::-webkit-scrollbar-thumb{
  background:#aeb8c8!important;
  border:3px solid #f4f6fa;
  border-radius:999px;
  min-height:72px;
}
.bt-sidebar-menu::-webkit-scrollbar-thumb:hover{
  background:#7f8aa1!important;
}
.bt-sidebar-resizer{
  right:-8px!important;
  width:16px!important;
  opacity:.45!important;
  background:linear-gradient(90deg,transparent 0,transparent 5px,#d8dee9 5px,#d8dee9 8px,transparent 8px)!important;
}
.bt-sidebar-resizer:after{
  content:"";
  position:absolute;
  top:50%;
  right:4px;
  width:6px;
  height:64px;
  transform:translateY(-50%);
  border-radius:999px;
  background:#c8d0dc;
  box-shadow:0 0 0 4px rgba(255,255,255,.7);
}
.bt-sidebar-resizer:hover,
body.bt-sidebar-resizing .bt-sidebar-resizer{
  opacity:1!important;
  background:linear-gradient(90deg,transparent 0,transparent 4px,rgba(233,9,21,.14) 4px,rgba(233,9,21,.14) 12px,transparent 12px)!important;
}
.bt-sidebar-resizer:hover:after,
body.bt-sidebar-resizing .bt-sidebar-resizer:after{
  background:#e90915;
  box-shadow:0 0 0 5px rgba(233,9,21,.10);
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar-menu{
  padding-right:10px!important;
  scrollbar-gutter:auto;
}
.bt-app-shell.bt-sidebar-collapsed .bt-sidebar-menu::-webkit-scrollbar{
  width:8px!important;
}

/* V18 report layout fixes: filter visible, submit button easy to click, SKU/Qty report table readable */
.report-filter-card{overflow:visible!important}
.bt-report-filter{display:grid;grid-template-columns:minmax(220px,1.35fr) minmax(180px,.9fr) minmax(180px,.9fr) minmax(170px,.65fr);gap:18px 24px;align-items:end;width:100%}
.bt-report-field label{font-weight:750;color:#0f172a;margin-bottom:8px}
.bt-report-filter .form-control,.bt-report-filter .form-select{height:52px;min-height:52px;border-radius:12px;background:#fff;font-size:15px}
.bt-report-action .btn{height:52px;border-radius:12px;font-size:16px;font-weight:900;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:none!important}
.bt-report-note{grid-column:1 / -1;background:#eff6ff;color:#175cd3;border:1px solid #dbeafe;border-radius:14px;padding:12px 14px;font-size:13px;line-height:1.45}
.report-card .table-responsive{overflow:auto;max-height:calc(100vh - 330px)}
.report-card table{min-width:980px}
.report-card td{white-space:normal;max-width:360px;line-height:1.45}
.report-card th{white-space:nowrap;position:sticky;top:0;z-index:2;background:#fbfcfe!important}
.report-card td:nth-child(10),.report-card td:nth-child(5){min-width:220px}
@media (max-width:1100px){.bt-report-filter{grid-template-columns:1fr 1fr}.bt-report-action{grid-column:1 / -1}.bt-report-note{grid-column:1 / -1}}
@media (max-width:680px){.bt-report-filter{grid-template-columns:1fr}.bt-report-action,.bt-report-note{grid-column:auto}.report-card .table-responsive{max-height:none}}

/* ===== V21: tombol lebih jelas di semua menu + lokasi rak selectable ===== */
.btn{
  min-height:42px;
  padding:.62rem 1rem;
  border-width:1.5px!important;
  font-weight:850!important;
  letter-spacing:.01em;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  opacity:1!important;
  text-decoration:none!important;
}
.btn-sm{min-height:34px;padding:.38rem .72rem;font-size:.86rem}
.btn-lg{min-height:52px;padding:.75rem 1.15rem;font-size:1rem}
.btn:disabled,.btn.disabled{opacity:.62!important;cursor:not-allowed}
.btn-dark,
.btn-secondary{
  background:#111827!important;
  border-color:#111827!important;
  color:#fff!important;
  box-shadow:0 10px 20px rgba(17,24,39,.12)!important;
}
.btn-dark:hover,.btn-secondary:hover{background:#0b1220!important;border-color:#0b1220!important;color:#fff!important}
.btn-light,
.btn-outline-secondary{
  background:#fff!important;
  border-color:#cbd5e1!important;
  color:#1f2937!important;
  box-shadow:0 6px 14px rgba(16,24,40,.06)!important;
}
.btn-light:hover,.btn-outline-secondary:hover{background:#f8fafc!important;border-color:#94a3b8!important;color:#0f172a!important}
.btn-outline-primary{
  background:#fff!important;
  color:#e90915!important;
  border-color:#ff9aa3!important;
  box-shadow:0 6px 14px rgba(233,9,21,.08)!important;
}
.btn-outline-primary:hover{background:#e90915!important;border-color:#e90915!important;color:#fff!important}
.btn-outline-danger{
  background:#fff!important;
  color:#e90915!important;
  border-color:#ff9aa3!important;
  box-shadow:0 6px 14px rgba(233,9,21,.08)!important;
}
.btn-outline-danger:hover{background:#e90915!important;border-color:#e90915!important;color:#fff!important}
.btn-outline-dark{
  background:#fff!important;
  color:#111827!important;
  border-color:#94a3b8!important;
  box-shadow:0 6px 14px rgba(16,24,40,.06)!important;
}
.btn-outline-dark:hover{background:#111827!important;color:#fff!important;border-color:#111827!important}
.btn-info{
  background:#0ea5e9!important;
  border-color:#0ea5e9!important;
  color:#fff!important;
  box-shadow:0 10px 20px rgba(14,165,233,.16)!important;
}
.btn-info:hover{background:#0284c7!important;border-color:#0284c7!important;color:#fff!important}
.card .card-header .btn,
.table .btn,
.modal-footer .btn,
.bt-modal-actionbar .btn{white-space:nowrap}
.form-select.form-select-lg,
.form-control.form-control-lg{min-height:52px}
.form-text{color:#667085!important;font-size:12px;line-height:1.45;margin-top:6px}


/* V24 Finance business report seperti laporan bisnis marketplace */
.bt-business-report .card-body{font-size:15px}.bt-biz-row{display:flex;justify-content:space-between;gap:16px;padding:12px 14px;border-bottom:1px solid #eef1f5;align-items:center}.bt-biz-green{background:#dff8f5;border-radius:10px;margin-top:6px;border-bottom:0}.bt-biz-profit{background:#eaf8ef;border-radius:10px;border-bottom:0;color:#04733b}.bt-biz-loss{background:#fff0f0;border-radius:10px;border-bottom:0;color:#c1121f}.bt-biz-detail{padding:10px 14px}.bt-biz-detail>div{display:flex;justify-content:space-between;gap:12px;padding:5px 0;color:#555}.bt-biz-detail .bt-sub{font-size:13px;color:#777;padding-left:14px}.bt-tren{display:flex;align-items:center;gap:18px;flex-wrap:wrap;color:#667085}.bt-tren .dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:6px;vertical-align:-1px}.dot.teal{background:#00a9a5}.dot.orange{background:#ff9f1c}.dot.green{background:#00b61e}.dot.blue{background:#4095ff}

/* V26 Finance multi SKU detail cards */
.finance-sku-summary{
  padding:10px 12px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  background:#f8fafc;
  margin-bottom:10px;
}
.finance-sku-detail-card{
  border:1px solid #e2e8f0;
  border-radius:16px;
  background:#ffffff;
  padding:12px;
  margin-bottom:10px;
  box-shadow:0 8px 22px rgba(15,23,42,.05);
}
.finance-sku-detail-card.active{
  border-color:#ef4444;
  box-shadow:0 10px 24px rgba(239,68,68,.14);
}
.finance-sku-detail-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.finance-sku-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  padding:6px 10px;
  border-radius:999px;
  background:#fee2e2;
  color:#dc2626;
  font-weight:800;
  font-size:12px;
}
.finance-sku-detail-card .form-control[readonly]{
  background:#f8fafc;
  color:#111827;
  font-weight:600;
}

/* V37 Searchable dropdown: semua select besar bisa dicari berdasarkan nama/SKU/lokasi/toko */
.bt-native-select-hidden{
  position:absolute!important;
  opacity:0!important;
  width:1px!important;
  height:1px!important;
  pointer-events:none!important;
  left:-9999px!important;
}
.bt-searchable-select{
  position:relative;
  width:100%;
}
.bt-searchable-select .bt-searchable-input{
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' viewBox='0 0 24 24'%3E%3Cpath stroke='%23667085' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 14px center;
  padding-right:38px;
  cursor:text;
}
.bt-searchable-select.open .bt-searchable-input{
  border-color:#e90915!important;
  box-shadow:0 0 0 .22rem rgba(233,9,21,.13)!important;
}
.bt-searchable-options{
  display:none;
  position:absolute;
  z-index:3000;
  left:0;
  right:0;
  top:calc(100% + 6px);
  max-height:330px;
  overflow:hidden;
  background:#fff;
  border:1px solid #d8e0ec;
  border-radius:14px;
  box-shadow:0 18px 45px rgba(15,23,42,.18);
}
.bt-searchable-select.open .bt-searchable-options{display:block;}
.bt-searchable-hint{
  padding:9px 12px;
  font-size:12px;
  color:#667085;
  background:#f8fafc;
  border-bottom:1px solid #edf1f7;
  font-weight:700;
}
.bt-searchable-list{
  max-height:284px;
  overflow:auto;
  padding:6px;
}
.bt-searchable-list::-webkit-scrollbar{width:12px;height:12px;}
.bt-searchable-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:999px;}
.bt-searchable-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px;border:2px solid #f1f5f9;}
.bt-searchable-list::-webkit-scrollbar-thumb:hover{background:#94a3b8;}
.bt-searchable-option{
  width:100%;
  border:0;
  background:#fff;
  text-align:left;
  padding:10px 12px;
  border-radius:10px;
  color:#0f172a;
  font-size:14px;
  line-height:1.25;
  cursor:pointer;
  font-weight:600;
}
.bt-searchable-option:hover,
.bt-searchable-option.keyboard{
  background:#fff1f2;
  color:#b91c1c;
}
.bt-searchable-option.selected{
  background:#e90915;
  color:#fff;
}
.bt-searchable-empty{
  padding:14px 12px;
  text-align:center;
  color:#64748b;
  font-size:13px;
}
.modal .bt-searchable-options{z-index:5000;}
.table .bt-searchable-options{min-width:260px;}
.bt-searchable-select-sm .bt-searchable-option{font-size:13px;padding:8px 10px;}
@media (max-width: 768px){
  .bt-searchable-options{max-height:280px;}
  .bt-searchable-list{max-height:235px;}
}


/* V41 login hero custom image */
.login-hero.login-hero-custom{background:linear-gradient(135deg,#fff,#fff6f6);padding:36px;display:flex;align-items:center;justify-content:center}
.login-hero.login-hero-custom:before{display:none}
.login-hero-image-card{position:relative;z-index:1;width:min(100%,900px);background:rgba(255,255,255,.72);border:1px solid #f0d8dc;border-radius:28px;padding:18px;box-shadow:0 24px 80px rgba(16,24,40,.10);backdrop-filter:blur(8px)}
.login-hero-image-card img{display:block;width:100%;height:auto;border-radius:22px;object-fit:cover}
@media (max-width:992px){.login-hero.login-hero-custom{padding:22px}.login-hero-image-card{padding:12px;border-radius:20px}.login-hero-image-card img{border-radius:14px}}

/* V42 resi otomatis */
.bt-auto-resi-holder .form-control[readonly]{background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-weight:800}
