: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 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)}

/* 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)}
.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%}

/* 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)}
.stat-icon{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;margin-bottom:6px;color:#fff}
.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}

/* FILTERS & FORMS */
.filter-card{padding: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 .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-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}
.label-name{font-size:14px;font-weight:700;line-height:1.2}
.label-meta{font-size:11px}
.label-barcode{text-align:center;padding:6px 0 3px;border-top:1px dashed #555;border-bottom:1px dashed #555}
.label-barcode svg{max-width:100%;height:auto}
.label-barcode .bc-num{font-family:'Courier New',monospace;font-size:10px;letter-spacing:1px;margin-top:2px}
.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}
  .content-grid-2col,.dashboard-grid,.reports-mini-grid,.tile-grid,.filter-grid,.form-grid-2col,.kv-grid{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}
  .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{padding:12px}
  .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}
  .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) */
.fab-container{position:fixed;bottom:24px;right:24px;z-index:38;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:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;font-weight:700;font-size:13px;white-space:nowrap}
.fab-item span[data-lucide]{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.18);transition:.15s ease}
.fab-item:hover span[data-lucide]{transform:scale(1.08)}
.fab-label{background:rgba(47,36,24,.88);padding:6px 12px;border-radius:8px;font-size:12px;box-shadow:var(--shadow-sm)}
.fab-item.fab-emerald span[data-lucide]{background:linear-gradient(135deg,#22c55e,#16a34a)}
.fab-item.fab-violet span[data-lucide]{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}
.fab-item.fab-navy span[data-lucide]{background:linear-gradient(135deg,#3b82f6,#2563eb)}
.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}

@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}
}
