:root{
  --bg:#f7f2ea;--surface:#fffcf8;--surface-2:#fff6ea;--surface-3:#2f2418;
  --line:#e9d5b0;--line-soft:#f0e4cc;--text:#251b11;--muted:#7f6a4b;
  --gold:#c89b3c;--gold-2:#e5c87e;--gold-deep:#8c6420;
  --success:#1f8a53;--warning:#d09321;--danger:#b34444;--info:#4578c7;--violet:#7a57be;--neutral:#818181;
  --shadow-xl:0 28px 80px rgba(71,48,9,.14);--shadow-lg:0 18px 42px rgba(73,51,14,.12);
  --shadow-md:0 12px 24px rgba(78,58,20,.10);--shadow-sm:0 4px 12px rgba(78,58,20,.06);
  --radius-xl:24px;--radius-lg:20px;--radius-md:16px;--radius-sm:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden;-webkit-text-size-adjust:100%}
body{font-family:Arial,Helvetica,sans-serif;color:var(--text);background:linear-gradient(180deg,#fcf8f2 0,#f7f2ea 100%);overflow-x:hidden;min-height:100vh}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
small{display:block;color:var(--muted);margin-top:2px;font-size:12px}
.mono{font-family:Consolas,monospace}
.text-center{text-align:center}
img{max-width:100%;height:auto}

/* LOGIN PAGE */
.login-body{margin:0;padding:0;min-height:100vh;overflow:hidden;font-family:Arial,Helvetica,sans-serif}
.login-bg{position:fixed;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}
.login-overlay{position:fixed;inset:0;background:rgba(209,159,107,.35);z-index:1}
.login-shell{position:relative;z-index:2;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:rgba(255,252,248,.92);backdrop-filter:blur(16px);border:1px solid rgba(209,159,107,.3);box-shadow:0 20px 60px rgba(71,48,9,.18);width:100%;max-width:400px;border-radius:var(--radius-xl);padding:32px 28px;text-align:center}
.login-logo{margin-bottom:14px}
.login-logo img{width:64px;height:64px;border-radius:18px;object-fit:cover;box-shadow:0 6px 18px rgba(140,100,32,.18);margin:0 auto;display:block}
.login-title{margin:0 0 20px;font-size:22px;font-weight:800;color:var(--text);line-height:1.2}
.login-form{display:grid;gap:14px}
.login-form .field{text-align:left}
.btn-login{width:100%;border:none;cursor:pointer;border-radius:var(--radius-sm);padding:12px 16px;font-weight:700;font-size:14px;background:linear-gradient(135deg,#D19F6B 0%,#a37840 100%);color:#fff;box-shadow:0 6px 16px rgba(209,159,107,.30);transition:.2s ease;display:flex;align-items:center;justify-content:center;gap:6px}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(209,159,107,.38)}
.login-watermark{margin-top:20px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(127,106,75,.45);font-weight:800}
.pw-wrap{position:relative}
.pw-wrap input{width:100%;padding-right:44px}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);padding:6px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:.15s ease}
.pw-toggle:hover{color:var(--gold-deep);background:rgba(200,155,60,.08)}
.form-stack{display:grid;gap:14px;margin-top:16px}

@media(max-width:480px){
  .login-card{padding:24px 20px;border-radius:var(--radius-lg)}
  .login-title{font-size:20px}
  .login-logo img{width:56px;height:56px}
}
.field{display:grid;gap:6px}
.field span{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.field input,.field select,.field textarea{width:100%;border:1px solid #dfca9d;border-radius:var(--radius-sm);padding:11px 14px;background:#fff;transition:.2s ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.8);font-size:14px}
.field select{
  appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:38px;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b5a3e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
  background-size:12px;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(200,155,60,.12)}
.field-hint{font-size:11px;color:var(--muted);line-height:1.45;margin-top:2px}
.field-inline{display:flex;gap:8px;align-items:stretch}
.field-inline select{flex:1;min-width:0}
.mini-list-item.is-scan-active{
  outline:2px solid rgba(200,155,60,.55)!important;
  background:linear-gradient(90deg,rgba(255,248,230,.95) 0%,rgba(255,255,255,.4) 100%)!important;
}

/* BUTTONS */
.btn{border:none;cursor:pointer;border-radius:var(--radius-sm);padding:10px 16px;font-weight:700;font-size:13px;transition:.2s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-sm{padding:8px 12px;font-size:12px;border-radius:10px}
.btn-primary{background:linear-gradient(135deg,var(--gold) 0,var(--gold-deep) 100%);color:#fff;box-shadow:0 8px 18px rgba(140,100,32,.20)}
.btn-secondary{background:linear-gradient(180deg,#fff7e8 0,#f6e7c6 100%);color:var(--gold-deep);border:1px solid #e5c77b}
.btn-outline{color:var(--gold-deep);background:rgba(255,248,233,.86);border:1px solid #e4ca90}
.btn-block{width:100%}
.alert{border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:14px;font-size:13px}
.alert-danger{background:#fff1f1;border:1px solid #f3cccc;color:var(--danger)}
.alert-success{background:#eefaf3;border:1px solid #bce8cb;color:var(--success)}

/* APP SHELL - CRITICAL: overflow hidden prevents mobile geser */
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;overflow:hidden;max-width:100vw;gap:0}
.app-main{display:flex;flex-direction:column;min-width:0;max-width:100%;overflow-x:hidden}

/* SIDEBAR */
.sidebar{background:linear-gradient(180deg,#2e2317 0,#241a11 100%);color:#f9ebd5;padding:18px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:space-between;gap:16px;overflow-y:auto;overflow-x:hidden}
.sidebar-top{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.sidebar-logo-img{width:44px;height:44px;border-radius:14px;object-fit:cover;box-shadow:0 8px 20px rgba(255,214,117,.14);flex-shrink:0}
.sidebar-title{font-weight:800;font-size:15px}
.sidebar-subtitle{font-size:11px;color:#d8c2a0}
.sidebar-section-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#a88d63;font-weight:800;margin:8px 0}
.sidebar-nav{display:grid;gap:4px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid transparent;color:#f8ead2;transition:.2s ease;font-size:13px}
.nav-link:hover,.nav-link.is-active{background:rgba(255,238,197,.10);border-color:rgba(255,229,161,.16)}
.nav-link-quiet{font-size:12px;opacity:.92}
.nav-link-quiet:hover{opacity:1}
.sidebar-user{padding:12px;border-radius:var(--radius-sm);background:rgba(255,255,255,.06);display:flex;gap:10px;align-items:center}
.user-avatar{width:36px;height:36px;border-radius:50%;background:#f2cc77;color:#2a1f12;display:grid;place-items:center;font-weight:900;font-size:14px;flex-shrink:0}
.user-name{font-weight:800;font-size:13px}
.user-role{font-size:11px;color:#d7c09a}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:49;backdrop-filter:blur(2px)}

/* TOPBAR */
.topbar{padding:14px 22px;display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid var(--line);background:rgba(255,252,247,.82);backdrop-filter:blur(12px);position:sticky;top:0;z-index:20}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}
.page-title{margin:0;font-size:20px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.topbar-badges{display:flex;gap:6px}
.icon-btn{border:1px solid var(--line);background:#fff7eb;padding:8px 10px;border-radius:10px;cursor:pointer;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;justify-content:center;transition:.15s ease;color:var(--gold-deep)}
.icon-btn:hover{background:#fff0d8;transform:translateY(-1px)}
.mobile-only{display:none}

/* PAGE CONTENT - overflow hidden prevents geser */
.page-content{padding:20px;padding-bottom:24px;overflow-x:hidden;max-width:100%}
.page-content>section,
.page-content>details.panel-card{margin-bottom:14px}
.page-content>section:last-child,
.page-content>details.panel-card:last-child{margin-bottom:0}

/* HERO */
.hero-card{padding:20px 22px;border-radius:var(--radius-xl);display:grid;grid-template-columns:1fr auto;gap:16px;margin-bottom:16px;background:radial-gradient(circle at top left,#fff3cf 0,#fffaf3 44%,#fffdf9 100%);border:1px solid var(--line);box-shadow:var(--shadow-md);overflow:hidden;align-items:center}
.hero-title{font-size:24px;line-height:1.12;margin:0 0 6px}
.hero-copy{color:var(--muted);font-size:13px;line-height:1.7;margin:0 0 12px;max-width:600px}
.hero-actions{display:flex;gap:8px;flex-wrap:wrap}
.hero-side-badge{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius-lg);background:rgba(53,38,16,.06);border:1px solid var(--line-soft)}
.hero-side-logo img{width:42px;height:42px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}
.hero-side-title{font-size:15px;font-weight:800;line-height:1.2;margin:0 0 2px;color:var(--text)}
.hero-side-meta{color:var(--muted);font-size:12px;line-height:1.4}

/* ========== KPI CARDS — VIBRANT FULL-COLOR (like SS8) ========== */
.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.reports-mini-grid{grid-template-columns:repeat(5,1fr)}
.stat-card{border-radius:18px;padding:16px 18px;position:relative;overflow:hidden;border:none;box-shadow:0 8px 24px rgba(0,0,0,.10);color:#fff;min-width:0;transition:.2s ease}
.stat-card:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 32px rgba(0,0,0,.16)}
.stat-card::after{content:'';position:absolute;right:-12px;bottom:-12px;width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.12)}
/* Ikon KPI: cahaya halus (opacity), bukan wadah kotak */
.stat-icon{
  display:inline-flex;align-items:center;justify-content:center;margin-bottom:6px;color:#fff;
  width:2.4rem;height:2.4rem;flex-shrink:0;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  box-shadow:none
}
.stat-icon svg{color:#fff;stroke:currentColor;opacity:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.12));flex-shrink:0}
.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:rgba(255,255,255,.85)}
.stat-value{font-size:22px;font-weight:900;margin:6px 0 3px;line-height:1.1;color:#fff}
.stat-foot{font-size:11px;color:rgba(255,255,255,.7)}

.stat-card.kpi-gold{background:linear-gradient(135deg,#e6a817 0%,#c89b3c 50%,#a67c25 100%)}
.stat-card.kpi-emerald{background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#15803d 100%)}
.stat-card.kpi-navy{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 50%,#1d4ed8 100%)}
.stat-card.kpi-rose{background:linear-gradient(135deg,#f97316 0%,#ea580c 50%,#c2410c 100%)}
.stat-card.kpi-champagne{background:linear-gradient(135deg,#d4a24e 0%,#b8902f 50%,#9a7820 100%)}
.stat-card.kpi-violet{background:linear-gradient(135deg,#8b5cf6 0%,#7c3aed 50%,#6d28d9 100%)}
.stat-card.kpi-sand{background:linear-gradient(135deg,#78716c 0%,#57534e 50%,#44403c 100%)}
.stat-card.kpi-charcoal{background:linear-gradient(135deg,#ef4444 0%,#dc2626 50%,#b91c1c 100%)}
.stat-card.kpi-gold .stat-label,.stat-card.kpi-gold .stat-foot,
.stat-card.kpi-emerald .stat-label,.stat-card.kpi-emerald .stat-foot,
.stat-card.kpi-navy .stat-label,.stat-card.kpi-navy .stat-foot,
.stat-card.kpi-rose .stat-label,.stat-card.kpi-rose .stat-foot,
.stat-card.kpi-champagne .stat-label,.stat-card.kpi-champagne .stat-foot,
.stat-card.kpi-violet .stat-label,.stat-card.kpi-violet .stat-foot,
.stat-card.kpi-sand .stat-label,.stat-card.kpi-sand .stat-foot,
.stat-card.kpi-charcoal .stat-label,.stat-card.kpi-charcoal .stat-foot{color:rgba(255,255,255,.8)}
.stat-card.emphasis{background:linear-gradient(160deg,#2f2418 0,#47351f 100%);color:#f9ebcf;border:1px solid #4a3b22}
.stat-card.emphasis .stat-label,.stat-card.emphasis .stat-foot{color:#e9d3aa}

/* PANELS */
.page-head-card{padding:18px 22px;border-radius:var(--radius-xl);display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px;background:linear-gradient(180deg,#fffdf9 0,#fff8ef 100%);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
.page-head-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex-shrink:0}
.section-title{font-size:22px;line-height:1.12;margin:0 0 4px}
.section-copy{margin:0;max-width:600px;color:var(--muted);font-size:13px;line-height:1.6}
.content-grid-2col{display:grid;grid-template-columns:1.22fr .78fr;gap:14px;margin-bottom:16px}
.compact-gap{gap:12px}
.panel-card{border-radius:var(--radius-lg);padding:18px;background:rgba(255,252,248,.96);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
.panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.panel-header h3{margin:0 0 2px;font-size:16px}
.panel-header p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}
.with-action .text-action{margin-top:2px}
.text-action{font-weight:800;color:var(--gold-deep);font-size:13px}
.text-action:hover{text-decoration:underline}

/* TABLES */
.table-shell{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line-soft);border-radius:var(--radius-md);background:#fff}
.data-table{width:100%;border-collapse:collapse;min-width:700px;background:#fff}
.compact-table{min-width:560px}
.data-table th,.data-table td{padding:10px 12px;border-bottom:1px solid #f1e7d4;text-align:left;vertical-align:middle;font-size:13px}
.data-table th{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:#fffaf1;padding:8px 12px}
.data-table tbody tr:hover{background:#fffaf4}
.data-table tbody tr.clickable-row{cursor:pointer}
.empty-state{padding:28px !important;text-align:center;color:var(--muted);font-size:13px}

/* ACTION ICONS */
.action-cell{white-space:nowrap}
.action-group{display:inline-flex;gap:4px;align-items:center}
.action-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fffaf2;color:var(--gold-deep);cursor:pointer;transition:.15s ease}
.action-icon:hover{background:#fff0d8;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.action-icon.danger{color:var(--danger);border-color:#f0d0d0;background:#fff8f8}
.action-icon.danger:hover{background:#ffe8e8}
.table-shell form{display:inline-block}
.hero-actions form{display:inline-block}

/* BADGES */
.badge{display:inline-flex;align-items:center;justify-content:center;padding:5px 8px;border-radius:999px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:800}
.badge.success{background:#eefaf3;color:var(--success)}
.badge.warning{background:#fff6e8;color:var(--warning)}
.badge.danger{background:#fff1f1;color:var(--danger)}
.badge.info{background:#eef4ff;color:var(--info)}
.badge.violet{background:#f4efff;color:var(--violet)}
.badge.neutral{background:#f2f2f2;color:var(--neutral)}

/* LISTS */
.summary-item,.mini-list-item{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px 12px;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--line-soft)}
.summary-item span,.mini-list-item span{display:block;color:var(--muted);font-size:12px;line-height:1.4}
.summary-item strong,.mini-list-item strong{font-size:13px}
.status-stack,.mini-list{display:grid;gap:8px}
.mini-list.dense{max-height:480px;overflow:auto;padding-right:4px}
.mini-list-meta{display:grid;justify-items:end;gap:4px}

/* TILE GRID */
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.tile-card{border-radius:var(--radius-lg);padding:16px;background:rgba(255,251,244,.82);backdrop-filter:blur(10px);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
.tile-card h3{margin:0 0 4px;font-size:14px}
.tile-card p{color:var(--muted);font-size:12px;line-height:1.5;margin:0 0 8px}
.tile-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#fff0c7 0,#d09a3b 100%);margin-bottom:10px;box-shadow:0 6px 14px rgba(208,154,59,.16);display:flex;align-items:center;justify-content:center;color:#5c3a0a}
.tile-icon svg{stroke:currentColor;flex-shrink:0}

/* FILTERS & FORMS */
.filter-card{padding:14px 16px}
/* Collapsible filter (ditingkatkan via app.js: tombol + bodi; default tertutup) */
.filter-card.is-filter-card-enhanced{padding:0;overflow:hidden}
.filter-card-toggle{
  display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;
  margin:0;padding:14px 16px;border:0;background:transparent;cursor:pointer;
  font:inherit;font-size:14px;font-weight:700;color:var(--text);text-align:left;
  border-bottom:1px solid transparent;transition:background .15s ease
}
.filter-card-toggle:hover{background:rgba(0,0,0,.04)}
.filter-card-toggle:focus{outline:none}
.filter-card-toggle:focus-visible{box-shadow:inset 0 0 0 2px rgba(200,155,60,.45);border-radius:10px 10px 0 0}
.filter-card-toggle-text{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.filter-card-chevron{flex-shrink:0;color:var(--muted);transition:transform .2s ease}
.filter-card.is-filter-open .filter-card-toggle{border-bottom-color:var(--line-soft)}
.filter-card.is-filter-open .filter-card-chevron{transform:rotate(180deg);color:var(--text)}
.filter-card .filter-card-body{display:none}
.filter-card.is-filter-open .filter-card-body{display:block}
.filter-card-body{padding:0 16px 14px 16px}
.filter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;align-items:end}
.form-panel{padding-top:18px}
.form-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.field.full,.kv-grid .full{grid-column:1 / -1}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;flex-wrap:wrap;align-items:center}
.master-tabs{display:flex;gap:6px;flex-wrap:wrap}

/* KV GRID */
.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.kv-grid>div{padding:12px 14px;border:1px solid var(--line-soft);background:#fff;border-radius:var(--radius-sm)}
.kv-grid span{display:block;color:var(--muted);font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:800;margin-bottom:4px}
.kv-grid strong{font-size:14px;line-height:1.5}

/* CHART & CHECKBOX */
canvas{width:100%;max-width:100%;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius-md)}
.color-pill{display:inline-block;width:20px;height:20px;border-radius:999px;border:2px solid rgba(0,0,0,.06)}
input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold)}
.mini-list-item input[type=checkbox]{margin-right:8px}

/* ========== PREVIEW MODAL (modern card-based like SS7) ========== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:60;align-items:flex-start;justify-content:center;padding:24px 16px;overflow-y:auto;backdrop-filter:blur(3px)}
.modal-overlay.is-open{display:flex}
.modal-box{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;margin-top:40px;animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-header{padding:20px 24px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line-soft)}
.modal-header h3{margin:0;font-size:18px;font-weight:800}
.modal-header .badge{margin-left:8px}
.modal-body{padding:20px 24px}
.modal-footer{padding:14px 24px;border-top:1px solid var(--line-soft);display:flex;justify-content:flex-end;gap:8px}
.modal-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);transition:.15s ease}
.modal-close:hover{background:#f5f0e8}
.modal-section{margin-bottom:16px}
.modal-section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--gold-deep);margin-bottom:8px;padding-bottom:4px;border-bottom:2px solid var(--gold-2);display:inline-block}
.modal-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.modal-detail-item{padding:10px 12px;background:#faf7f2;border-radius:10px;border:1px solid var(--line-soft)}
.modal-detail-item label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:800;margin-bottom:2px}
.modal-detail-item .val{font-size:14px;font-weight:700;color:var(--text)}
.modal-detail-item.full{grid-column:1/-1}
.modal-photo{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:12px;border:1px solid var(--line-soft)}
.modal-barcode{text-align:center;padding:12px;background:#fff;border:1px dashed var(--line);border-radius:10px;margin-bottom:12px}
.modal-barcode svg{max-width:240px;height:auto}
.modal-barcode canvas{max-width:150px;height:auto;margin:0 auto;display:block}
.modal-barcode .bc-text{font-family:Consolas,monospace;font-size:14px;letter-spacing:2px;margin-top:4px;color:var(--text)}

/* PHOTO UPLOAD */
.photo-upload-area{border:2px dashed var(--line);border-radius:var(--radius-md);padding:16px;text-align:center;background:#fefcf8;cursor:pointer;transition:.2s}
.photo-upload-area:hover{border-color:var(--gold);background:#fffaf0}
.photo-upload-area.has-photo{border-style:solid;padding:8px}
.photo-preview{max-width:100%;max-height:180px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:8px}
.photo-placeholder{width:100%;height:100px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;gap:6px}
.photo-actions{display:flex;gap:6px;justify-content:center;margin-top:6px}

/* PRINT */
.print-body{background:#f1ede6}
.print-stage{padding:24px}
.print-actions{text-align:center;margin-bottom:20px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.thermal-stage{display:flex;justify-content:center}
.thermal-paper{width:320px;background:#fff;padding:16px 14px;border-radius:10px;box-shadow:0 8px 20px rgba(0,0,0,.08);font-family:'Courier New',monospace;font-size:12px;color:#111}
.thermal-header,.thermal-footer{text-align:center;line-height:1.5}
.thermal-store{font-weight:700;font-size:15px;margin-bottom:4px}
.thermal-divider{border-top:1px dashed #555;margin:8px 0}
.thermal-item{padding:4px 0}
.thermal-item-name{font-weight:700}
.thermal-item-meta{font-size:11px;color:#666}
.thermal-item-price{margin-top:2px;text-align:right}
.thermal-total-row{display:flex;justify-content:space-between;padding:3px 0}
.thermal-total-row.grand{font-size:14px;font-weight:700}

/* INVOICE / FAKTUR */
.invoice-stage{display:flex;justify-content:center}
.invoice-paper{width:700px;background:#fff;padding:0;border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,.10);font-size:13px;color:#111;overflow:hidden}
.invoice-header{background:linear-gradient(135deg,#c89b3c 0%,#8c6420 100%);color:#fff;padding:20px 24px;display:flex;justify-content:space-between;align-items:center}
.invoice-brand{display:flex;align-items:center;gap:12px}
.invoice-brand img{width:48px;height:48px;border-radius:12px;object-fit:cover;border:2px solid rgba(255,255,255,.3)}
.invoice-brand-text h2{margin:0;font-size:18px;font-weight:900}
.invoice-brand-text p{margin:0;font-size:11px;opacity:.85}
.invoice-number{text-align:right}
.invoice-number h3{margin:0;font-size:14px;font-weight:800}
.invoice-number p{margin:2px 0 0;font-size:11px;opacity:.85}
.invoice-body{padding:20px 24px}
.invoice-meta{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.invoice-meta-item{padding:8px 12px;background:#faf7f2;border-radius:8px}
.invoice-meta-item label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:800;margin-bottom:2px}
.invoice-meta-item span{font-weight:700;font-size:13px}
.invoice-meta-item.full{grid-column:1/-1}
.invoice-table{width:100%;border-collapse:collapse;margin-bottom:12px}
.invoice-table th{background:#f5f0e6;font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:8px 10px;text-align:left;color:var(--muted);border-bottom:2px solid var(--line)}
.invoice-table td{padding:8px 10px;border-bottom:1px solid #f0ead8;font-size:12px}
.invoice-totals{display:flex;justify-content:flex-end}
.invoice-totals table{width:260px;font-size:13px}
.invoice-totals td{padding:4px 8px}
.invoice-totals .grand td{font-weight:900;font-size:15px;border-top:2px solid var(--gold);padding-top:8px}
.invoice-footer{border-top:1px solid var(--line-soft);padding:16px 24px;background:#fefcf8;text-align:center}
.invoice-footer p{margin:0;color:var(--muted);font-size:11px;line-height:1.6}
.invoice-perhatian{font-size:10px;color:var(--muted);line-height:1.5;margin-top:8px;padding:8px;background:#fff8ef;border-radius:6px;border:1px solid var(--line-soft)}

/* LABEL */
.label-stage{display:flex;justify-content:center}
.label-sheet{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:900px}
.label-card{background:#fff;border:2px solid #111;padding:10px;min-height:130px;display:grid;align-content:start;gap:4px}
.label-top{font-size:9px;text-transform:uppercase;letter-spacing:.08em}
.opname-title-note{font-weight:600;color:var(--muted);font-size:.72em}
.opname-page-head .section-copy{max-width:52rem}
.opname-help-details{background:rgba(255,252,248,.96);border:1px solid var(--line);border-radius:var(--radius-lg);padding:0;margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.opname-help-summary{cursor:pointer;list-style:none;padding:12px 16px;font-size:13px;font-weight:800;color:var(--gold-deep)}
.opname-help-details[open] .opname-help-summary{border-bottom:1px solid var(--line-soft);background:rgba(255,248,233,.45)}
.opname-help-summary::-webkit-details-marker{display:none}
.opname-help-details .opname-steps{margin:0;padding:12px 16px 14px 2.25rem}
.opname-steps{display:grid;gap:8px;font-size:13px;line-height:1.55;color:#3a2a1a}
.opname-step-num{display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;border-radius:50%;background:var(--gold);color:#fff;font-size:11px;font-weight:800;margin-right:6px;vertical-align:middle}
.opname-filter-bar{padding:12px 16px;margin-bottom:12px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.opname-filter-field{min-width:220px;margin:0;flex:1}
.opname-form-stack{display:flex;flex-direction:column;gap:0}
.opname-form-intro{padding-bottom:12px;margin-bottom:14px;border-bottom:1px solid var(--line-soft)}
.opname-rekap-wrap{margin-top:20px;padding-top:18px;border-top:1px solid var(--line-soft)}
.opname-rekap-heading{margin:0;font-size:14px;font-weight:800;color:#5c4018}
.opname-rekap-lead{margin:4px 0 12px!important;font-size:12px!important;line-height:1.45!important}
.opname-rekap-grid{display:grid;gap:8px;padding:0}
.opname-rekap-grid--simple{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:680px){.opname-rekap-grid--simple{grid-template-columns:1fr}}
.opname-rekap-cell{border-radius:10px;padding:10px 12px}
.opname-rekap-label{font-size:11px;font-weight:700;line-height:1.35;margin-bottom:4px}
.opname-rekap-num{font-size:18px;display:block}
.opname-rekap-neutral{background:#fff;border:1px solid var(--line)}
.opname-rekap-neutral .opname-rekap-label{color:var(--muted)}
.opname-rekap-num{color:#6b4a16}
.opname-rekap-ok{background:#f3fbf3;border:1px solid #c6e7c6}
.opname-rekap-ok .opname-rekap-label{color:#2f6d2f}
.opname-rekap-ok .opname-rekap-num{color:#1d5c1d}
.opname-rekap-warn{background:#fff8ef;border:1px solid #d4a85a}
.opname-rekap-warn .opname-rekap-label{color:#7a5a1a}
.opname-rekap-bad{background:#fef3f3;border:1px solid #e7a6a6}
.opname-rekap-bad .opname-rekap-label{color:#8a1f1f}
.opname-rekap-bad .opname-rekap-num{color:#8a1f1f}
.opname-history-shell{margin-top:18px;max-height:min(40vh,360px)}
.opname-list-card .opname-list-head{align-items:flex-start}
.opname-list-actions{display:flex;gap:6px;flex-shrink:0;flex-wrap:wrap}
.opname-product-list .opname-row{align-items:center;padding:12px 14px;gap:10px}
.opname-row-main{min-width:0;flex:1}
.opname-row-meta{display:block;margin-top:4px;font-size:12px;color:var(--muted);line-height:1.45}
.opname-row-qty{align-items:center}
.opname-qty-label{display:flex;flex-direction:column;gap:4px;align-items:flex-end;margin:0}
.opname-qty-span{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.opname-qty-input{width:68px;padding:8px 10px;border-radius:8px;border:1px solid var(--line);text-align:center;font-weight:700}
.opname-empty-list{padding:16px!important}
.label-photo{text-align:center}
.label-photo img{max-width:100%;max-height:48px;object-fit:contain;border-radius:4px}
.label-name{font-size:14px;font-weight:700;line-height:1.2}
.label-meta{font-size:11px}
.money-input{text-align:right;font-variant-numeric:tabular-nums}
.money-input[readonly]{background:#f5f3ef;color:#4a4035}
.label-barcode-wrap{display:flex;justify-content:center;align-items:center;width:100%}
.label-barcode{text-align:center;padding:6px 0 3px;border-top:1px dashed #555;border-bottom:1px dashed #555;max-width:100%}
.label-barcode svg,.label-barcode canvas{display:block;max-width:100%;height:auto;margin:0 auto}
.label-barcode .bc-num{font-family:'Courier New',monospace;font-size:10px;letter-spacing:1px;margin-top:2px}
.label-barcode .bc-ean13-svg{display:block;max-width:100%;height:auto;margin:0 auto}
.label-price{font-weight:800;font-size:14px;margin-top:3px}

/* LABEL SETTINGS */
.label-presets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.label-preset-btn{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;text-align:center;transition:.15s}
.label-preset-btn:hover,.label-preset-btn.active{border-color:var(--gold);background:#fff8ef;box-shadow:var(--shadow-sm)}
.label-preset-btn strong{display:block;font-size:13px;margin-bottom:2px}
.label-preset-btn span{font-size:11px;color:var(--muted)}

/* BOTTOM NAVBAR */
.bottom-navbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:40;background:linear-gradient(180deg,#fffcf7 0,#fff8ef 100%);border-top:1px solid var(--line);box-shadow:0 -4px 16px rgba(71,48,9,.08);padding:6px 4px calc(6px + env(safe-area-inset-bottom));justify-content:space-around;align-items:center}
.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 8px;border-radius:10px;color:var(--muted);background:none;border:none;cursor:pointer;font-size:10px;font-weight:700;min-width:56px;transition:.15s ease;text-decoration:none}
.bottom-nav-item.is-active{color:var(--gold-deep);background:rgba(200,155,60,.10)}
.bottom-nav-item:hover{color:var(--gold-deep)}
.bottom-nav-label{display:block;line-height:1}

/* ========== RESPONSIVE 1280 ========== */
@media(max-width:1280px){
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
  .reports-mini-grid{grid-template-columns:repeat(3,1fr)}
  .tile-grid{grid-template-columns:repeat(2,1fr)}
  .filter-grid{grid-template-columns:repeat(2,1fr)}
  .hero-card,.content-grid-2col{grid-template-columns:1fr}
  .page-head-card{flex-wrap:wrap}
}

/* ========== RESPONSIVE 920 (TABLET) ========== */
@media(max-width:920px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-100%;top:0;bottom:0;z-index:50;width:280px;height:100vh;transition:.25s ease}
  .sidebar.open{left:0}
  .sidebar.open~.sidebar-overlay,.sidebar-overlay.is-open{display:block}
  .mobile-only{display:inline-flex}
  .topbar{padding:12px 14px}
  .page-content{padding:12px;padding-bottom:80px}
  .page-content>section,
  .page-content>details.panel-card{margin-bottom:12px}
  .content-grid-2col,.reports-mini-grid,.tile-grid,.form-grid-2col,.kv-grid{grid-template-columns:1fr}
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
  /* Filter: 2 kolom kiri–kanan, baris berikutnya ke bawah (bukan 1 kolom) */
  .filter-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px;align-items:end}
  .filter-card .filter-card-body .filter-grid .form-actions,
  .filter-card .filter-card-body .filter-grid .form-actions.full,
  .filter-card > form.filter-grid .form-actions,
  .filter-card > form.filter-grid .form-actions.full{grid-column:1/-1}
  .products-filter-grid .field{min-width:0}
  .products-filter-grid .form-actions,
  .products-search-field{grid-column:1/-1}
  .products-filter-grid .form-actions{justify-content:space-between;flex-direction:row;align-items:stretch;gap:8px}
  .products-filter-grid .form-actions .btn{flex:1;min-width:0;width:auto}
  .bulk-form-grid{grid-template-columns:1fr}
  .bulk-qty-list{grid-template-columns:1fr}
  .bottom-navbar{display:flex}
  .hero-card{grid-template-columns:1fr}
  .modal-detail-grid{grid-template-columns:1fr}
  .invoice-paper{width:100%}
  .invoice-meta{grid-template-columns:1fr}
  .label-presets-grid{grid-template-columns:repeat(2,1fr)}
}

/* ========== RESPONSIVE 680 (MOBILE) ========== */
@media(max-width:680px){
  .hero-title,.section-title{font-size:20px}
  .page-title{font-size:16px}
  .stat-value{font-size:18px}
  .stat-card{padding:12px 14px}
  .stat-card::after{width:50px;height:50px}
  .topbar-right{gap:4px}
  .topbar-badges{display:none}
  .page-head-card{padding:14px 16px;border-radius:var(--radius-lg);flex-direction:column;gap:10px}
  .page-head-actions{width:100%}
  .hero-card,.panel-card,.stat-card{border-radius:var(--radius-lg)}
  .panel-card{padding:14px}
  .page-content{padding:10px;padding-bottom:80px}
  .page-content>section,
  .page-content>details.panel-card{margin-bottom:10px}
  .label-sheet{grid-template-columns:1fr}
  .thermal-paper{width:100%}
  .data-table th,.data-table td{padding:8px 10px;font-size:12px}
  .field input,.field select,.field textarea{padding:10px 12px;font-size:13px}
  .btn{padding:9px 12px;font-size:12px}
  .btn-sm{padding:7px 10px;font-size:11px}
  .action-icon{width:30px;height:30px}
  .kv-grid>div{padding:10px 12px}
  .kv-grid strong{font-size:13px}
  .summary-item,.mini-list-item{padding:8px 10px}
  .filter-card:not(.is-filter-card-enhanced){padding:12px}
  .filter-card-toggle{padding:12px 14px;font-size:13px}
  .filter-card-body{padding:0 14px 12px 14px}
  .filter-card-body .filter-grid .field{min-width:0}
  .products-filter-grid .field{min-width:0}
  .products-filter-grid .form-actions{gap:8px;flex-direction:row;align-items:stretch;justify-content:space-between;flex-wrap:nowrap}
  .products-filter-grid .form-actions .btn{flex:1;min-width:0;width:auto}
  .filter-card-body .filter-grid .form-actions,
  .filter-card .filter-card-body .form-actions{display:flex;flex-direction:row;align-items:stretch;gap:8px;flex-wrap:nowrap;justify-content:space-between}
  .filter-card-body .filter-grid .form-actions .btn,
  .filter-card-body .filter-grid .form-actions a.btn{flex:1;min-width:0;width:auto;justify-content:center}
  .form-grid-2col{gap:10px}
  .dashboard-grid{gap:8px}
  .master-tabs{gap:4px}
  .master-tabs .btn{padding:6px 10px;font-size:11px}
  .mini-list.dense{max-height:360px}
  .modal-box{margin-top:16px;border-radius:var(--radius-lg)}
  .modal-header,.modal-body,.modal-footer{padding-left:16px;padding-right:16px}
  .invoice-header{padding:14px 16px;flex-direction:column;text-align:center;gap:8px}
  .invoice-body{padding:14px 16px}
}

/* ========== RESPONSIVE 480 (SMALL PHONE) ========== */
@media(max-width:480px){
  .topbar{padding:10px 12px}
  .page-title{font-size:15px}
  .hero-title{font-size:18px}
  .section-title{font-size:18px}
  .stat-value{font-size:16px}
  .stat-label{font-size:9px}
  .stat-foot{font-size:9px}
  .stat-card{padding:10px 12px;border-radius:14px}
  .page-content{padding:8px;padding-bottom:80px}
  .page-content>section,
  .page-content>details.panel-card{margin-bottom:8px}
  .panel-card{padding:12px}
  .hero-card{padding:14px 16px}
  .hero-copy{font-size:12px}
  .data-table{min-width:580px}
  .compact-table{min-width:460px}
  .bottom-nav-item{min-width:48px;padding:5px 6px}
  .bottom-nav-label{font-size:9px}
  .dashboard-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .label-presets-grid{grid-template-columns:1fr}
}

/* SWEETALERT2 GOLD THEME OVERRIDES */
.swal2-popup{border-radius:24px!important;border:1px solid #e8d3a8!important;box-shadow:0 24px 70px rgba(73,51,14,.18)!important;font-family:Arial,Helvetica,sans-serif!important}
.swal2-title{color:#2f2418!important;font-weight:800!important}
.swal2-html-container{color:#7f6a4b!important}
.swal2-confirm{background:linear-gradient(135deg,#c89b3c 0,#8c6420 100%)!important;border-radius:14px!important;padding:.7rem 1.2rem!important;font-weight:700!important;border:none!important}
.swal2-cancel{border-radius:14px!important;padding:.7rem 1.2rem!important;font-weight:700!important}
.swal2-icon{border-color:#e8d3a8!important}

/* CHART CANVAS WRAP */
.chart-canvas-wrap{position:relative;width:100%;overflow:hidden}
.chart-canvas-wrap canvas{width:100%!important;border:none;background:transparent;border-radius:var(--radius-md)}

/* FAB (Floating Action Button) — pill penuh, warna per aksi */
.fab-container{position:fixed;bottom:24px;right:24px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.fab-menu{display:flex;flex-direction:column;align-items:flex-end;gap:10px;opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:.25s cubic-bezier(.4,0,.2,1)}
.fab-container.is-open .fab-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.fab-item{
  display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:#fff;font-weight:800;font-size:12px;white-space:nowrap;
  padding:5px 18px 5px 5px;border-radius:999px;border:1px solid rgba(255,255,255,.32);
  box-shadow:0 8px 22px rgba(45,35,20,.22);
  transition:transform .18s ease,box-shadow .18s ease;
}
.fab-item:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(45,35,20,.28)}
.fab-item span[data-lucide]{
  width:40px;height:40px;flex-shrink:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.26);box-shadow:inset 0 1px 0 rgba(255,255,255,.4);
  transition:transform .15s ease;
}
.fab-item:hover span[data-lucide]{transform:scale(1.06)}
.fab-label{background:transparent;padding:0 2px 0 0;border-radius:0;box-shadow:none;font-size:12px;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.12)}
.fab-item.fab-gold{background:linear-gradient(135deg,#f7c14d 0%,#d97706 55%,#b45309 100%)}
.fab-item.fab-emerald{background:linear-gradient(135deg,#4ade80 0%,#16a34a 50%,#15803d 100%)}
.fab-item.fab-violet{background:linear-gradient(135deg,#c4b5fd 0%,#8b5cf6 45%,#5b21b6 100%)}
.fab-item.fab-navy{background:linear-gradient(135deg,#93c5fd 0%,#3b82f6 50%,#1e40af 100%)}
.fab-item.fab-charcoal{background:linear-gradient(135deg,#94a3b8 0%,#475569 50%,#1e293b 100%)}
.fab-item.fab-rose{background:linear-gradient(135deg,#fda4af 0%,#f43f5e 50%,#be123c 100%)}
.fab-item svg,.fab-toggle svg{width:20px;height:20px;stroke:#fff;color:#fff;stroke-width:2.2}
.fab-toggle{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;background:linear-gradient(135deg,#c89b3c,#8c6420);color:#fff;box-shadow:0 8px 24px rgba(140,100,32,.28);display:flex;align-items:center;justify-content:center;transition:.3s ease}
.fab-toggle:hover{transform:scale(1.06);box-shadow:0 10px 30px rgba(140,100,32,.35)}
.fab-container.is-open .fab-toggle{transform:rotate(45deg);background:linear-gradient(135deg,#b34444,#8b2525)}
.fab-container.is-open .fab-icon-open{display:none}
.fab-container.is-open .fab-icon-close{display:flex!important}

@media(max-width:920px){
  .fab-container{bottom:80px;right:16px}
}

/* BARCODE MINI IN TABLE */
.bc-mini{display:inline-block;vertical-align:middle}
.bc-mini svg{display:block}
[data-qr-text] canvas{max-width:100%;height:auto}

/* PRODUCTS OPERATIONAL TABLE (desktop: grid lebar; jangan ditaruh setelah @media agar tidak menimpa mobile) */
@media (min-width: 921px) {
  .products-filter-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .products-search-field{grid-column:span 2}
}
.products-status-nav-card{padding:14px 16px}
.products-status-nav-label{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.products-status-nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:9px 14px;border-radius:999px;font-size:13px;font-weight:700;border:1px solid #e4ca90;background:rgba(255,248,233,.92);color:var(--gold-deep);transition:.15s ease;white-space:nowrap}
.status-pill:hover{background:#fff5dc;border-color:var(--gold);transform:translateY(-1px)}
.status-pill.is-active{background:linear-gradient(135deg,var(--gold) 0,var(--gold-deep) 100%);color:#fff;border-color:transparent;box-shadow:0 6px 14px rgba(140,100,32,.2)}
.products-filter-details.filter-card{padding:0;overflow:visible}
.products-filter-summary{display:flex;align-items:center;gap:8px;cursor:pointer;list-style:none;padding:14px 16px;font-size:14px;font-weight:700;color:var(--text)}
.products-filter-summary::-webkit-details-marker{display:none}
.products-filter-details[open] .products-filter-summary{border-bottom:1px solid var(--line-soft);background:rgba(255,252,248,.65)}
.products-filter-summary-hint{font-weight:500;color:var(--muted);font-size:12px}
.products-filter-details .filter-grid{padding:12px 16px 16px}
.shell-excel-scroll{max-height:min(72vh,720px);overflow:auto;-webkit-overflow-scrolling:touch}
.table-excel{border-collapse:separate;border-spacing:0}
.table-excel thead th{position:sticky;top:0;z-index:3;background:linear-gradient(180deg,#f3e8d6 0,#e9dcc8 100%);border-bottom:2px solid #c9a66a;color:#4a3824;font-weight:800;box-shadow:0 1px 0 rgba(255,255,255,.4) inset}
.table-excel tbody tr:nth-child(even){background:#faf7f2}
.table-excel tbody tr:hover{background:#fff4e0}
.table-excel th,.table-excel td{border-right:1px solid #ede4d4}
.table-excel th:last-child,.table-excel td:last-child{border-right:none}
.table-excel td{font-variant-numeric:tabular-nums}

/* Kolom Aksi: tetap di kanan saat scroll horizontal */
.table-excel thead th.col-actions{
  position:sticky;
  right:0;
  top:0;
  z-index:5;
  min-width:152px;
  text-align:right;
  box-shadow:-6px 0 10px -4px rgba(74,56,36,.12);
}
.table-excel tbody td.col-actions{
  position:sticky;
  right:0;
  z-index:2;
  min-width:152px;
  text-align:right;
  box-shadow:-6px 0 10px -4px rgba(74,56,36,.1);
}
.table-excel tbody tr:nth-child(odd) td.col-actions{background:#fff}
.table-excel tbody tr:nth-child(even) td.col-actions{background:#faf7f2}
.table-excel tbody tr:hover td.col-actions{background:#fff4e0}
.products-toolbar-print{align-items:stretch}
.products-export-details{position:relative}
.products-export-summary{list-style:none;cursor:pointer}
.products-export-summary::-webkit-details-marker{display:none}
.products-export-menu{position:absolute;left:0;top:calc(100% + 6px);min-width:240px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);padding:6px;z-index:35;display:grid;gap:2px}
.products-export-link{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text)}
.products-export-link:hover{background:#fff5e6}
.products-toolbar-hint{font-size:12px!important;line-height:1.5!important;margin:8px 0 0!important;color:var(--muted)!important}
.products-toolbar{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.products-toolbar-left,.products-toolbar-right{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.products-subbar{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:12px;color:var(--muted);margin:8px 0 12px;padding:10px 12px;background:rgba(255,250,242,.85);border:1px solid var(--line-soft);border-radius:var(--radius-sm)}
.products-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:0 0 14px;padding-top:4px}
@media(max-width:920px){
  .products-summary-grid{grid-template-columns:1fr;gap:10px}
}
.products-summary-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--line);box-shadow:var(--shadow-sm);min-width:0;transition:transform .15s ease,box-shadow .15s ease}
.products-summary-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.products-summary-icon{flex-shrink:0;width:42px;height:42px;border-radius:14px;display:grid;place-items:center;color:var(--gold-deep)}
.products-summary-main{display:grid;gap:5px;min-width:0;flex:1}
.products-summary-label{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;line-height:1.25}
.products-summary-value{font-size:20px;font-weight:800;line-height:1.15;color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.products-summary-foot{display:block;margin:2px 0 0;font-size:11px;font-weight:600;line-height:1.35;color:inherit;opacity:.82}
.products-summary-card--pcs{background:linear-gradient(145deg,#f0f7ff 0,#e8f1fb 96%);border-color:#bcd7f1}
.products-summary-card--pcs .products-summary-label{color:#1f4e79}
.products-summary-card--pcs .products-summary-value{color:#0f3558}
.products-summary-card--pcs .products-summary-foot{color:#356391}
.products-summary-card--pcs .products-summary-icon{background:linear-gradient(145deg,#dbeafe,#bfdbfe);color:#1d4ed8;box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.products-summary-card--weight{background:linear-gradient(145deg,#fff9ed 0,#ffefd8 92%);border-color:#e9c986}
.products-summary-card--weight .products-summary-label{color:#7a5820}
.products-summary-card--weight .products-summary-value{color:#55380b}
.products-summary-card--weight .products-summary-foot{color:#8c6d30}
.products-summary-card--weight .products-summary-icon{background:linear-gradient(145deg,rgba(255,230,178,.95),rgba(232,183,106,.42));color:var(--gold-deep);box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.products-summary-card--money{background:linear-gradient(145deg,#f0fdf6 0,#dcfce8 94%);border-color:#8fd4ae}
.products-summary-card--money .products-summary-label{color:#16643a}
.products-summary-card--money .products-summary-value{color:#065f46}
.products-summary-card--money .products-summary-foot{color:#1c7d52}
.products-summary-card--money .products-summary-icon{background:linear-gradient(145deg,#d1fae5,#a7f3d0);color:#059669;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.products-summary-card--sale{background:linear-gradient(145deg,#faf8ff 0,#eee8ff 94%);border-color:#c9b8f5}
.products-summary-card--sale .products-summary-label{color:#5b2bb0}
.products-summary-card--sale .products-summary-value{color:#4c1d95}
.products-summary-card--sale .products-summary-foot{color:#6b3ac9}
.products-summary-card--sale .products-summary-icon{background:linear-gradient(145deg,#ede9fe,#ddd6fe);color:#6d28d9;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
@media(max-width:680px){
  .products-summary-value{font-size:18px}
  .products-summary-icon{width:40px;height:40px;border-radius:12px}
}
.products-table{min-width:1780px}
.product-code-card{display:grid;gap:4px;min-width:145px}
.product-barcode-box{padding:4px 6px;border:1px dashed var(--line);border-radius:8px;background:#fff;max-width:160px}
.product-barcode-box .label-barcode{border-color:var(--line);padding:4px 0 2px}
.product-barcode-box .label-barcode svg,.product-barcode-box .label-barcode canvas{display:block;max-width:100%;height:auto;margin:0 auto}
.product-barcode-box .bc-num{font-family:'Courier New',monospace;font-size:9px;letter-spacing:.5px}
.product-thumb{width:52px;height:52px;object-fit:cover;border-radius:8px;border:1px solid var(--line-soft)}
.product-thumb-placeholder{width:52px;height:52px;border-radius:8px;border:1px dashed var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);background:#faf7f0}
.products-pagination{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.pagination-chip{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;font-size:12px;background:#fff}
.pagination-chip.active{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;border-color:transparent}

/* PRODUCT SHOW — 2 kolom + timeline + foto lightbox */
.product-show-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(268px,360px);gap:14px;align-items:start;margin-bottom:16px}
.product-show-main .modal-section:last-child{margin-bottom:0}
.product-show-aside{display:flex;flex-direction:column;gap:14px;position:sticky;top:14px}
.product-show-photo-card{padding:14px;display:flex;flex-direction:column;min-height:0}
.product-show-photo-hit{width:100%;padding:0;border:none;background:none;border-radius:var(--radius-md);cursor:zoom-in;position:relative;display:block;line-height:0;transition:box-shadow .2s ease}
.product-show-photo-hit:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.product-show-photo-hit:hover{box-shadow:0 8px 24px rgba(74,56,36,.14)}
.product-show-photo-img{width:100%;max-height:min(420px,55vh);object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--line-soft)}
.product-show-photo-hit-hint{display:flex;align-items:center;justify-content:center;gap:6px;position:absolute;left:0;right:0;bottom:0;padding:28px 10px 10px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.85);pointer-events:none;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));border-radius:0 0 var(--radius-md) var(--radius-md)}
.product-show-photo-empty{min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;font-size:13px;font-weight:600;color:var(--muted);background:linear-gradient(180deg,#faf7f2,#f5efe6);border:1px dashed var(--line);border-radius:var(--radius-md);padding:20px}
.product-show-barcode{margin-top:12px;margin-bottom:0;padding:10px 8px}
.product-show-barcode svg{max-width:100%;height:auto}
.product-show-barcode canvas{display:block;margin:0 auto}
.product-show-barcode .bc-text{font-size:12px;letter-spacing:.04em}

.product-show-history-card{padding:0;overflow:hidden}
.product-show-history-head{display:flex;align-items:flex-start;gap:12px;padding:16px 16px 12px;background:linear-gradient(135deg,#fffbf5 0%,#fff7eb 85%);border-bottom:1px solid var(--line-soft)}
.product-show-history-icon{flex-shrink:0;width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(145deg,rgba(200,155,60,.35),rgba(200,155,60,.08));border:1px solid rgba(200,155,60,.38);color:var(--gold-deep)}
.product-show-history-title{margin:0 0 2px;font-size:14px;font-weight:800;line-height:1.25;color:#3d2f1f}
.product-show-history-sub{margin:0;font-size:11px;font-weight:600;color:var(--muted);opacity:.92}

.product-history-timeline{margin:0;padding:14px 16px 18px;display:grid;gap:0;list-style:none;padding-inline-start:0}
.product-history-row{position:relative;display:grid;gap:6px;margin:0;padding:0 0 16px 0;border-left:2px solid #e9dcc8;margin-left:9px;padding-left:20px;padding-bottom:14px}
.product-history-row:last-child{border-left-color:transparent;padding-bottom:0}
.product-history-row::before{content:'';position:absolute;left:-6px;top:6px;width:10px;height:10px;border-radius:50%;background:linear-gradient(145deg,var(--gold),#a67d32);border:2px solid #fffaf1;box-shadow:0 0 0 1px rgba(200,155,60,.35)}
.product-history-time{font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--muted);margin:0 0 2px}
.product-history-body{display:grid;gap:8px;background:#fffdfa;border:1px solid var(--line-soft);border-radius:12px;padding:10px 12px;box-shadow:0 1px 4px rgba(74,56,36,.06)}
.product-history-flow{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:2px 0 0}
.product-history-flow .badge{font-size:10px;line-height:1.2;text-transform:none;letter-spacing:.02em;font-weight:800}
.product-history-arrow{color:#c89b3c;opacity:.9;display:inline-flex;line-height:0}
.product-history-notes{margin:0;font-size:12px;font-weight:600;line-height:1.45;color:#5c4d3d}
.product-history-flow + .product-history-notes{margin-top:6px;padding-top:10px;border-top:1px dashed #efe4d4}
.product-history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:28px 16px;color:var(--muted);font-weight:600;font-size:13px}

.product-photo-lightbox-overlay{padding:24px!important;align-items:center!important;justify-content:center!important;background:rgba(20,17,13,.76)!important;backdrop-filter:blur(8px)!important}
.product-photo-lightbox-inner{margin-top:0!important;max-width:min(940px,calc(100vw - 32px));background:transparent!important;box-shadow:none!important;padding:8px!important;animation:modalIn .28s ease;position:relative}
.product-photo-lightbox-inner .modal-close{background:rgba(255,252,246,.94);border-radius:999px;top:16px!important;right:16px!important;width:44px;height:44px;box-shadow:var(--shadow-sm)}
.product-photo-lightbox-img{max-width:100%;max-height:calc(100vh - 120px);width:auto;margin:0 auto;display:block;border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.2);box-shadow:0 16px 50px rgba(0,0,0,.52)}

@media(max-width:900px){
  .product-show-layout{grid-template-columns:1fr}
  .product-show-aside{position:static;order:-1}
}

/* BULK PRINT MODAL */
.products-print-modal{max-width:940px;max-height:calc(100vh - 56px);display:flex;flex-direction:column}
.products-print-modal .modal-body{overflow:hidden;display:flex;flex-direction:column}
.products-print-modal .modal-footer{position:sticky;bottom:0;background:#fff;z-index:2}
.bulk-print-footer{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;align-items:center}
.bulk-print-switch{display:flex;gap:8px;margin-bottom:10px}
.bulk-print-switch .btn.active{background:linear-gradient(135deg,var(--gold) 0,var(--gold-deep) 100%);color:#fff;border-color:transparent}
.bulk-print-hint{margin:0 0 10px;font-size:12px;line-height:1.45;color:var(--muted)}
.bulk-form-quick{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(min-width:800px){
  .bulk-form-quick{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(min-width:1024px){
  .bulk-form-quick{grid-template-columns:repeat(4,minmax(0,1fr))}
}
.field-inline-unit{display:flex;align-items:center;gap:6px;min-width:0}
.field-inline-unit input{flex:1;min-width:0}
.field-inline-unit abbr{cursor:help;text-decoration:none;font-size:11px;color:var(--muted);width:22px;text-align:left}
.bulk-form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.bulk-preview-scroll{margin-top:8px;max-height:min(52vh,460px);overflow:auto;padding-right:4px}
.bulk-preview-title{margin:12px 0 8px;font-size:12px;font-weight:800;color:var(--gold-deep);text-transform:uppercase;letter-spacing:.05em}
.bulk-preview-wrap{background:#f7efe4;border:1px solid var(--line);border-radius:10px;padding:12px;min-height:120px;overflow:auto}
.bulk-grid{display:grid}
.bulk-label-card{background:#fff;border:1px solid #111;border-radius:6px;display:grid;gap:2px}
.bulk-code{font-size:8pt;font-weight:700}
.bulk-bc{border-top:1px dashed #333;border-bottom:1px dashed #333;padding:1mm 0;text-align:center}
.bulk-bc svg{max-width:100%;height:auto}
.bulk-name{font-size:8pt;line-height:1.1}
.bulk-meta{font-size:7pt;color:#444}
.bulk-price{font-size:8.5pt;font-weight:800}
.bulk-qty-editor{margin-top:10px}
.bulk-qty-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.bulk-advanced-panel{margin-top:8px;border:1px solid var(--line);border-radius:10px;background:#fff}
.bulk-advanced-panel summary{cursor:pointer;list-style:none;padding:10px 12px;font-size:12px;font-weight:800;color:var(--gold-deep)}
.bulk-advanced-panel summary::-webkit-details-marker{display:none}
.bulk-advanced-panel[open] summary{border-bottom:1px solid var(--line-soft)}
.bulk-advanced-panel .bulk-form-grid{padding:10px}
.label-name{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* SETTINGS PRINT LAYOUT */
.settings-print-stack{display:grid;gap:12px}
.settings-print-stack .panel-card{margin:0}
.settings-print-intro{display:flex;align-items:center;gap:8px;background:#fff8ef;border:1px solid var(--line);color:#7f6a4b;padding:10px 12px;border-radius:12px;font-size:12px;font-weight:600}
.settings-print-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);padding:10px 12px;border-radius:12px}
.settings-print-search input{width:100%;border:none;outline:none;background:transparent;font-size:13px;color:#2f2418}
.settings-print-search input::placeholder{color:#9b8a72}
.settings-print-search .btn{white-space:nowrap}
.settings-accordion-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.settings-accordion-item .panel-card.form-panel{border:none;border-radius:0;box-shadow:none}
.settings-accordion-summary{list-style:none;cursor:pointer;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(180deg,#fffcf7 0,#fff8ef 100%);border-bottom:1px solid transparent}
.settings-accordion-summary::-webkit-details-marker{display:none}
.settings-acc-main{display:flex;align-items:flex-start;gap:10px;min-width:0}
.settings-acc-copy{display:grid;gap:2px;min-width:0}
.settings-acc-copy strong{font-size:14px;color:#3f2f1a;line-height:1.35}
.settings-acc-copy small{font-size:11px;color:var(--muted);line-height:1.5}
.settings-acc-chevron{transition:transform .2s ease;color:#6b5a3f}
.settings-accordion-item[open] .settings-accordion-summary{border-bottom-color:var(--line-soft)}
.settings-accordion-item[open] .settings-acc-chevron{transform:rotate(180deg)}
.settings-accordion-item.is-filtered-out{display:none}

/* DESKTOP: keep sidebar fixed, content scrolls */
@media(min-width:921px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;z-index:40}
  .app-shell{display:block}
  .app-main{margin-left:260px;min-height:100vh}
}

@media(max-width:920px){
  .products-print-modal{max-height:calc(100vh - 24px)}
  .bulk-preview-scroll{max-height:min(48vh,420px)}
}

.product-filter-toolbar{
  display:flex;flex-wrap:wrap;gap:8px;padding:10px 0 8px;
  border-bottom:1px solid var(--line-soft,#ead9b5);margin-bottom:6px;align-items:center;
}
.product-filter-toolbar--filters-only .filter-select{flex:1;min-width:128px}
.product-filter-toolbar--filters-only .filter-select--compact{flex:0 1 auto;min-width:96px}
.product-filter-toolbar .filter-search{
  flex:1;min-width:160px;border:1px solid #dfca9d;border-radius:var(--radius-sm);
  padding:10px 12px;background:#fff;font-size:13px;transition:.2s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.product-filter-toolbar .filter-search:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(200,155,60,.12);
}
.product-filter-toolbar .filter-select{
  border:1px solid #dfca9d;border-radius:var(--radius-sm);padding:10px 32px 10px 12px;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b5a3e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
  background-size:12px;font-size:13px;cursor:pointer;appearance:none;-webkit-appearance:none;
  min-width:128px;transition:.2s ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.8);color:var(--text,#3d2f1f);
}
.product-filter-toolbar .filter-select:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(200,155,60,.12);
}
.product-filter-toolbar .filter-select--compact{min-width:96px}

@media print{
  .print-actions,.bottom-navbar,.no-print{display:none!important}
  .invoice-paper{box-shadow:none;width:100%}
  .thermal-paper{box-shadow:none}
  .print-stage{padding:0}
  .label-card{break-inside:avoid;page-break-inside:avoid}
}
