:root{
    --primary:#4f46e5; --primary-dark:#3730a3; --body:#f5f7fb; --text:#172033; --muted:#748094; --border:#e8ecf3; --card:#fff;
}
*{box-sizing:border-box}
body{background:var(--body); color:var(--text); font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;}
a{text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:280px;background:#0f172a;color:white;padding:22px;position:fixed;top:0;bottom:0;left:0;z-index:1040;transition:.25s;overflow-y:auto}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,#6366f1,#22d3ee);font-size:24px}.brand strong{display:block;font-size:18px}.brand small{color:#94a3b8}.side-nav{display:flex;flex-direction:column;gap:6px}.side-nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;color:#cbd5e1;font-weight:600}.side-nav a i{font-size:20px}.side-nav a:hover,.side-nav a.active{background:rgba(255,255,255,.11);color:#fff}.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#64748b;margin:18px 12px 6px}.main-content{margin-left:280px;width:calc(100% - 280px)}.topbar{height:86px;display:flex;justify-content:space-between;align-items:center;padding:18px 28px;background:rgba(245,247,251,.85);backdrop-filter:blur(18px);position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border)}.topbar h1{font-size:24px;font-weight:800;margin:0}.topbar p{margin:3px 0 0;color:var(--muted)}.topbar-actions{display:flex;gap:14px;align-items:center}.user-chip{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:999px;padding:7px 8px 7px 7px}.user-chip small{display:block;color:var(--muted);line-height:1}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:#eef2ff;color:#4f46e5;font-weight:800}.content-area{padding:28px}.modern-card,.metric{border:1px solid var(--border);border-radius:24px;box-shadow:0 16px 50px rgba(15,23,42,.06);}.modern-card{overflow:hidden}.btn{font-weight:700}.btn-primary{background:var(--primary);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.form-control,.form-select{border-radius:14px;border-color:#dfe4ee}.form-control:focus,.form-select:focus{border-color:#a5b4fc;box-shadow:0 0 0 .25rem rgba(79,70,229,.12)}.stat-card{position:relative;overflow:hidden;border-radius:26px;padding:24px;color:white;min-height:156px;box-shadow:0 18px 55px rgba(15,23,42,.1)}.stat-card span{opacity:.86}.stat-card h3{font-size:28px;font-weight:850;margin:10px 0}.stat-card small{opacity:.86}.stat-card i{position:absolute;right:18px;bottom:6px;font-size:76px;opacity:.16}.gradient-blue{background:linear-gradient(135deg,#2563eb,#06b6d4)}.gradient-purple{background:linear-gradient(135deg,#7c3aed,#ec4899)}.gradient-green{background:linear-gradient(135deg,#059669,#14b8a6)}.gradient-orange{background:linear-gradient(135deg,#ea580c,#f59e0b)}.mini-list{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.mini-list:last-child{border-bottom:0}.mini-list small{display:block;color:var(--muted)}.mini-list span{font-weight:800;color:var(--primary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:60px 20px}.empty-state.small{padding:28px}.empty-state i{font-size:42px;color:#cbd5e1}.metric{background:#fff;padding:20px}.metric span{color:var(--muted);display:block}.metric strong{font-size:22px}.metric.primary{background:#eef2ff;color:#3730a3}.search-box{position:relative}.search-box i{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted);z-index:2}.search-box input{padding-left:44px;height:48px}.pos-grid{display:grid;grid-template-columns:minmax(0,1fr) 430px;gap:22px}.pos-products,.pos-cart{min-height:calc(100vh - 150px)}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;max-height:calc(100vh - 250px);overflow:auto;padding-right:5px}.product-card{border:1px solid var(--border);background:#fff;border-radius:20px;padding:15px;cursor:pointer;transition:.18s;position:relative}.product-card:hover{transform:translateY(-3px);box-shadow:0 18px 35px rgba(15,23,42,.08);border-color:#c7d2fe}.product-card .icon{width:42px;height:42px;border-radius:15px;background:#eef2ff;color:#4f46e5;display:grid;place-items:center;font-size:22px;margin-bottom:12px}.product-card h6{font-weight:800;margin-bottom:4px}.product-card p{color:var(--muted);font-size:12px;margin:0 0 12px}.product-card .price{font-weight:900;color:#111827}.product-card .stock{font-size:12px;position:absolute;right:12px;bottom:12px;color:var(--muted)}.cart-items{max-height:265px;overflow:auto}.cart-item{display:grid;grid-template-columns:1fr 110px 34px;gap:10px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.cart-item strong{display:block;font-size:14px}.cart-item small{color:var(--muted)}.qty-control{display:flex;align-items:center;border:1px solid var(--border);border-radius:999px;overflow:hidden}.qty-control button{border:0;background:#f8fafc;width:30px;height:30px;font-weight:900}.qty-control input{width:44px;border:0;text-align:center;font-weight:800}.cart-summary{background:#f8fafc;border:1px solid var(--border);border-radius:20px;padding:14px}.cart-summary>div{display:flex;justify-content:space-between;margin-bottom:10px;gap:12px}.cart-summary input{max-width:160px}.cart-summary .grand{font-size:20px;border-top:1px dashed #cbd5e1;padding-top:12px;margin-top:8px}.payment-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.payment-tabs button{border:1px solid var(--border);background:#fff;border-radius:16px;padding:11px 8px;font-weight:800}.payment-tabs button.active{background:#eef2ff;color:#3730a3;border-color:#a5b4fc}.invoice-info{display:flex;justify-content:space-between;border-bottom:1px solid var(--border);padding:12px 0}.invoice-info span{color:var(--muted)}.totals-box{max-width:360px;background:#f8fafc;border-radius:18px;padding:16px}.totals-box div{display:flex;justify-content:space-between;margin-bottom:8px}.totals-box .grand{font-size:20px;border-top:1px dashed #cbd5e1;padding-top:10px}.auth-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#c7d2fe,transparent 34%),linear-gradient(135deg,#eef2ff,#f8fafc)}.auth-card{width:min(980px,94vw);min-height:620px;background:#fff;border-radius:34px;box-shadow:0 28px 90px rgba(15,23,42,.14);display:grid;grid-template-columns:1.1fr .9fr;overflow:hidden}.auth-hero{padding:56px;color:white;background:linear-gradient(135deg,#0f172a,#4338ca);display:flex;flex-direction:column;justify-content:end;position:relative}.auth-hero:before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.11);top:-80px;right:-60px}.auth-hero h1{font-weight:900;font-size:42px;line-height:1.1}.auth-hero p{font-size:17px;color:#cbd5e1}.floating-card{position:absolute;top:42px;left:42px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(14px);border-radius:22px;padding:14px 16px;font-weight:800}.floating-card i{font-size:24px;margin-right:8px}.auth-form{padding:56px;display:flex;flex-direction:column;justify-content:center}.login-icon{width:66px;height:66px;border-radius:22px;background:#eef2ff;display:grid;place-items:center;margin:auto;color:#4f46e5;font-size:32px}.demo-login{text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;padding:12px;border-radius:16px}
@media(max-width:991px){.sidebar{transform:translateX(-105%)}.sidebar.show{transform:translateX(0)}.main-content{margin-left:0;width:100%}.topbar{padding:14px 18px}.topbar-actions .btn-primary{display:none}.content-area{padding:18px}.pos-grid{grid-template-columns:1fr}.auth-card{grid-template-columns:1fr}.auth-hero{display:none}}

.permission-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:16px;
}
.permission-group{
    padding:14px;
    border:1px solid rgba(15,23,42,.08);
    border-radius:18px;
    background:rgba(248,250,252,.8);
}
.permission-group strong{
    display:block;
    margin-bottom:8px;
    font-size:.85rem;
    color:#0f172a;
}
.permission-group .form-check{
    margin-bottom:6px;
    font-size:.88rem;
}
/* v3 refinements */
.product-card{display:block;text-align:left}.product-card strong{display:block;font-size:14px;margin-bottom:4px}.product-card span{display:block;color:var(--muted);font-size:12px}.product-card div{display:flex;justify-content:space-between;align-items:end;margin-top:12px}.product-card b{color:#111827}.product-card small{color:var(--muted)}.cart-item{display:flex;gap:10px;align-items:flex-start}.cart-item .rm{width:34px;height:34px}.empty-cart{text-align:center;color:var(--muted);padding:24px}.empty-cart i{font-size:36px;color:#cbd5e1}.payment-row .form-control,.payment-row .form-select{border-radius:10px}.stat-card{background:linear-gradient(135deg,#4f46e5,#06b6d4)}.stat-card strong{display:block;font-size:25px;margin:8px 0}.table .badge{font-weight:700}.side-nav{padding-bottom:24px}


/* POS customer Select2 */
.customer-field .select2-container--bootstrap-5 .select2-selection{
    min-height:44px;
    border-radius:14px;
    border-color:#dfe4ee;
    display:flex;
    align-items:center;
}
.customer-field .select2-container--bootstrap-5.select2-container--focus .select2-selection,
.customer-field .select2-container--bootstrap-5.select2-container--open .select2-selection{
    border-color:#a5b4fc;
    box-shadow:0 0 0 .25rem rgba(79,70,229,.12);
}
.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered{
    padding-left:12px;
    color:#0f172a;
    font-weight:600;
}
.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder{
    color:#94a3b8;
    font-weight:500;
}
.customer-required-help{
    display:block;
    color:#748094;
    font-size:12px;
    margin-top:7px;
}
.customer-option{
    display:flex;
    flex-direction:column;
    gap:2px;
    padding:4px 2px;
}
.customer-option strong{
    font-size:14px;
    font-weight:800;
    color:#0f172a;
}
.customer-option small{
    font-size:12px;
    color:#748094;
}
.customer-option i{
    font-size:13px;
}
.customer-option-general{
    border-left:3px solid #4f46e5;
    padding-left:8px;
}
.customer-option-general strong{
    color:#3730a3;
}
.select2-dropdown{
    border-color:#dfe4ee;
    border-radius:16px;
    overflow:hidden;
    box-shadow:0 18px 45px rgba(15,23,42,.12);
}
.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field{
    border-radius:12px;
    padding:8px 12px;
}


/* POS customer option display: phone/email/address tampil sebagai detail, bukan digabung dengan nama */
.customer-option strong{
    display:block;
    margin-bottom:4px;
}
.customer-option small{
    display:flex;
    align-items:flex-start;
    gap:6px;
    line-height:1.35;
    margin-top:2px;
    color:#64748b;
    white-space:normal;
}
.customer-option small i{
    margin-top:1px;
    flex:0 0 auto;
}
.customer-option-general small{
    display:block;
}
.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered{
    line-height:42px;
}

/* =========================================================
   POS CART ITEM ZEBRA / SELANG-SELING
   Patch: membuat item keranjang lebih mudah dicrosscheck
========================================================= */
#cartItems.cart-items{
    counter-reset: cartItem;
    display:flex;
    flex-direction:column;
    gap:10px;
    max-height:265px;
    overflow:auto;
    padding-right:4px;
}

