@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg: #F7F4EF; --bg2: #EDE8DF; --bg3: #E2DBD0;
  --card: #FFFFFF; --border: #DDD4C0; --border2: #C5B89A;
  --text: #1C1208; --text2: #6B5840; --text3: #9E8B6E;
  --accent: #3D2208; --accent2: #7B4A18;
  --amber: #C07B10; --amber-lt: #FFF5E0; --amber-bd: #E8C060;
  --green: #1A6B3E; --green-lt: #E6F7EF; --green-bd: #82C9A4;
  --red: #8B1C1C; --red-lt: #FFF0F0; --red-bd: #F0AAAA;
  --blue: #1A4A7A; --blue-lt: #EEF5FF; --blue-bd: #90B8E8;
  --shadow: 0 1px 4px rgba(61,34,8,.08), 0 4px 16px rgba(61,34,8,.06);
  --shadow-lg: 0 8px 32px rgba(61,34,8,.14);
  --radius: 14px; --radius-sm: 9px; --radius-xs: 6px;
  --sidebar-w: 220px;
}

*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);font-family:'Inter',sans-serif;color:var(--text);font-size:14px;min-height:100vh}

/* Ã¢â€â‚¬Ã¢â€â‚¬ TOPBAR Ã¢â€â‚¬Ã¢â€â‚¬ */
.topbar{background:var(--accent);color:#FFF8EE;padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-logo{font-size:22px}
.topbar-left h1{font-size:16px;font-weight:700;letter-spacing:.2px}
.topbar-left span{font-size:11px;opacity:.55;display:block}
.topbar-right{font-size:11px;opacity:.6;font-style:italic}
.hamburger{display:none;background:rgba(255,255,255,.12);border:none;color:#FFF8EE;font-size:20px;width:36px;height:36px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}

/* Ã¢â€â‚¬Ã¢â€â‚¬ LAYOUT Ã¢â€â‚¬Ã¢â€â‚¬ */
.layout{display:flex;min-height:calc(100vh - 56px)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ SIDEBAR Ã¢â€â‚¬Ã¢â€â‚¬ */
.sidebar{width:var(--sidebar-w);background:#2B1705;flex-shrink:0;padding:12px 0;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}
.sidebar-section{padding:12px 16px 4px;font-size:10px;color:rgba(255,248,238,.3);letter-spacing:.8px;text-transform:uppercase;font-weight:600}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:rgba(255,248,238,.65);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;border-left:3px solid transparent;border-radius:0 8px 8px 0;margin-right:8px}
.nav-item:hover{background:rgba(255,255,255,.06);color:#FFF8EE}
.nav-item.active{background:rgba(240,192,96,.14);color:#F0C060;border-left-color:#F0C060}
.nav-icon{font-size:15px;width:18px;text-align:center}

/* Ã¢â€â‚¬Ã¢â€â‚¬ OVERLAY Ã¢â€â‚¬Ã¢â€â‚¬ */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100}
.sidebar-overlay.open{display:block}

/* Ã¢â€â‚¬Ã¢â€â‚¬ CONTENT Ã¢â€â‚¬Ã¢â€â‚¬ */
.content{flex:1;padding:20px;overflow-y:auto;min-width:0}
.page{display:none}.page.active{display:block}

/* Ã¢â€â‚¬Ã¢â€â‚¬ PAGE HEADER Ã¢â€â‚¬Ã¢â€â‚¬ */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.page-title{font-size:18px;font-weight:700;color:var(--accent)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ CARDS Ã¢â€â‚¬Ã¢â€â‚¬ */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow)}
.card-title{font-size:14px;font-weight:700;color:var(--accent);margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ STAT GRID Ã¢â€â‚¬Ã¢â€â‚¬ */
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.stat-icon{font-size:26px;flex-shrink:0}
.stat-val{font-size:24px;font-weight:700;color:var(--accent2);line-height:1}
.stat-label{font-size:11px;color:var(--text3);margin-top:3px;text-transform:uppercase;letter-spacing:.4px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ MATRIX Ã¢â€â‚¬Ã¢â€â‚¬ */
.matrix-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.matrix-grid{display:grid;gap:0}
.matrix-header{padding:7px 10px;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;background:var(--bg2);border-bottom:1px solid var(--border)}
.matrix-label{padding:10px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--bg2);font-size:13px}
.matrix-val{padding:10px;text-align:right;border-bottom:1px solid var(--bg2);font-weight:700;color:var(--accent2);font-size:13px;white-space:nowrap}
.produk-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.text-right{text-align:right}

/* Ã¢â€â‚¬Ã¢â€â‚¬ MINI CARDS (dashboard) Ã¢â€â‚¬Ã¢â€â‚¬ */
.mini-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--bg2)}
.mini-item:last-child{border-bottom:none}
.mini-info{flex:1;min-width:0}
.mini-title{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-sub{font-size:11px;color:var(--text3);margin-top:2px}
.mini-prices{display:flex;align-items:center;gap:6px;flex-shrink:0}
.price-old{color:var(--text3);text-decoration:line-through;font-size:12px}
.price-new{color:var(--green);font-weight:700;font-size:13px}
.arrow{color:var(--amber);font-size:14px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ PRODUK CARDS Ã¢â€â‚¬Ã¢â€â‚¬ */
.produk-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;box-shadow:var(--shadow);flex-wrap:wrap}
.produk-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.produk-info{flex:1;min-width:0}
.produk-nama{font-weight:700;font-size:15px}
.produk-desk{font-size:12px;color:var(--text3);margin-top:2px}
.produk-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* Ã¢â€â‚¬Ã¢â€â‚¬ TABS Ã¢â€â‚¬Ã¢â€â‚¬ */
.tabs-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.ptab{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:transparent;color:var(--text2);transition:all .15s;white-space:nowrap;user-select:none}
.ptab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.ptab:hover:not(.active){background:var(--bg2)}
.empty-tabs{font-size:12px;color:var(--text3)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ HPP HERO Ã¢â€â‚¬Ã¢â€â‚¬ */
.hpp-hero{background:linear-gradient(135deg,var(--accent) 0%,#6B3010 100%);border-radius:var(--radius);padding:22px 24px;color:#FFF8EE;margin-bottom:16px;box-shadow:var(--shadow-lg);transition:opacity .2s}
.hpp-hero.loading{opacity:.5}
.hpp-hero h2{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;opacity:.6;margin-bottom:4px;font-weight:500}
.hpp-val{font-size:44px;font-weight:700;color:#F0C060;line-height:1;margin-bottom:4px}
.hpp-sub{font-size:12px;opacity:.65;margin-bottom:14px}
.hpp-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.hpp-break-item{background:rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:10px 12px}
.hpp-break-item .bl{font-size:9px;letter-spacing:.5px;text-transform:uppercase;opacity:.6;margin-bottom:4px;font-weight:500}
.hpp-break-item .bv{font-size:15px;font-weight:700;color:#F0C060}

/* Ã¢â€â‚¬Ã¢â€â‚¬ SIMULASI BOX Ã¢â€â‚¬Ã¢â€â‚¬ */
.sim-box{background:var(--amber-lt);border:1.5px solid var(--amber-bd);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px}
.sim-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow)}
.sim-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.sim-nama{flex:1;font-weight:700;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sim-meta{font-size:11px;color:var(--text3);margin-bottom:10px}
.sim-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}
.sim-stat{background:var(--bg2);border-radius:var(--radius-xs);padding:8px 10px}
.sim-stat-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px}
.sim-stat-val{font-size:14px;font-weight:700;color:var(--text);margin-top:2px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ RESEP GRID Ã¢â€â‚¬Ã¢â€â‚¬ */
.resep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.resep-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow)}
.resep-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.resep-nama-input{flex:1;font-weight:600;font-size:14px;border:none;border-bottom:1.5px solid var(--border2);border-radius:0;background:transparent;padding:2px 4px;color:var(--text);outline:none}
.resep-nama-input:focus{border-bottom-color:var(--amber)}
.resep-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.resep-catatan{grid-column:1/-1}

/* Ã¢â€â‚¬Ã¢â€â‚¬ TABLE Ã¢â€â‚¬Ã¢â€â‚¬ */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{padding:8px 12px;background:var(--bg2);color:var(--text3);font-size:10px;letter-spacing:.5px;font-weight:600;text-transform:uppercase;border-bottom:1px solid var(--border)}
.tbl td{padding:9px 12px;border-bottom:1px solid var(--bg2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--bg)}
.tbl td.money{text-align:right;font-weight:700;color:var(--accent2)}
.tbl td.note{color:var(--text3);font-size:11px;font-style:italic}
.tbl .total-row td{background:var(--amber-lt)!important;font-weight:700;border-top:2px solid var(--amber-bd)}
.tbl .total-row td.money{color:var(--accent);font-size:15px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ FORM Ã¢â€â‚¬Ã¢â€â‚¬ */
input[type=text],input[type=number],select,textarea{border:1px solid var(--border);border-radius:var(--radius-xs);padding:7px 10px;font-size:13px;font-family:'Inter',sans-serif;background:var(--card);color:var(--text);outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(192,123,16,.12)}
select{cursor:pointer}
.input-inline{border:1px solid transparent;border-radius:var(--radius-xs);padding:4px 8px;font-size:13px;background:transparent;color:var(--text);transition:border-color .15s;font-family:'Inter',sans-serif;width:100%}
.input-inline:focus{border-color:var(--amber);background:var(--card)}
.w-full{width:100%}
.text-right{text-align:right}
.field-label{display:block;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.field-group{display:flex;flex-direction:column}

/* Ã¢â€â‚¬Ã¢â€â‚¬ BUTTONS Ã¢â€â‚¬Ã¢â€â‚¬ */
.btn{padding:8px 16px;border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:1.5px solid transparent;display:inline-flex;align-items:center;gap:6px;line-height:1}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-primary{background:var(--accent);color:#FFF8EE;border-color:var(--accent)}
.btn-primary:hover{background:#2B1705}
.btn-amber{background:var(--amber);color:#fff}
.btn-amber:hover{background:#9A620C}
.btn-success{background:var(--green-lt);color:var(--green);border-color:var(--green-bd)}
.btn-success:hover{background:#C8F0DC}
.btn-danger{background:var(--red-lt);color:var(--red);border-color:var(--red-bd)}
.btn-danger:hover{background:#FFD8D8}
.btn-outline{background:transparent;color:var(--text2);border-color:var(--border)}
.btn-outline:hover{background:var(--bg2)}
.btn-secondary{background:var(--bg2);color:var(--text2);border-color:var(--border)}
.btn-secondary:hover{background:var(--bg3)}
.btn-icon{background:transparent;color:var(--text3);border:none;padding:5px 8px;cursor:pointer;border-radius:var(--radius-xs);font-size:16px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.btn-icon:hover{background:var(--bg2)}
.btn-icon-danger:hover{background:var(--red-lt);color:var(--red)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ BADGES / CHIPS Ã¢â€â‚¬Ã¢â€â‚¬ */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap}
.badge-green{background:var(--green-lt);color:var(--green)}
.badge-amber{background:var(--amber-lt);color:var(--amber)}
.badge-red{background:var(--red-lt);color:var(--red)}
.badge-blue{background:var(--blue-lt);color:var(--blue)}
.chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.chip-normal{background:#E8F4FF;color:#1A4A7A}
.chip-espresso{background:#FFF0DC;color:#8B5000}
.chip-packaging{background:#F0FFF4;color:#1A6B3E}
.chip-overhead{background:var(--blue-lt);color:var(--blue)}
.chip-kopi{background:#F5EBE0;color:#7B4A18}
.chip-creamer,.chip-susu{background:#F0F8FF;color:#1A4A7A}
.chip-pemanis{background:#FFFBE6;color:#8B6B00}
.chip-lainnya{background:var(--bg2);color:var(--text2)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ INFO BOX Ã¢â€â‚¬Ã¢â€â‚¬ */
.info-box{background:var(--amber-lt);border-left:3px solid var(--amber-bd);border-radius:0 var(--radius-xs) var(--radius-xs) 0;padding:10px 14px;font-size:12px;color:var(--text2);margin-bottom:14px;line-height:1.6}

/* Ã¢â€â‚¬Ã¢â€â‚¬ ACTION ROW Ã¢â€â‚¬Ã¢â€â‚¬ */
.action-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ MARGIN BAR Ã¢â€â‚¬Ã¢â€â‚¬ */
.margin-bar-wrap{background:var(--bg2);border-radius:8px;height:8px;overflow:hidden}
.margin-bar{height:100%;border-radius:8px;transition:width .4s,background .4s}

/* Ã¢â€â‚¬Ã¢â€â‚¬ HISTORI ITEM Ã¢â€â‚¬Ã¢â€â‚¬ */
.histori-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);margin-bottom:8px;box-shadow:var(--shadow);flex-wrap:wrap}

/* Ã¢â€â‚¬Ã¢â€â‚¬ TOAST Ã¢â€â‚¬Ã¢â€â‚¬ */
.toast{position:fixed;bottom:24px;right:24px;background:var(--green);color:#fff;padding:11px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);z-index:9999;transform:translateY(60px);opacity:0;transition:all .25s}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:var(--red)}

/* Ã¢â€â‚¬Ã¢â€â‚¬ MODAL Ã¢â€â‚¬Ã¢â€â‚¬ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open,.modal-overlay[style*="flex"]{display:flex}
.modal-box{background:var(--card);border-radius:var(--radius);padding:24px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}
.modal-title{font-size:16px;font-weight:700;color:var(--accent);margin-bottom:18px}
.modal-fields{display:grid;gap:12px;margin-bottom:18px}
.modal-row{display:flex;flex-direction:column;gap:4px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ EMPTY STATE Ã¢â€â‚¬Ã¢â€â‚¬ */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text3);gap:10px}
.empty-icon{font-size:40px;opacity:.6}
.empty-state-sm{padding:12px;color:var(--text3);font-size:13px;text-align:center}

/* Ã¢â€â‚¬Ã¢â€â‚¬ LOADING Ã¢â€â‚¬Ã¢â€â‚¬ */
.loading-text{text-align:center;padding:30px;color:var(--text3);font-style:italic}

/* Ã¢â€â‚¬Ã¢â€â‚¬ COLORS Ã¢â€â‚¬Ã¢â€â‚¬ */
.text-green{color:var(--green)!important}
.text-red{color:var(--red)!important}
.text-accent{color:var(--accent2)!important}

/* Ã¢â€â‚¬Ã¢â€â‚¬ GRID UTILS Ã¢â€â‚¬Ã¢â€â‚¬ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.flex{display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.align-center{align-items:center}.flex-wrap{flex-wrap:wrap}

/* Ã¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢Â
   MOBILE RESPONSIVE
Ã¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢ÂÃ¢â€¢Â */
@media(max-width:700px){
  .hamburger{display:flex}
  .sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-w);z-index:200;transform:translateX(-100%);transition:transform .28s ease;padding-top:56px}
  .sidebar.open{transform:translateX(0)}
  .content{padding:12px}
  .card{padding:14px 14px}
  .hpp-val{font-size:34px}
  .hpp-breakdown{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .resep-grid{grid-template-columns:1fr!important}
  .grid-2{grid-template-columns:1fr!important;gap:12px}
  .produk-card{gap:10px}
  .sim-stats{grid-template-columns:1fr 1fr}

  /* STACKED TABLES - tabel normal berubah jadi kartu di mobile */
  .tbl,.tbl thead,.tbl tbody,.tbl th,.tbl td,.tbl tr{display:block}
  .tbl thead tr{position:absolute;top:-9999px;left:-9999px}
  .tbl tr{border:1px solid var(--border);margin-bottom:10px;border-radius:var(--radius-sm);background:var(--card);overflow:hidden}
  .tbl td{position:relative;padding:11px 12px 11px 42%;border:none;border-bottom:1px solid var(--bg2);text-align:right;min-height:40px;display:flex;justify-content:flex-end;align-items:center;gap:8px}
  .tbl td:last-child{border-bottom:none}
  .tbl td::before{position:absolute;top:50%;left:12px;transform:translateY(-50%);width:36%;text-align:left;font-weight:600;color:var(--text3);font-size:10px;text-transform:uppercase;letter-spacing:.5px}
  .tbl td input,.tbl td select{max-width:140px;text-align:right}
  .total-row td{background:var(--amber-lt)!important;flex-direction:column;align-items:flex-end}
  .total-row td::before{content:"TOTAL HPP"!important;font-size:10px}

  /* tbl-scroll: tabel tetap scroll horizontal, tidak di-stack */
  .tbl-scroll,.tbl-scroll thead,.tbl-scroll tbody,
  .tbl-scroll th,.tbl-scroll td,.tbl-scroll tr{display:revert}
  .tbl-scroll thead tr{position:static}
  .tbl-scroll tr{border:none;margin-bottom:0;border-radius:0;overflow:visible}
  .tbl-scroll td{position:static;padding:9px 10px;min-height:unset;display:table-cell;text-align:left;border-bottom:1px solid var(--bg2)}
  .tbl-scroll td.text-right{text-align:right}
  .tbl-scroll td::before{display:none}
  .tbl-scroll tr:hover td{background:var(--bg)}
  .tbl-scroll tfoot td{background:var(--amber-lt);font-weight:700}
  .tbl-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}

  #hpp-detail-table td:nth-child(1)::before{content:"Komponen"}
  #hpp-detail-table td:nth-child(2)::before{content:"Tipe"}
  #hpp-detail-table td:nth-child(3)::before{content:"Catatan"}
  #hpp-detail-table td:nth-child(4)::before{content:"Biaya"}
  /* preset-bahan-table dan overhead-table kini pakai .cell-label HTML spans -- tidak perlu ::before */
  #preset-bahan-table td::before{display:none!important;content:none!important}
  #overhead-table td::before{display:none!important;content:none!important}
  #bahan-table td::before{display:none!important;content:none!important}

  /* Neutralize .tbl generic mobile styles untuk row yg pakai grid card baru */
  /* (bahan-row, preset-bahan-row, overhead-row sudah punya display:grid & flex column di masing-masing td) */
  .bahan-row, .preset-bahan-row, .overhead-row {display:grid!important}
  .bahan-row td, .preset-bahan-row td, .overhead-row td {
    position:static!important;
    padding:8px 10px!important;
    text-align:left!important;
    justify-content:flex-start!important;
    min-height:auto!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:flex-start!important;
  }
  .bahan-row td input, .bahan-row td select,
  .preset-bahan-row td input, .preset-bahan-row td select,
  .overhead-row td input, .overhead-row td select {
    max-width:none!important;
    text-align:left!important;
    width:100%!important;
  }
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ ORDERAN Ã¢â€â‚¬Ã¢â€â‚¬ */
.ord-summary-bar { display:flex;gap:0;flex-wrap:wrap }
.ord-sum-item { flex:1;text-align:center;padding:8px 12px;border-right:1px solid var(--border);min-width:80px }
.ord-sum-item:last-child { border-right:none }
.ord-sum-val { font-size:20px;font-weight:700;color:var(--accent);line-height:1 }
.ord-sum-label { font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-top:3px }

.ord-day-group { margin-bottom:20px }
.ord-day-header { display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg2);border-radius:var(--radius-xs);margin-bottom:8px;font-size:13px;font-weight:600;color:var(--text2) }

.ord-card { background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);margin-bottom:8px;overflow:hidden }
.ord-card-top { display:flex;align-items:center;gap:12px;padding:12px 14px }
.ord-avatar { width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--amber));color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0 }
.ord-info { flex:1;min-width:0 }
.ord-nama { font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.ord-meta { font-size:11px;color:var(--text3);margin-top:2px }
.ord-total { font-size:16px;font-weight:700;color:var(--accent);flex-shrink:0 }
.ord-actions { display:flex;gap:4px;flex-shrink:0 }

.form-item-row { display:flex;gap:10px;align-items:flex-start;padding:12px;background:var(--bg2);border-radius:var(--radius-sm);margin-bottom:8px;flex-wrap:wrap }

.detail-item { display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--bg2) }
.detail-item:last-child { border-bottom:none }

/* Ã¢â€â‚¬Ã¢â€â‚¬ CUAN Ã¢â€â‚¬Ã¢â€â‚¬ */
.cuan-produk-row { display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--bg2) }
.cuan-produk-row:last-child { border-bottom:none }

@media(max-width:700px) {
  .ord-card-top { flex-wrap:wrap;gap:8px }
  .ord-total { font-size:15px }
  .form-item-row { flex-direction:column }
  .content{padding:10px}
  .hpp-breakdown{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}

  /* overhead-table kini pakai .cell-label HTML spans -- tidak perlu ::before */
  #overhead-table td::before{display:none!important;content:none!important}
}

@media(max-width:420px){
  .topbar{padding:0 12px}
  .topbar-left h1{font-size:14px}
  .topbar-left span{display:none}
  .content{padding:10px}
  .hpp-breakdown{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
}

/* -- PWA -- */
.pwa-hidden{display:none!important}


/* -- BAHAN PAGE -- */
#bahan-add-form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end}
@media(max-width:700px){
  #bahan-add-form{grid-template-columns:1fr 1fr;}
  #bahan-add-form button{grid-column:1/-1;}
}
@media(max-width:420px){
  #bahan-add-form{grid-template-columns:1fr;}
}

/* Ã¢â€â‚¬Ã¢â€â‚¬ SKELETON LOADING Ã¢â€â‚¬Ã¢â€â‚¬ */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton-wrap{display:flex;flex-direction:column;gap:10px;padding:4px 0}
.skeleton-row{display:flex;gap:10px;align-items:center}
.skeleton-block{height:36px;flex:1;border-radius:var(--radius-xs);background:linear-gradient(90deg,var(--bg2) 25%,var(--bg3) 50%,var(--bg2) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite}
.skeleton-block.short{flex:0 0 80px}
.skeleton-block.tall{height:80px}
.skeleton-block.circle{flex:0 0 40px;width:40px;height:40px;border-radius:50%}

/* Ã¢â€â‚¬Ã¢â€â‚¬ UPDATE BANNER Ã¢â€â‚¬Ã¢â€â‚¬ */
#update-banner{animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Ã¢â€â‚¬Ã¢â€â‚¬ UNDO TOAST Ã¢â€â‚¬Ã¢â€â‚¬ */
.toast.undo-toast{background:var(--amber)!important;color:var(--accent)!important;font-weight:600;min-width:260px}

/* Ã¢â€â‚¬Ã¢â€â‚¬ DARK MODE Ã¢â€â‚¬Ã¢â€â‚¬ */
[data-theme="dark"]{
  --bg:#1A1410;--bg2:#231C16;--bg3:#2D2419;
  --card:#2B2018;--border:#3D3025;--border2:#5A4535;
  --text:#F5EDE0;--text2:#C4A882;--text3:#8A7260;
  --accent:#C07B10;--accent2:#E8A830;
  --shadow:0 1px 4px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
  --shadow-lg:0 8px 32px rgba(0,0,0,.5)
}
[data-theme="dark"] .topbar{background:#0F0A06}
[data-theme="dark"] .sidebar{background:#0F0A06}
[data-theme="dark"] body{background:var(--bg);color:var(--text)}
[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea{background:var(--bg2);color:var(--text);border-color:var(--border)}
[data-theme="dark"] .hpp-hero{background:linear-gradient(135deg,#1A0D00 0%,#3D2000 100%)}
[data-theme="dark"] .matrix-header{background:var(--bg2)}
[data-theme="dark"] .tbl th{background:var(--bg2)}
[data-theme="dark"] .info-box{background:rgba(192,123,16,.12)}
[data-theme="dark"] .sim-box{background:rgba(192,123,16,.08)}
[data-theme="dark"] .stat-card,[data-theme="dark"] .card,[data-theme="dark"] .ord-card,[data-theme="dark"] .sim-card{background:var(--card);border-color:var(--border)}

/* MOBILE CARD TABLE - Bahan, Preset & Overhead */
@media(max-width:700px){
  /* Force semua target tabel jadi block */
  #bahan-table, #bahan-table tbody,
  #preset-bahan-table, #preset-bahan-table tbody,
  #overhead-table, #overhead-table tbody{
    display:block!important;
    width:100%!important;
  }
  #bahan-table thead, #preset-bahan-table thead,
  #overhead-table thead{ display:none!important; }

  /* Setiap row jadi kartu grid 2 kolom */
  .bahan-row, .preset-bahan-row, .overhead-row{
    display:grid!important;
    grid-template-columns:1fr 1fr;
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    margin-bottom:10px;
    background:var(--card);
    box-shadow:var(--shadow);
    overflow:hidden;
    width:100%!important;
  }

  /* Setiap td = flex column: label di atas, kontrol di bawah */
  .bahan-row td, .preset-bahan-row td, .overhead-row td{
    display:flex!important;
    flex-direction:column!important;
    align-items:flex-start!important;
    padding:8px 10px!important;
    border-bottom:1px solid var(--bg2)!important;
    border-right:1px solid var(--bg2)!important;
    gap:4px;
    min-height:60px;
    width:auto!important;
    box-sizing:border-box;
  }
  /* Hapus border kanan kolom kanan */
  .bahan-row td:nth-child(even),
  .preset-bahan-row td:nth-child(even),
  .overhead-row td:nth-child(even){ border-right:none!important; }

  /* Input & select penuh lebar */
  .bahan-row input, .bahan-row select,
  .preset-bahan-row input, .preset-bahan-row select,
  .overhead-row input, .overhead-row select{
    width:100%!important; max-width:none!important; min-width:0!important;
    font-size:13px!important; text-align:left!important;
    padding:4px 6px!important; height:32px!important;
    box-sizing:border-box!important;
  }

  /* Sel Nama / Nama Bahan: selalu span 2 kolom */
  .bahan-row td[data-label="Nama Bahan"],
  .preset-bahan-row td[data-label="Nama Bahan"],
  .overhead-row td[data-label="Nama Biaya"]{
    grid-column:1/-1;
    border-right:none!important;
    min-height:auto;
  }

  /* Aksi: span 2 kolom, tombol horizontal */
  .bahan-row td[data-label="Aksi"],
  .preset-bahan-row td[data-label="Aksi"],
  .overhead-row td[data-label="Aksi"]{
    grid-column:1/-1;
    flex-direction:column!important;
    border-right:none!important;
    border-bottom:none!important;
    min-height:52px; padding:8px 10px!important;
  }
  .bahan-row td[data-label="Aksi"] div,
  .preset-bahan-row td[data-label="Aksi"] div,
  .overhead-row td[data-label="Aksi"] div{
    display:flex!important; gap:8px; flex-wrap:wrap; align-items:center;
  }
  .bahan-row td[data-label="Aksi"] .btn,
  .preset-bahan-row td[data-label="Aksi"] .btn,
  .overhead-row td[data-label="Aksi"] .btn{ flex-shrink:0; }

} /* end @media max-width:700px */

/* Label kecil (cell-label) - visible di mobile via HTML span */
.cell-label{
  font-size:9px;
  font-weight:800;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.7px;
  line-height:1;
  display:block;
  margin-bottom:2px;
}
/* Sembunyikan cell-label di layar besar (hanya butuh di mobile) */
@media(min-width:701px){ .cell-label{ display:none; } }