#cartItems .cart-item{
    counter-increment:cartItem;
    position:relative;
    display:flex;
    align-items:flex-start;
    gap:12px;
    padding:14px 12px 14px 48px;
    border:1px solid #e3e8f2;
    border-radius:16px;
    border-bottom:1px solid #e3e8f2;
    box-shadow:0 6px 18px rgba(15,23,42,.035);
    transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease;
}

#cartItems .cart-item:nth-child(odd){
    background:#ffffff;
    border-left:4px solid #4f46e5;
}

#cartItems .cart-item:nth-child(even){
    background:#f3f7ff;
    border-left:4px solid #0ea5e9;
}

#cartItems .cart-item:hover{
    background:#eef4ff;
    border-color:#c7d2fe;
    box-shadow:0 10px 24px rgba(15,23,42,.065);
    transform:translateY(-1px);
}

#cartItems .cart-item::before{
    content:counter(cartItem);
    position:absolute;
    left:12px;
    top:14px;
    width:24px;
    height:24px;
    display:grid;
    place-items:center;
    border-radius:999px;
    background:#eef2ff;
    color:#3730a3;
    font-size:12px;
    font-weight:900;
    line-height:1;
}

#cartItems .cart-item:nth-child(even)::before{
    background:#e0f2fe;
    color:#0369a1;
}

#cartItems .cart-item strong{
    display:block;
    font-size:14px;
    font-weight:850;
    color:#0f172a;
    margin-bottom:3px;
}

#cartItems .cart-item small{
    display:block;
    color:#64748b;
    font-size:12px;
    margin-bottom:8px;
}

#cartItems .cart-item .row{
    margin-left:0;
    margin-right:0;
}

#cartItems .cart-item .form-control{
    background:#fff;
    border-radius:999px;
}

#cartItems .cart-item .rm{
    flex:0 0 auto;
    width:34px;
    height:34px;
    border-radius:10px;
    background:#fff;
    border:1px solid #ffe0e4;
}

#cartItems .cart-item .rm:hover{
    background:#fff1f2;
    border-color:#fecdd3;
}

#cartItems .empty-cart{
    border:1px dashed #dbe3ef;
    border-radius:18px;
    background:#f8fafc;
}

/* =========================================================
   WEB SETTINGS / DYNAMIC BRANDING PATCH
========================================================= */
.brand-logo-img,
.login-logo-img,
.floating-logo{
    max-width:100%;
    max-height:100%;
    object-fit:contain;
    display:block;
}
.brand-icon img{width:34px;height:34px;object-fit:contain;}
.login-icon img{width:44px;height:44px;object-fit:contain;}
.floating-card{display:flex;align-items:center;gap:8px;}
.floating-logo{width:26px;height:26px;}
.settings-section{
    border:1px solid var(--border);
    border-radius:22px;
    padding:20px;
    background:#fff;
}
.settings-section h6{
    font-weight:850;
    margin-bottom:16px;
    color:#0f172a;
}
.asset-preview{
    width:100%;
    min-height:82px;
    border:1px dashed #cbd5e1;
    border-radius:16px;
    background:#f8fafc;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:12px;
}
.asset-preview img{
    max-width:180px;
    max-height:70px;
    object-fit:contain;
}
.asset-preview.thumbnail img{
    max-width:100%;
    max-height:140px;
    border-radius:12px;
}
.asset-preview.favicon{
    width:82px;
    min-height:82px;
}
.asset-preview.favicon img{
    max-width:42px;
    max-height:42px;
}
.form-control-color{
    height:46px;
    padding:6px;
    cursor:pointer;
}

/* =========================================================
   v4.1 SINGLE THEME COLOR
   Semua aksen utama memakai 1 warna dari Web Settings.
========================================================= */
:root{
    --theme:var(--primary, #4f46e5);
    --theme-hover:color-mix(in srgb, var(--theme) 84%, #000000);
    --theme-soft:color-mix(in srgb, var(--theme) 10%, #ffffff);
    --theme-soft-2:color-mix(in srgb, var(--theme) 16%, #ffffff);
    --theme-soft-3:color-mix(in srgb, var(--theme) 24%, #ffffff);
    --theme-border:color-mix(in srgb, var(--theme) 32%, #ffffff);
    --theme-shadow:color-mix(in srgb, var(--theme) 22%, transparent);
}

.sidebar{
    background:linear-gradient(180deg, var(--theme) 0%, color-mix(in srgb, var(--theme) 78%, #000000) 100%) !important;
}
.brand-icon,
.stat-card,
.gradient-blue,
.gradient-purple,
.gradient-green,
.gradient-orange{
    background:var(--theme) !important;
}
.side-nav a:hover,
.side-nav a.active{
    background:rgba(255,255,255,.18) !important;
    color:#fff !important;
}
.nav-label,
.brand small{
    color:rgba(255,255,255,.72) !important;
}

.btn-primary,
.btn-primary:focus,
.btn-primary:active{
    background:var(--theme) !important;
    border-color:var(--theme) !important;
    color:#fff !important;
}
.btn-primary:hover{
    background:var(--theme-hover) !important;
    border-color:var(--theme-hover) !important;
}
.btn-outline-primary{
    color:var(--theme) !important;
    border-color:var(--theme-border) !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus{
    background:var(--theme) !important;
    border-color:var(--theme) !important;
    color:#fff !important;
}

.text-primary{color:var(--theme) !important;}
.bg-primary{background:var(--theme) !important;}
.border-primary{border-color:var(--theme) !important;}
.badge.text-bg-primary,
.text-bg-primary{
    background:var(--theme) !important;
    color:#fff !important;
}
.page-item.active .page-link{
    background:var(--theme) !important;
    border-color:var(--theme) !important;
}
.page-link{color:var(--theme);}

.form-control:focus,
.form-select:focus{
    border-color:var(--theme-border) !important;
    box-shadow:0 0 0 .25rem var(--theme-soft-2) !important;
}
.form-check-input:checked{
    background-color:var(--theme) !important;
    border-color:var(--theme) !important;
}
.form-range::-webkit-slider-thumb{background:var(--theme);}
.form-range::-moz-range-thumb{background:var(--theme);}

.avatar,
.login-icon,
.product-card .icon,
.metric.primary,
.payment-tabs button.active,
.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered{
    color:var(--theme) !important;
    background:var(--theme-soft-2) !important;
}
.product-card:hover,
.modern-card:hover{
    border-color:var(--theme-border);
}
.product-card:hover{
    box-shadow:0 18px 35px var(--theme-shadow);
}
.product-card .price,
.mini-list span,
.metric.primary strong,
.permission-group strong,
.settings-section h6{
    color:var(--theme) !important;
}
.payment-tabs button.active{
    border-color:var(--theme-border) !important;
}

.auth-body{
    background:radial-gradient(circle at top left, var(--theme-soft-3), transparent 34%), linear-gradient(135deg, var(--theme-soft), #f8fafc) !important;
}
.auth-hero{
    background:linear-gradient(135deg, var(--theme), color-mix(in srgb, var(--theme) 78%, #000000)) !important;
}
.floating-card{
    border-color:rgba(255,255,255,.28);
}

.topbar{
    background:color-mix(in srgb, var(--theme) 5%, #f8fafc) !important;
}
.modern-card,
.metric,
.cart-summary,
.totals-box,
.settings-section{
    border-color:color-mix(in srgb, var(--theme) 11%, var(--border)) !important;
}

/* Dashboard card menjadi ikut warna tema, bukan warna statis per-card. */
.stat-card{
    box-shadow:0 18px 55px var(--theme-shadow) !important;
}
.stat-card i{color:#fff;}

/* POS customer select2 ikut warna tema. */
.customer-field .select2-container--bootstrap-5.select2-container--focus .select2-selection,
.customer-field .select2-container--bootstrap-5.select2-container--open .select2-selection{
    border-color:var(--theme-border) !important;
    box-shadow:0 0 0 .25rem var(--theme-soft-2) !important;
}
.select2-container--bootstrap-5 .select2-dropdown{
    border-color:var(--theme-border) !important;
}
.select2-results__option--highlighted{
    background:var(--theme) !important;
}

/* Cart zebra tetap halus, aksennya ikut warna tema. */
#cartItems .cart-item:nth-child(odd),
.cart-items .cart-item:nth-child(odd){
    border-left-color:var(--theme) !important;
}
#cartItems .cart-item:nth-child(even),
.cart-items .cart-item:nth-child(even){
    border-left-color:color-mix(in srgb, var(--theme) 55%, #ffffff) !important;
    background:var(--theme-soft) !important;
}

.theme-color-input{
    height:58px;
    border-color:var(--theme-border) !important;
    background:var(--theme-soft) !important;
}


/* =========================================================
   v4.2 GRADIENT THEME LIKE AR COLLECTION
   Tetap memakai 1 warna dari Web Settings, tetapi tampilannya
   dibuat gradasi otomatis agar lebih modern.
========================================================= */
:root{
    --theme-deep:color-mix(in srgb, var(--theme) 78%, #000000);
    --theme-deeper:color-mix(in srgb, var(--theme) 62%, #020617);
    --theme-light:color-mix(in srgb, var(--theme) 38%, #ffffff);
    --theme-lighter:color-mix(in srgb, var(--theme) 20%, #ffffff);
    --theme-glass:color-mix(in srgb, var(--theme) 10%, #ffffff);
    --theme-gradient:linear-gradient(135deg, var(--theme-light) 0%, var(--theme) 42%, var(--theme-deep) 100%);
    --theme-gradient-hover:linear-gradient(135deg, var(--theme) 0%, var(--theme-deep) 55%, var(--theme-deeper) 100%);
    --theme-gradient-soft:linear-gradient(135deg, color-mix(in srgb, var(--theme) 12%, #ffffff) 0%, color-mix(in srgb, var(--theme) 7%, #f8fafc) 48%, #ffffff 100%);
    --theme-gradient-card:linear-gradient(145deg, #ffffff 0%, color-mix(in srgb, var(--theme) 7%, #ffffff) 58%, color-mix(in srgb, var(--theme) 13%, #ffffff) 100%);
    --theme-ring:0 0 0 .25rem color-mix(in srgb, var(--theme) 18%, transparent);
    --theme-card-shadow:0 22px 60px color-mix(in srgb, var(--theme) 18%, transparent);
    --theme-button-shadow:0 14px 28px color-mix(in srgb, var(--theme) 26%, transparent);
}

body{
    background:
        radial-gradient(circle at 4% 0%, color-mix(in srgb, var(--theme) 18%, transparent) 0, transparent 28%),
        radial-gradient(circle at 88% 8%, color-mix(in srgb, var(--theme) 10%, transparent) 0, transparent 26%),
        linear-gradient(135deg, #f8fafc 0%, color-mix(in srgb, var(--theme) 5%, #f1f5f9) 45%, #eef2f7 100%) !important;
}

.sidebar{
    background:
        radial-gradient(circle at 18% 0%, rgba(255,255,255,.26) 0, transparent 30%),
        radial-gradient(circle at 94% 18%, color-mix(in srgb, var(--theme-light) 46%, transparent) 0, transparent 28%),
        linear-gradient(155deg, var(--theme-light) 0%, var(--theme) 34%, var(--theme-deep) 72%, var(--theme-deeper) 100%) !important;
    box-shadow:18px 0 45px color-mix(in srgb, var(--theme) 18%, transparent) !important;
}
.sidebar::after{
    content:"";
    position:absolute;
    inset:auto -90px -120px auto;
    width:230px;
    height:230px;
    border-radius:999px;
    background:rgba(255,255,255,.09);
    pointer-events:none;
}
.brand-icon{
    background:linear-gradient(135deg, rgba(255,255,255,.32), rgba(255,255,255,.08)) !important;
    border:1px solid rgba(255,255,255,.34);
    box-shadow:0 14px 30px rgba(2,6,23,.16);
}
.brand strong,
.side-nav a,
.side-nav a span,
.side-nav a i{
    text-shadow:0 1px 10px rgba(2,6,23,.12);
}
.side-nav a:hover,
.side-nav a.active{
    background:linear-gradient(135deg, rgba(255,255,255,.26), rgba(255,255,255,.12)) !important;
    border:1px solid rgba(255,255,255,.22);
    box-shadow:0 14px 28px rgba(2,6,23,.10);
    backdrop-filter:blur(8px);
}

.topbar{
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 7%, #ffffff) 0%, rgba(255,255,255,.88) 100%) !important;
    border-bottom:1px solid color-mix(in srgb, var(--theme) 12%, #e5e7eb) !important;
    backdrop-filter:blur(12px);
}
.content-area{
    background:transparent !important;
}

.btn-primary,
.btn-success,
.btn-info,
.btn-primary:focus,
.btn-primary:active{
    background:var(--theme-gradient) !important;
    border-color:transparent !important;
    color:#fff !important;
    box-shadow:var(--theme-button-shadow) !important;
}
.btn-primary:hover,
.btn-success:hover,
.btn-info:hover{
    background:var(--theme-gradient-hover) !important;
    border-color:transparent !important;
    color:#fff !important;
    transform:translateY(-1px);
}
.btn-outline-primary{
    color:var(--theme) !important;
    border-color:color-mix(in srgb, var(--theme) 38%, #ffffff) !important;
    background:linear-gradient(135deg, #fff, color-mix(in srgb, var(--theme) 7%, #ffffff)) !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus{
    background:var(--theme-gradient) !important;
    border-color:transparent !important;
    color:#fff !important;
    box-shadow:var(--theme-button-shadow) !important;
}

.stat-card,
.gradient-blue,
.gradient-purple,
.gradient-green,
.gradient-orange{
    background:
        radial-gradient(circle at 90% 0%, rgba(255,255,255,.32) 0, transparent 30%),
        radial-gradient(circle at 0% 100%, rgba(255,255,255,.18) 0, transparent 28%),
        var(--theme-gradient) !important;
    box-shadow:var(--theme-card-shadow) !important;
    border:1px solid rgba(255,255,255,.32) !important;
    overflow:hidden;
    position:relative;
}
.stat-card::after,
.gradient-blue::after,
.gradient-purple::after,
.gradient-green::after,
.gradient-orange::after{
    content:"";
    position:absolute;
    right:-38px;
    bottom:-48px;
    width:130px;
    height:130px;
    border-radius:999px;
    background:rgba(255,255,255,.13);
    pointer-events:none;
}
.stat-card *,
.gradient-blue *,
.gradient-purple *,
.gradient-green *,
.gradient-orange *{
    position:relative;
    z-index:1;
}
.stat-card i{
    width:44px;
    height:44px;
    border-radius:15px;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.18);
    color:#fff !important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}

.modern-card,
.settings-section,
.metric,
.cart-summary,
.totals-box,
.permission-group{
    background:var(--theme-gradient-card) !important;
    border-color:color-mix(in srgb, var(--theme) 14%, #e5e7eb) !important;
    box-shadow:0 18px 50px rgba(15,23,42,.055) !important;
}
.modern-card:hover,
.product-card:hover{
    border-color:color-mix(in srgb, var(--theme) 32%, #ffffff) !important;
    box-shadow:var(--theme-card-shadow) !important;
}

.product-card .icon,
.login-icon,
.avatar,
.metric.primary{
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 16%, #ffffff), color-mix(in srgb, var(--theme) 8%, #ffffff)) !important;
    color:var(--theme) !important;
    box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--theme) 18%, #ffffff);
}
.product-card .price,
.metric.primary strong,
.settings-section h6,
.permission-group strong,
.text-primary{
    color:var(--theme-deep) !important;
}

.badge.text-bg-primary,
.text-bg-primary,
.bg-primary{
    background:var(--theme-gradient) !important;
    color:#fff !important;
}
.page-item.active .page-link{
    background:var(--theme-gradient) !important;
    border-color:transparent !important;
    box-shadow:0 10px 22px color-mix(in srgb, var(--theme) 20%, transparent);
}
.page-link{color:var(--theme-deep) !important;}

.form-control:focus,
.form-select:focus,
.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection{
    border-color:color-mix(in srgb, var(--theme) 42%, #ffffff) !important;
    box-shadow:var(--theme-ring) !important;
}
.form-check-input:checked{
    background:var(--theme-gradient) !important;
    border-color:transparent !important;
}

.payment-tabs button.active{
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 17%, #ffffff), color-mix(in srgb, var(--theme) 8%, #ffffff)) !important;
    border-color:color-mix(in srgb, var(--theme) 32%, #ffffff) !important;
    color:var(--theme-deep) !important;
    box-shadow:0 10px 24px color-mix(in srgb, var(--theme) 13%, transparent);
}
.select2-results__option--highlighted{
    background:var(--theme-gradient) !important;
    color:#fff !important;
}
.customer-option-general{
    border-left-color:var(--theme) !important;
}
.customer-option-general strong{
    color:var(--theme-deep) !important;
}

#cartItems .cart-item:nth-child(odd),
.cart-items .cart-item:nth-child(odd){
    background:linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, var(--theme) 4%, #ffffff) 100%) !important;
    border-left-color:var(--theme) !important;
}
#cartItems .cart-item:nth-child(even),
.cart-items .cart-item:nth-child(even){
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 8%, #ffffff), color-mix(in srgb, var(--theme) 3%, #ffffff)) !important;
    border-left-color:color-mix(in srgb, var(--theme) 55%, #ffffff) !important;
}
#cartItems .cart-item::before{
    background:var(--theme-gradient) !important;
    color:#fff !important;
    box-shadow:0 8px 18px color-mix(in srgb, var(--theme) 20%, transparent);
}
#cartItems .cart-item:hover{
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 11%, #ffffff), #ffffff) !important;
    border-color:color-mix(in srgb, var(--theme) 25%, #ffffff) !important;
}

.auth-body{
    background:
        radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--theme) 32%, transparent) 0, transparent 33%),
        radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--theme) 18%, transparent) 0, transparent 35%),
        linear-gradient(135deg, color-mix(in srgb, var(--theme) 8%, #f8fafc), #ffffff) !important;
}
.auth-card{
    box-shadow:0 32px 100px color-mix(in srgb, var(--theme) 18%, rgba(15,23,42,.15)) !important;
}
.auth-hero{
    background:
        radial-gradient(circle at 92% 0%, rgba(255,255,255,.28) 0, transparent 30%),
        linear-gradient(135deg, var(--theme-light) 0%, var(--theme) 42%, var(--theme-deep) 100%) !important;
}
.floating-card{
    background:linear-gradient(135deg, rgba(255,255,255,.20), rgba(255,255,255,.08)) !important;
    box-shadow:0 20px 50px rgba(2,6,23,.16);
}

.theme-color-input{
    height:62px;
    border:0 !important;
    background:var(--theme-gradient) !important;
    box-shadow:0 14px 30px color-mix(in srgb, var(--theme) 22%, transparent) !important;
    border-radius:18px !important;
}
.theme-gradient-preview{
    min-height:92px;
    border-radius:22px;
    padding:18px;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    background:
        radial-gradient(circle at 92% 0%, rgba(255,255,255,.32) 0, transparent 32%),
        var(--theme-gradient) !important;
    box-shadow:var(--theme-card-shadow);
    overflow:hidden;
    position:relative;
}
.theme-gradient-preview::after{
    content:"";
    position:absolute;
    right:-26px;
    bottom:-42px;
    width:130px;
    height:130px;
    border-radius:999px;
    background:rgba(255,255,255,.13);
}
.theme-gradient-preview strong,
.theme-gradient-preview small,
.theme-gradient-preview span{
    position:relative;
    z-index:1;
}
.theme-gradient-preview strong{
    display:block;
    font-size:16px;
    font-weight:900;
}
.theme-gradient-preview small{
    display:block;
    max-width:330px;
    margin-top:4px;
    color:rgba(255,255,255,.82);
    line-height:1.35;
}
.theme-gradient-preview span{
    width:52px;
    height:52px;
    flex:0 0 auto;
    border-radius:18px;
    display:grid;
    place-items:center;
    background:rgba(255,255,255,.18);
    border:1px solid rgba(255,255,255,.24);
    font-size:26px;
}
.table thead th{
    background:linear-gradient(135deg, color-mix(in srgb, var(--theme) 8%, #f8fafc), #ffffff) !important;
    color:#0f172a;
}
.dataTables_wrapper .form-control:focus,
.dataTables_wrapper .form-select:focus{
    border-color:color-mix(in srgb, var(--theme) 42%, #ffffff) !important;
    box-shadow:var(--theme-ring) !important;
}

/* =========================================================
   v4.3 AR COLLECTION STYLE SIDEBAR
   Sidebar tidak lagi mengikuti warna tema utama.
   Warna tema tetap dipakai sebagai aksen menu/icon saja.
========================================================= */
:root{
    --sidebar-bg:#0b1628;
    --sidebar-bg-2:#111f35;
    --sidebar-border:rgba(148,163,184,.18);
    --sidebar-text:#dbe7f6;
    --sidebar-muted:#8fa1bb;
    --sidebar-label:#8b9cb4;
    --sidebar-hover:rgba(255,255,255,.055);
    --sidebar-active:rgba(20,184,166,.10);
}

.sidebar{
    background:
        radial-gradient(circle at 18% 0%, rgba(20,184,166,.10) 0, transparent 26%),
        linear-gradient(180deg, var(--sidebar-bg) 0%, #091225 58%, #071120 100%) !important;
    color:var(--sidebar-text) !important;
    box-shadow:14px 0 38px rgba(2,6,23,.28) !important;
    border-right:1px solid rgba(148,163,184,.10);
    padding:18px 16px 22px !important;
}
.sidebar::after{
    display:none !important;
}
.sidebar::-webkit-scrollbar{width:7px;}
.sidebar::-webkit-scrollbar-track{background:transparent;}
.sidebar::-webkit-scrollbar-thumb{
    background:rgba(148,163,184,.34);
    border-radius:999px;
}
.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.52);}

.brand{
    margin-bottom:20px !important;
    padding:14px !important;
    border:1px solid var(--sidebar-border);
    border-radius:20px;
    background:linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 14px 34px rgba(2,6,23,.18);
}
.brand-icon{
    width:48px !important;
    height:48px !important;
    min-width:48px;
    border-radius:16px !important;
    background:linear-gradient(135deg, var(--theme), color-mix(in srgb, var(--theme) 72%, #075985)) !important;
    border:0 !important;
    box-shadow:0 12px 26px color-mix(in srgb, var(--theme) 22%, transparent) !important;
    color:#fff !important;
}
.brand strong{
    color:#ffffff !important;
    font-weight:900;
    letter-spacing:-.01em;
    text-shadow:none !important;
    line-height:1.2;
}
.brand small{
    color:var(--sidebar-muted) !important;
    font-size:12px;
    line-height:1.25;
    display:block;
    margin-top:2px;
    text-shadow:none !important;
}

.side-nav{
    gap:4px !important;
    padding-bottom:30px !important;
}
.nav-label{
    color:var(--sidebar-label) !important;
    font-size:11px !important;
    font-weight:900;
    letter-spacing:.18em;
    margin:20px 8px 8px !important;
    display:flex;
    align-items:center;
    gap:8px;
    text-shadow:none !important;
}
.nav-label::after{
    content:"";
    height:1px;
    flex:1;
    background:rgba(148,163,184,.20);
}
.side-nav a{
    position:relative;
    color:var(--sidebar-text) !important;
    padding:11px 10px !important;
    border-radius:13px !important;
    border:1px solid transparent !important;
    font-weight:800 !important;
    transition:background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
    text-shadow:none !important;
}
.side-nav a i{
    width:32px;
    height:32px;
    border-radius:11px;
    display:grid;
    place-items:center;
    font-size:18px !important;
    color:var(--theme) !important;
    background:color-mix(in srgb, var(--theme) 13%, rgba(255,255,255,.05)) !important;
    box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--theme) 22%, transparent);
    text-shadow:none !important;
}
.side-nav a span{
    color:inherit !important;
    text-shadow:none !important;
}
.side-nav a:hover{
    background:var(--sidebar-hover) !important;
    border-color:rgba(148,163,184,.12) !important;
    color:#ffffff !important;
    transform:translateX(2px);
    box-shadow:none !important;
    backdrop-filter:none !important;
}
.side-nav a.active{
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--theme) 18%, transparent), rgba(255,255,255,.045)) !important;
    border-color:color-mix(in srgb, var(--theme) 28%, transparent) !important;
    color:#ffffff !important;
    box-shadow:inset 3px 0 0 var(--theme), 0 10px 24px rgba(2,6,23,.16) !important;
    backdrop-filter:none !important;
}
.side-nav a.active i{
    color:#ffffff !important;
    background:var(--theme-gradient) !important;
    box-shadow:0 10px 22px color-mix(in srgb, var(--theme) 23%, transparent) !important;
}
.side-nav a.active::after{
    content:"";
    position:absolute;
    right:10px;
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--theme);
    box-shadow:0 0 0 4px color-mix(in srgb, var(--theme) 14%, transparent);
}

/* Mobile overlay tetap clean. */
@media(max-width:991px){
    .sidebar{
        width:min(84vw, 300px) !important;
    }
}

/* =========================================================
   v4.4 COMPACT GRADIENT PATCH
   Gradasi diperketat supaya area putih tidak terlalu dominan.
   Sidebar tetap dark navy AR Collection.
========================================================= */
:root{
    --theme-gradient-soft:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 18%, #ffffff) 0%,
        color-mix(in srgb, var(--theme) 12%, #ffffff) 42%,
        color-mix(in srgb, var(--theme) 6%, #f8fafc) 100%);
    --theme-gradient-card:linear-gradient(145deg,
        color-mix(in srgb, var(--theme) 15%, #ffffff) 0%,
        color-mix(in srgb, var(--theme) 10%, #ffffff) 45%,
        color-mix(in srgb, var(--theme) 5%, #ffffff) 100%);
    --theme-gradient-page:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 16%, #f8fafc) 0%,
        color-mix(in srgb, var(--theme) 9%, #f8fafc) 56%,
        #f8fafc 100%);
    --theme-gradient-table:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 12%, #f8fafc) 0%,
        color-mix(in srgb, var(--theme) 6%, #ffffff) 100%);
}

body{
    background:
        radial-gradient(circle at 4% 0%, color-mix(in srgb, var(--theme) 14%, transparent) 0, transparent 22%),
        radial-gradient(circle at 92% 7%, color-mix(in srgb, var(--theme) 11%, transparent) 0, transparent 20%),
        linear-gradient(135deg,
            color-mix(in srgb, var(--theme) 8%, #f8fafc) 0%,
            color-mix(in srgb, var(--theme) 5%, #f1f5f9) 52%,
            #eef2f7 100%) !important;
}

.topbar{
    background:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 10%, #ffffff) 0%,
        color-mix(in srgb, var(--theme) 5%, #ffffff) 62%,
        rgba(255,255,255,.92) 100%) !important;
}

.modern-card,
.settings-section,
.metric,
.cart-summary,
.totals-box,
.permission-group,
.product-card,
.user-chip{
    background:var(--theme-gradient-card) !important;
}

/* Header / card besar dibuat tetap modern, tapi area putihnya dipersempit. */
.modern-card{
    position:relative;
    overflow:hidden;
}
.modern-card::before{
    content:"";
    position:absolute;
    top:-58px;
    right:-72px;
    width:190px;
    height:190px;
    border-radius:999px;
    background:color-mix(in srgb, var(--theme) 12%, transparent);
    pointer-events:none;
}
.modern-card > *{
    position:relative;
    z-index:1;
}

/* Dashboard/stat card: highlight putih dikecilkan agar tidak terlalu pucat. */
.stat-card,
.gradient-blue,
.gradient-purple,
.gradient-green,
.gradient-orange{
    background:
        radial-gradient(circle at 92% 0%, rgba(255,255,255,.18) 0, transparent 20%),
        radial-gradient(circle at 0% 100%, rgba(255,255,255,.10) 0, transparent 18%),
        var(--theme-gradient) !important;
}
.stat-card::after,
.gradient-blue::after,
.gradient-purple::after,
.gradient-green::after,
.gradient-orange::after{
    right:-54px !important;
    bottom:-60px !important;
    width:110px !important;
    height:110px !important;
    background:rgba(255,255,255,.09) !important;
}

/* Table header dan area data dibuat sedikit tint, tidak polos putih. */
.table thead th{
    background:var(--theme-gradient-table) !important;
}
.table tbody tr:nth-child(even){
    background:color-mix(in srgb, var(--theme) 3%, #ffffff) !important;
}
.table tbody tr:hover{
    background:color-mix(in srgb, var(--theme) 7%, #ffffff) !important;
}

/* POS keranjang / form kecil dibuat tetap clean tapi tidak putih polos. */
#cartItems .cart-item:nth-child(odd),
.cart-items .cart-item:nth-child(odd){
    background:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 7%, #ffffff) 0%,
        color-mix(in srgb, var(--theme) 3%, #ffffff) 100%) !important;
}
#cartItems .cart-item:nth-child(even),
.cart-items .cart-item:nth-child(even){
    background:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 12%, #ffffff) 0%,
        color-mix(in srgb, var(--theme) 6%, #ffffff) 100%) !important;
}

/* Preview gradasi di Web Settings: efek putih diperkecil. */
.theme-gradient-preview{
    background:
        radial-gradient(circle at 92% 0%, rgba(255,255,255,.18) 0, transparent 20%),
        var(--theme-gradient) !important;
}
.theme-gradient-preview::after{
    width:96px !important;
    height:96px !important;
    right:-38px !important;
    bottom:-44px !important;
    background:rgba(255,255,255,.08) !important;
}

/* Login page juga dibuat lebih solid, tidak terlalu banyak putih. */
.auth-body{
    background:
        radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--theme) 26%, transparent) 0, transparent 24%),
        radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--theme) 16%, transparent) 0, transparent 26%),
        linear-gradient(135deg,
            color-mix(in srgb, var(--theme) 12%, #f8fafc),
            color-mix(in srgb, var(--theme) 5%, #ffffff)) !important;
}
.auth-hero{
    background:
        radial-gradient(circle at 92% 0%, rgba(255,255,255,.17) 0, transparent 20%),
        linear-gradient(135deg, var(--theme-light) 0%, var(--theme) 44%, var(--theme-deep) 100%) !important;
}
.auth-hero:before{
    width:190px !important;
    height:190px !important;
    background:rgba(255,255,255,.08) !important;
}

/* =========================================================
   v4.5 DASHBOARD ICON FIX
   Icon pada stat card dashboard tidak lagi terpotong.
   Icon dibuat sebagai badge kecil di kanan atas, sedangkan
   dekorasi lingkaran tetap berada di pojok bawah.
========================================================= */
.stat-card{
    min-height:156px !important;
    padding:26px 78px 24px 24px !important;
}
.stat-card i,
.gradient-blue i,
.gradient-purple i,
.gradient-green i,
.gradient-orange i{
    position:absolute !important;
    top:22px !important;
    right:22px !important;
    bottom:auto !important;
    width:52px !important;
    height:52px !important;
    min-width:52px !important;
    min-height:52px !important;
    display:grid !important;
    place-items:center !important;
    border-radius:18px !important;
    font-size:25px !important;
    line-height:1 !important;
    opacity:1 !important;
    color:#ffffff !important;
    background:rgba(255,255,255,.18) !important;
    border:1px solid rgba(255,255,255,.24) !important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.08), 0 12px 26px rgba(2,6,23,.10) !important;
    z-index:3 !important;
    transform:none !important;
    overflow:visible !important;
}
.stat-card::after,
.gradient-blue::after,
.gradient-purple::after,
.gradient-green::after,
.gradient-orange::after{
    right:-34px !important;
    bottom:-34px !important;
    width:96px !important;
    height:96px !important;
    background:rgba(255,255,255,.07) !important;
    z-index:0 !important;
}
.stat-card::before,
.gradient-blue::before,
.gradient-purple::before,
.gradient-green::before,
.gradient-orange::before{
    content:"";
    position:absolute;
    right:14px;
    bottom:14px;
    width:38px;
    height:38px;
    border-radius:999px;
    background:rgba(255,255,255,.075);
    pointer-events:none;
    z-index:0;
}
.stat-card span,
.stat-card h3,
.stat-card strong,
.stat-card small{
    position:relative;
    z-index:2;
}

@media(max-width:575px){
    .stat-card{
        padding:22px 68px 22px 20px !important;
        min-height:142px !important;
    }
    .stat-card i,
    .gradient-blue i,
    .gradient-purple i,
    .gradient-green i,
    .gradient-orange i{
        top:18px !important;
        right:18px !important;
        width:46px !important;
        height:46px !important;
        min-width:46px !important;
        min-height:46px !important;
        font-size:22px !important;
        border-radius:16px !important;
    }
}

/* =========================================================
   v4.6 NUMBER FORMAT, MOBILE SIDEBAR, BUTTON GRADIENT FIX
========================================================= */
@media(max-width:991px){
    body.sidebar-open{overflow:hidden;}
    body.sidebar-open::before{
        content:"";
        position:fixed;
        inset:0;
        background:rgba(2,6,23,.48);
        backdrop-filter:blur(2px);
        z-index:1035;
    }
    .sidebar{z-index:1045 !important;}
    .topbar{z-index:1020 !important;}
}

/* Input nominal: tetap terlihat seperti angka Rupiah, tapi value dikirim tanpa titik. */
input[data-money-bound="1"],
input.money-input,
input.nominal-input,
input.rupiah-input{
    text-align:right;
    font-variant-numeric:tabular-nums;
}
input[data-money-bound="1"]::placeholder,
input.money-input::placeholder,
input.nominal-input::placeholder,
input.rupiah-input::placeholder{
    color:#94a3b8;
}

/* Button gradient dibalik: default warna utama, hover muncul highlight putih modern. */
:root{
    --theme-gradient:linear-gradient(135deg,
        var(--theme) 0%,
        color-mix(in srgb, var(--theme) 84%, #000000) 55%,
        var(--theme-deep) 100%);
    --theme-gradient-hover:linear-gradient(135deg,
        color-mix(in srgb, var(--theme) 38%, #ffffff) 0%,
        var(--theme) 38%,
        color-mix(in srgb, var(--theme) 82%, #000000) 100%);
}
.btn-primary,
.btn-success,
.btn-info{
    background:var(--theme-gradient) !important;
    border-color:transparent !important;
    color:#fff !important;
    box-shadow:var(--theme-button-shadow) !important;
    background-size:140% 140% !important;
    background-position:100% 50% !important;
}
.btn-primary:hover,
.btn-success:hover,
.btn-info:hover,
.btn-primary:focus,
.btn-success:focus,
.btn-info:focus{
    background:var(--theme-gradient-hover) !important;
    background-position:0% 50% !important;
    border-color:transparent !important;
    color:#fff !important;
    box-shadow:0 16px 32px color-mix(in srgb, var(--theme) 28%, transparent) !important;
    transform:translateY(-1px);
}
.btn-outline-primary:hover,
.btn-outline-primary:focus{
    background:var(--theme-gradient-hover) !important;
    border-color:transparent !important;
    color:#fff !important;
}

/* =========================================================
   v4.7 CLEAN POS, REMOVE CARD HOVER, FIX CUSTOMER SELECT2
   - Card tidak lagi bergerak/berubah warna saat hover.
   - POS panel lebih bersih, dekorasi lingkaran besar dihilangkan.
   - Dropdown customer dibuat normal, rapi, dan mudah dibaca.
========================================================= */

/* 1) Hapus efek hover berlebihan pada semua card/panel utama */
.modern-card,
.metric,
.settings-section,
.permission-group,
.product-card,
.user-chip,
.stat-card,
#cartItems .cart-item,
.cart-items .cart-item{
    transition:none !important;
}

.modern-card:hover,
.metric:hover,
.settings-section:hover,
.permission-group:hover,
.product-card:hover,
.user-chip:hover,
.stat-card:hover,
#cartItems .cart-item:hover,
.cart-items .cart-item:hover{
    transform:none !important;
}

.modern-card:hover,
.metric:hover,
.settings-section:hover,
.permission-group:hover,
.user-chip:hover{
    border-color:color-mix(in srgb, var(--theme) 14%, #e5e7eb) !important;
    box-shadow:0 18px 50px rgba(15,23,42,.055) !important;
}

.product-card:hover{
    border-color:var(--border) !important;
    box-shadow:0 16px 38px rgba(15,23,42,.045) !important;
    background:var(--theme-gradient-card) !important;
}

.stat-card:hover{
    box-shadow:var(--theme-card-shadow) !important;
}

#cartItems .cart-item:hover,
.cart-items .cart-item:hover{
    border-color:#e3e8f2 !important;
    box-shadow:0 6px 18px rgba(15,23,42,.035) !important;
}

/* 2) Khusus halaman POS: panel jangan terlalu ramai */
.pos-products.modern-card,
.pos-cart.modern-card{
    background:linear-gradient(145deg,
        color-mix(in srgb, var(--theme) 6%, #ffffff) 0%,
        #ffffff 48%,
        color-mix(in srgb, var(--theme) 4%, #ffffff) 100%) !important;
    border-color:color-mix(in srgb, var(--theme) 13%, #e5e7eb) !important;
    overflow:visible !important;
}

.pos-products.modern-card::before,
.pos-cart.modern-card::before,
.pos-products.modern-card::after,
.pos-cart.modern-card::after{
    display:none !important;
}

.pos-products .product-card{
    background:#ffffff !important;
    border:1px solid color-mix(in srgb, var(--theme) 9%, #e5e7eb) !important;
    box-shadow:0 10px 28px rgba(15,23,42,.035) !important;
}

.pos-products .product-card:hover{
    background:#ffffff !important;
    border-color:color-mix(in srgb, var(--theme) 9%, #e5e7eb) !important;
    box-shadow:0 10px 28px rgba(15,23,42,.035) !important;
    transform:none !important;
}

.pos-products .product-card:active{
    transform:scale(.995) !important;
}

/* 3) Select customer POS dibuat clean, bukan blok gradasi gelap */
.customer-field{
    position:relative;
    z-index:20;
}

.customer-field .select2-container{
    width:100% !important;
}

.customer-field .select2-container--bootstrap-5 .select2-selection,
.customer-field .select2-container--bootstrap-5 .select2-selection--single{
    min-height:46px !important;
    height:46px !important;
    border-radius:14px !important;
    border:1px solid #dfe4ee !important;
    background:#ffffff !important;
    box-shadow:none !important;
    display:flex !important;
    align-items:center !important;
}

.customer-field .select2-container--bootstrap-5.select2-container--focus .select2-selection,
.customer-field .select2-container--bootstrap-5.select2-container--open .select2-selection{
    border-color:color-mix(in srgb, var(--theme) 42%, #ffffff) !important;
    box-shadow:0 0 0 .22rem color-mix(in srgb, var(--theme) 13%, transparent) !important;
    background:#ffffff !important;
}

.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered{
    background:transparent !important;
    color:#0f172a !important;
    font-weight:700 !important;
    line-height:44px !important;
    padding-left:13px !important;
    padding-right:38px !important;
}

.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__placeholder{
    color:#94a3b8 !important;
    font-weight:700 !important;
}

.customer-field .select2-container--bootstrap-5 .select2-selection--single .select2-selection__arrow{
    height:44px !important;
    right:12px !important;
}

.select2-container--bootstrap-5 .select2-dropdown,
.select2-dropdown{
    border:1px solid color-mix(in srgb, var(--theme) 18%, #dfe4ee) !important;
    border-radius:14px !important;
    background:#ffffff !important;
    box-shadow:0 18px 40px rgba(15,23,42,.12) !important;
    overflow:hidden !important;
    z-index:2055 !important;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search,
.select2-dropdown .select2-search{
    padding:10px !important;
    background:#ffffff !important;
    border-bottom:1px solid #eef2f7 !important;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field,
.select2-dropdown .select2-search__field{
    height:42px !important;
    border-radius:12px !important;
    border:1px solid #dfe4ee !important;
    padding:8px 12px !important;
    color:#0f172a !important;
    background:#ffffff !important;
    outline:none !important;
    box-shadow:none !important;
}

.select2-container--bootstrap-5 .select2-dropdown .select2-search .select2-search__field:focus,
.select2-dropdown .select2-search__field:focus{
    border-color:color-mix(in srgb, var(--theme) 42%, #ffffff) !important;
    box-shadow:0 0 0 .20rem color-mix(in srgb, var(--theme) 10%, transparent) !important;
}

.select2-results__options{
    max-height:280px !important;
}

.select2-results__option{
    padding:10px 12px !important;
    background:#ffffff !important;
    color:#0f172a !important;
    border-bottom:1px solid #f1f5f9 !important;
}

.select2-results__option:last-child{
    border-bottom:0 !important;
}

.select2-results__option--selected,
.select2-results__option[aria-selected="true"]{
    background:color-mix(in srgb, var(--theme) 9%, #ffffff) !important;
    color:#0f172a !important;
}

.select2-results__option--highlighted,
.select2-results__option--highlighted[aria-selected],
.select2-container--bootstrap-5 .select2-results__option--highlighted{
    background:color-mix(in srgb, var(--theme) 11%, #ffffff) !important;
    color:#0f172a !important;
}

.customer-option{
    display:flex !important;
    flex-direction:column !important;
    gap:3px !important;
    padding:2px 0 !important;
    background:transparent !important;
}

.customer-option strong{
    color:#0f172a !important;
    font-size:14px !important;
    font-weight:900 !important;
    line-height:1.25 !important;
    margin:0 0 3px !important;
}

.customer-option small{
    color:#64748b !important;
    font-size:12px !important;
    line-height:1.35 !important;
    margin:1px 0 0 !important;
    display:flex !important;
    gap:6px !important;
    align-items:flex-start !important;
}

.customer-option small i{
    color:var(--theme) !important;
    margin-top:1px !important;
}

.customer-option-general{
    border-left:3px solid var(--theme) !important;
    padding-left:9px !important;
    background:transparent !important;
}

.customer-option-general strong{
    color:var(--theme-deep) !important;
}

.customer-option-general small{
    color:#748094 !important;
    display:block !important;
}

/* Saat dropdown customer terbuka, jangan menutupi summary dengan warna aneh */
.pos-cart .select2-container--open,
.pos-cart .select2-container--focus{
    z-index:21 !important;
}

@media(max-width:575px){
    .select2-results__options{max-height:230px !important;}
    .select2-results__option{padding:9px 10px !important;}
}


/* =========================================================
   v4.18 - BUTTON HOVER TRANSITION
   ========================================================= */
.btn,
button.btn,
a.btn,
.btn-check + .btn,
.dropdown-item,
.page-link,
.nav-pills .nav-link,
.payment-row .btn,
.table .btn,
.modal-footer .btn {
    transition:
        transform .18s ease,
        box-shadow .18s ease,
        background-color .18s ease,
        border-color .18s ease,
        color .18s ease,
        opacity .18s ease !important;
}

.btn:not(.btn-close):not(:disabled):not(.disabled):hover,
a.btn:not(.disabled):hover,
button.btn:not(.btn-close):not(:disabled):hover {
    transform: translateY(-1px);
}

.btn:not(.btn-close):active,
a.btn:active,
button.btn:not(.btn-close):active {
    transform: translateY(0);
}

.btn-primary:not(:disabled):not(.disabled):hover,
.btn-success:not(:disabled):not(.disabled):hover,
.btn-warning:not(:disabled):not(.disabled):hover,
.btn-danger:not(:disabled):not(.disabled):hover,
.btn-info:not(:disabled):not(.disabled):hover {
    box-shadow: 0 10px 22px rgba(15, 23, 42, .14) !important;
}

.btn-light:not(:disabled):not(.disabled):hover,
.btn-outline-primary:not(:disabled):not(.disabled):hover,
.btn-outline-secondary:not(:disabled):not(.disabled):hover,
.btn-outline-success:not(:disabled):not(.disabled):hover,
.btn-outline-danger:not(:disabled):not(.disabled):hover {
    box-shadow: 0 8px 18px rgba(15, 23, 42, .08) !important;
}

/* Tombol hapus pembayaran tetap kecil dan bersih */
.payment-row .del-pay {
    width: 32px;
    height: 32px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
