.topbar-right{display:flex;align-items:center;gap:12px}

/* Desktop: sempre mostrar menu */
@media (min-width: 769px) {
  .topbar-right { display: flex !important; }
  .icon-btn { display: none !important; }
}

.nav{display:flex;gap:8px;align-items:center}
.icon-link{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid var(--border);color:var(--text);text-decoration:none;font-size:18px;transition:all .3s ease;cursor:pointer}
.icon-link .mobile-text{display:none}
.icon-link:hover{border-color:rgba(255,255,255,.14)}
.icon-link.active{border-color:rgba(107,138,253,.3);background:rgba(107,138,253,.08)}
.icon-gear{display:block}
.pill.active{border-color:rgba(107,138,253,.3);background:rgba(107,138,253,.08)}
.stock-add{display:flex;gap:12px;align-items:end;justify-content:space-between;margin-bottom:10px}
.stock-add label{flex:1}
.stock-add-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end}
.actions-cell{white-space:nowrap;text-align:right}
:root{
  --bg:#111318;
  --card:#1a1d24;
  --border:rgba(255,255,255,.07);
  --text:#c8c8cd;
  --muted:#71717a;
  --primary:#6b8afd;
  --primary2:#5471e0;
  --danger:#d4716b;
  --success:#5bb98c;
  --accent:#c9944e;
}
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);position:relative}
.container{max-width:1050px;margin:0 auto;padding:16px;animation:fadeInUp .6s ease}
.topbar{position:sticky;top:0;background:rgba(17,19,24,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:1000;transition:all .3s ease}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative}
.brand{display:flex;flex-direction:column}
.title{font-weight:700;font-size:18px;letter-spacing:-.3px;color:var(--text)}
.subtitle{color:var(--muted);font-size:13px}
.topbar .nav{align-items:center}

/* Header: estilo de abas (tabs) para navegação no topbar */
.topbar .nav .pill,
.topbar .nav .icon-link{
  background:transparent;
  border:0;
  border-bottom:2px solid transparent;
  border-radius:0;
  width:auto;
  height:auto;
  padding:8px 12px;
  min-height:unset;
  height:auto;
  color:var(--muted);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.topbar .nav .pill:hover,
.topbar .nav .icon-link:hover{
  color:var(--primary);
  background:transparent;
}
.topbar .nav .pill.active,
.topbar .nav .icon-link.active{
  color:var(--primary);
  border-bottom-color:var(--primary);
  background:transparent;
}

/* Profile icon + tooltip in topbar */
.profile-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;padding:6px;border:0;background:transparent;color:var(--muted);cursor:pointer}
.profile-btn:hover{color:var(--primary)}
.profile-tooltip{position:absolute;right:0;top:48px;min-width:220px;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--card);box-shadow:0 6px 18px rgba(0,0,0,.18);z-index:110;display:none}
.profile-tooltip[aria-hidden="false"]{display:block}
.profile-tooltip-email{font-size:13px;color:var(--text);margin-bottom:8px;word-break:break-all}
.profile-tooltip .pill{display:inline-block;padding:6px 10px;border-radius:8px}


.lang-switch{display:flex;gap:8px}
.pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border:1px solid var(--border);border-radius:10px;color:var(--text);text-decoration:none;font-size:14px;transition:all .2s ease;cursor:pointer;min-height:40px}
.pill:hover{border-color:rgba(107,138,253,.3)}
.icon-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:rgba(2,6,23,.35);color:var(--text);cursor:pointer;transition:all .3s ease;font-size:15px}
.icon-btn:hover{border-color:rgba(255,255,255,.14)}
.icon-btn-bars{width:16px;height:2px;background:var(--text);display:inline-block;position:relative;border-radius:999px;opacity:.9}
.icon-btn-bars:before,.icon-btn-bars:after{content:"";position:absolute;left:0;width:16px;height:2px;background:var(--text);border-radius:999px}
.icon-btn-bars:before{top:-6px}
.icon-btn-bars:after{top:6px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.12);margin-top:16px;transition:border-color .2s ease}
.card:hover{border-color:rgba(255,255,255,.12)}
.section-title{margin:16px 0 10px 0;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.form label{display:flex;flex-direction:column;gap:6px;animation:fadeInUp .5s ease}
.form label>span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
input,select{background:rgba(2,6,23,.65);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);outline:none;transition:all .15s ease}
input:focus,select:focus{border-color:rgba(107,138,253,.5);box-shadow:0 0 0 2px rgba(107,138,253,.1);background:rgba(2,6,23,.9)}
input::placeholder{color:rgba(255,255,255,.2)}
.rm-icon-display{margin-top:6px;position:relative;width:100%}
.rm-icon-preview{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;background:rgba(107,138,253,.1);border:2px solid rgba(107,138,253,.3);border-radius:8px;color:rgba(107,138,253,.9);font-size:22px;margin-bottom:6px}
.rm-icon-picker{position:absolute;top:100%;left:0;right:auto;z-index:1000;display:none;grid-template-columns:repeat(5,1fr);gap:8px;padding:16px;border-radius:12px;border:1px solid var(--border);background:var(--card);box-shadow:0 12px 32px rgba(0,0,0,.15);width:320px;margin-top:8px}
.rm-icon-picker.is-open{display:grid}
.rm-icon-option{position:relative;display:flex;align-items:center;justify-content:center;height:48px;border-radius:8px;border:1px solid var(--border);background:rgba(255,255,255,.02);color:var(--text);cursor:pointer;transition:all .15s ease;font-size:18px}
.rm-icon-option:hover{border-color:var(--primary);background:rgba(var(--primary-rgb),0.1)}
.rm-icon-option.is-selected{border-color:var(--primary);background:rgba(var(--primary-rgb),0.2);font-weight:600}
.rm-icon-option::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:rgba(17,19,24,.95);color:#fff;padding:6px 10px;border-radius:6px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:20}
.rm-icon-option::before{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid rgba(17,19,24,.95);opacity:0;transition:opacity .15s ease;z-index:19}
.rm-icon-option:hover::after,.rm-icon-option:hover::before{opacity:1}
.rm-icon-option:hover::after,.rm-icon-option:hover::before{opacity:1}
.rm-icon-option:hover::after,.rm-icon-option:hover::before{opacity:1}
.rm-icon-inline{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:rgba(255,255,255,.05);margin-right:8px;font-size:14px}
.textarea{width:100%;background:rgba(2,6,23,.65);border:1px solid var(--border);border-radius:12px;padding:12px;color:var(--text);outline:none;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;resize:vertical;transition:all .2s ease}
.textarea:focus{border-color:rgba(107,138,253,.4);box-shadow:0 0 0 2px rgba(107,138,253,.08);background:rgba(2,6,23,.8)}
.table{width:100%;border-collapse:separate;border-spacing:0;margin-top:8px;font-variant-numeric:tabular-nums}
.table th,.table td{padding:14px 16px;border-bottom:1px solid var(--border);transition:background .15s ease}
.table th{font-size:11px;font-weight:600;color:var(--muted);text-align:left !important;background:transparent;text-transform:uppercase;letter-spacing:0.8px;border-bottom:1px solid var(--border);user-select:none;padding-top:16px;padding-bottom:16px}
.table tr:last-child td{border-bottom:none}
.table tr{transition:background-color .15s ease}
.table tr:hover td{background-color:rgba(255,255,255,0.02)}
/* Remove override, respect user wish for left headers */
.table td.num{text-align:right;font-family:'Inter', sans-serif}
.table th.num{text-align:left !important}
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:8px;background:var(--card)}
.table-responsive .table{margin:0;border:none}
.materials tr{animation:fadeInUp .4s ease}
.materials > #addMaterialBtn{margin-top:12px}
.btn{border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;gap:8px;min-height:40px;font-size:14px}
.btn:hover{border-color:rgba(255,255,255,.14);background:rgba(255,255,255,.07)}
.btn.primary{background:var(--primary);border-color:transparent;color:#fff;font-weight:600;box-shadow:none}
.btn.primary:hover{background:var(--primary2);box-shadow:0 2px 8px rgba(107,138,253,.2)}
.btn.secondary{background:rgba(107,138,253,.1);border-color:rgba(107,138,253,.25);transition:all .15s ease}
.btn.secondary:hover{background:rgba(107,138,253,.18);border-color:rgba(107,138,253,.35)}
.btn.danger{background:rgba(212,113,107,.1);border-color:rgba(212,113,107,.25)}
.btn.danger:hover{background:rgba(212,113,107,.18);border-color:rgba(212,113,107,.35)}
.btn[disabled],.btn.is-loading{opacity:.65;cursor:not-allowed}
.btn.is-loading{position:relative;padding-right:34px}
.btn.is-loading:after{content:"";position:absolute;right:12px;top:50%;width:14px;height:14px;margin-top:-7px;border-radius:999px;border:2px solid rgba(255,255,255,.25);border-top-color:rgba(255,255,255,.75);animation:spin .7s linear infinite}
.btn-group{display:inline-flex;align-items:center;gap:8px}

/* Ensure consistent spacing between adjacent buttons / icon buttons */
.btn + .btn,
.btn + .icon-btn,
.icon-btn + .btn,
.icon-btn + .icon-btn{margin-left:8px}

/* Small helper: when buttons are grouped inside table cells without flex parents */
.actions-cell .btn{margin-left:0}
.actions-cell .btn + .btn{margin-left:8px}
.actions{display:flex;gap:10px;align-items:end;justify-content:flex-end;animation:fadeInUp .5s ease}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;animation:fadeInUp .5s ease}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;animation:fadeInUp .5s ease}
.grid4{display:grid;grid-template-columns:repeat(4, 1fr);gap:12px;animation:fadeInUp .5s ease}

/* Responsive Grids */
@media (max-width: 900px) {
  .grid2, .grid3, .grid4 { grid-template-columns: 1fr; } 
}
@media (min-width: 901px) and (max-width: 1200px) {
  .grid4 { grid-template-columns: 1fr 1fr; }
}
.inline{flex-direction:row !important;align-items:center;gap:10px;padding-top:24px}
.inline span{margin:0}
.errors{margin-top:12px;border:1px solid rgba(212,113,107,.25);background:rgba(212,113,107,.08);border-radius:10px;padding:10px;animation:fadeInUp .3s ease}
.errors ul{margin:0;padding-left:18px}
.results-header{display:flex;align-items:center;justify-content:space-between;gap:12px;animation:fadeInUp .5s ease}
.kpi{padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--card);margin-bottom:10px;transition:border-color .2s ease}
.kpi:hover{border-color:rgba(107,138,253,.2)}
.kpi-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.kpi-value{font-weight:700;font-size:22px;margin-top:4px;color:var(--text)}
.breakdown{list-style:none;padding:0;margin:0;animation:fadeInUp .5s ease}
.breakdown li{display:flex;justify-content:space-between;gap:12px;padding:10px;border-bottom:1px dashed rgba(255,255,255,.10);transition:all .2s ease;border-radius:6px}
.breakdown li:hover{background:rgba(107,138,253,.04);border-bottom-color:rgba(107,138,253,.15)}
.breakdown li:last-child{border-bottom:none}
.muted{color:var(--muted);font-size:12px}
.chart-wrap{border:1px solid var(--border);border-radius:10px;padding:10px;background:var(--card);animation:fadeInUp .4s ease;transition:border-color .2s ease;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.chart-wrap:hover{border-color:rgba(107,138,253,.2)}
.footer{padding:18px 0 26px 0}

.machine-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.machine-list{display:flex;flex-direction:column;gap:12px}
.machine-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--card);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.machine-header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:10px}
.machine-top-row{display:flex;justify-content:space-between;align-items:end;gap:10px;flex-wrap:wrap}
.machine-header-actions{display:flex;gap:8px;align-items:end}
.machine-fields{display:grid;gap:10px;margin-bottom:10px}
.machine-fields.grid3{grid-template-columns:repeat(auto-fit, minmax(140px, 1fr))}
.machine-fields.grid2{grid-template-columns:1fr 1fr}
.machine-extras{margin-top:10px}
.machine-extras-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.machine-extras-table th,.machine-extras-table td{padding:8px}

.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;animation:fadeInUp .4s ease}
.tab-btn{border:1px solid var(--border);background:rgba(2,6,23,.35);color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer;font-size:14px;transition:all .3s ease;position:relative;min-height:40px}
.tab-btn:hover{border-color:rgba(255,255,255,.14)}
.tab-btn.active{border-color:rgba(107,138,253,.35);background:rgba(107,138,253,.1)}

/* Pricing mode toggle button */
#pricingModeBtn{font-weight:600 !important}
#pricingModeBtn.primary{color:#ffffff !important}
#pricingModeBtn.primary #pricingModeText{color:#ffffff !important;text-shadow:0 1px 2px rgba(0,0,0,.3)}
#pricingModeBtn.secondary #pricingModeText{color:var(--text) !important}
.tab-panels{margin-top:12px}
.tab-panel{display:none}
.tab-panel.active{display:block}

.toast-wrap{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:10px;z-index:50;max-width:min(420px, calc(100vw - 32px))}
.toast{display:flex;gap:10px;align-items:flex-start;justify-content:space-between;padding:12px 12px;border-radius:10px;border:1px solid var(--border);background:rgba(26,29,36,.95);backdrop-filter:blur(10px);box-shadow:0 4px 16px rgba(0,0,0,.2);animation:toastIn .25s ease}
.toast.success{border-color:rgba(91,185,140,.3);background:rgba(91,185,140,.08)}
.toast.warning{border-color:rgba(201,148,78,.3);background:rgba(201,148,78,.08)}
.toast.danger{border-color:rgba(212,113,107,.3);background:rgba(212,113,107,.08)}
.toast.hide{opacity:0;transform:translateY(6px);transition:opacity .2s ease, transform .2s ease}
.toast-text{font-size:13px;line-height:1.25}
.toast-close{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;padding:0 2px}
.toast-close:hover{color:var(--text)}

.stats{display:grid;grid-template-columns:repeat(5, 1fr);gap:10px}
.stat{padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--card);transition:border-color .2s ease}
.stat:hover{border-color:rgba(107,138,253,.2)}
.stat-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.stat-value{font-weight:700;font-size:18px;margin-top:4px;color:var(--text)}

/* Modal overlay and simple modal layout for replacement of native dialogs */
.bizmaker-modal-overlay{position:fixed;inset:0;background:rgba(2,6,23,.6);display:flex;align-items:center;justify-content:center;z-index:120}
.bizmaker-modal{max-width:680px;width:calc(100% - 48px);padding:18px;border-radius:12px}
.bizmaker-modal-body{color:var(--text);font-size:14px;margin-bottom:14px;white-space:pre-wrap}
.bizmaker-modal-actions{display:flex;justify-content:flex-end;gap:10px}
.bizmaker-modal-actions .btn{min-width:84px}

/* Compact popover (tooltip-like) for short prompts */
.bizmaker-popover-wrap.bizmaker-modal-overlay{align-items:center;justify-content:center}
.bizmaker-popover-wrap .bizmaker-modal{max-width:360px;padding:14px;border-radius:12px}
.bizmaker-popover-wrap .bizmaker-modal-body{font-size:13px}
.bizmaker-popover-wrap .bizmaker-modal-actions{justify-content:flex-end;margin-top:8px}
.bizmaker-popover-wrap input[type="text"]{width:100%;box-sizing:border-box}

@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}

@media (prefers-reduced-motion: reduce){
  .toast{animation:none}
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
}

/* Utility classes */
.fade-in{animation:fadeInUp .4s ease}

/* Order expandable row styles */
.table tbody tr[data-order-id]{cursor:pointer;transition:background-color 0.2s ease}
.table tbody tr[data-order-id]:hover{background-color:rgba(107,138,253,.04)}
.table tbody tr[data-details-for]{background-color:rgba(15,23,42,.9);border-top:1px solid var(--border)}
.table tbody tr[data-details-for] td{padding:15px;animation:fadeInUp 0.3s ease}
/* Settings page styles */
.settings-section{margin-bottom:20px;padding-bottom:20px}
.settings-section:last-child{margin-bottom:0;padding-bottom:0}

.section-description{color:var(--muted);font-size:13px;margin-bottom:12px}

.setting-item{margin-bottom:16px;display:flex;flex-direction:column;gap:8px}
.setting-item label{color:var(--text);font-weight:600;font-size:13px}
.setting-item select{width:100%;max-width:400px}
.setting-item fieldset{border:none;padding:0;margin:0}
.setting-item legend{color:var(--text);font-weight:600;font-size:13px;margin-bottom:8px}

.radio-group,.checkbox-group{display:flex;flex-direction:column;gap:10px}
.radio-group label,.checkbox-group label{display:flex;align-items:center;gap:8px;color:var(--text);font-size:14px;cursor:pointer;transition:all .2s ease;user-select:none}
.radio-group label:hover,.checkbox-group label:hover{color:var(--primary)}

.radio-group input[type="radio"],.checkbox-group input[type="checkbox"]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary);transition:all .2s ease}
.radio-group input[type="radio"]:hover,.checkbox-group input[type="checkbox"]:hover{transform:scale(1.1)}

.form-control{width:100%;max-width:400px;background:rgba(2,6,23,.65);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);outline:none;transition:all .2s ease;font-family:inherit;font-size:14px}
.form-control:hover{border-color:rgba(107,138,253,.25)}
.form-control:focus{border-color:rgba(107,138,253,.5);box-shadow:0 0 0 2px rgba(107,138,253,.08);background:rgba(2,6,23,.9)}
.form-control option{background:rgba(15,23,42,.95);color:var(--text)}

.save-status{display:flex;align-items:center;gap:8px;padding:12px;border-radius:8px;background:rgba(91,185,140,.08);border:1px solid rgba(91,185,140,.2);color:var(--success);font-size:13px;transition:all .2s ease}
.save-status.error{background:rgba(212,113,107,.08);border-color:rgba(212,113,107,.25);color:var(--danger)}
.save-status.hidden{display:none}

/* Dark theme styles */
html.dark-theme{
  --bg:#0e1015;
  --card:#16181f;
  --border:rgba(255,255,255,.06);
  --text:#b8b8be;
  --muted:#62626a;
  --primary:#6b8afd;
  --primary2:#5471e0;
  --danger:#d4716b;
  --success:#5bb98c;
  --accent:#c9944e;
}

html.dark-theme body{background:var(--bg)}
html.dark-theme .topbar{background:rgba(14,16,21,.94);border-bottom-color:rgba(255,255,255,.05)}
html.dark-theme .card{background:var(--card);border-color:rgba(255,255,255,.05)}
html.dark-theme .card:hover{border-color:rgba(255,255,255,.1)}
html.dark-theme input,html.dark-theme select,html.dark-theme .textarea{background:rgba(10,12,16,.6)}
html.dark-theme input:focus,html.dark-theme select:focus,html.dark-theme .textarea:focus{background:rgba(10,12,16,.85)}

html.dark-theme .button{background:rgba(255,255,255,.06)}
html.dark-theme .btn.primary{background:var(--primary);color:#fff}
html.dark-theme .form-control{background:rgba(10,12,16,.6)}
html.dark-theme .form-control:focus{background:rgba(10,12,16,.85)}

/* Light theme */
html.light-theme{
  --bg:#f5f5f7;
  --card:#ffffff;
  --border:rgba(0,0,0,.06);
  --text:#27272a;
  --muted:#71717a;
  --primary:#4f6ce5;
  --primary2:#3d56c6;
  --danger:#c44040;
  --success:#3a9b6b;
  --accent:#b07d30;
}

html.light-theme body{background:var(--bg);color:var(--text)}
html.light-theme .topbar{background:rgba(245,245,247,.88);border-bottom-color:rgba(0,0,0,.06);box-shadow:0 1px 2px rgba(0,0,0,.04)}
html.light-theme .title{color:var(--text)}
html.light-theme .subtitle{color:var(--muted)}
html.light-theme .card{background:#fff;border-color:rgba(0,0,0,.06);box-shadow:0 1px 3px rgba(0,0,0,.05)}
html.light-theme .card:hover{border-color:rgba(0,0,0,.1)}
html.light-theme .section-title{color:var(--muted)}
html.light-theme input,html.light-theme select,html.light-theme .textarea{background:#fff;border-color:rgba(0,0,0,.1);color:var(--text)}
html.light-theme input:focus,html.light-theme select:focus,html.light-theme .textarea:focus{background:#fff;border-color:rgba(79,108,229,.5);box-shadow:0 0 0 2px rgba(79,108,229,.08)}
html.light-theme input::placeholder{color:rgba(0,0,0,.25)}
html.light-theme .tab-btn{border-color:rgba(0,0,0,.06);background:transparent;color:var(--text)}
html.light-theme .tab-btn.active{border-color:rgba(79,108,229,.3);background:rgba(79,108,229,.06)}
html.light-theme .btn{border-color:rgba(0,0,0,.08);background:rgba(0,0,0,.03);color:var(--text)}
html.light-theme .btn.primary{background:var(--primary);color:#fff}
html.light-theme .btn.secondary{background:rgba(79,108,229,.08);border-color:rgba(79,108,229,.18)}
html.light-theme .rm-icon-option{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.08);color:var(--text)}
html.light-theme .rm-icon-option:hover{border-color:var(--primary);background:rgba(79,108,229,.08)}
html.light-theme .rm-icon-option.is-selected{border-color:var(--primary);background:rgba(79,108,229,.12)}
html.light-theme .rm-icon-preview{background:rgba(79,108,229,.08);border-color:rgba(79,108,229,.2);color:var(--primary)}
html.light-theme .rm-icon-picker{background:#ffffff;box-shadow:0 8px 24px rgba(0,0,0,.1)}
html.light-theme .btn.secondary:hover{background:rgba(79,108,229,.12);border-color:rgba(79,108,229,.28)}
html.light-theme .btn.danger{background:rgba(196,64,64,.06);border-color:rgba(196,64,64,.18)}
html.light-theme .btn.danger:hover{background:rgba(196,64,64,.1);border-color:rgba(196,64,64,.28)}
html.light-theme .kpi{border-color:rgba(0,0,0,.06);background:#fff}
html.light-theme .kpi:hover{border-color:rgba(79,108,229,.2)}
html.light-theme .toast{border-color:rgba(0,0,0,.06);background:rgba(255,255,255,.96)}
html.light-theme .muted{color:var(--muted)}
html.light-theme .save-status{background:rgba(58,155,107,.06);border-color:rgba(58,155,107,.2);color:var(--success)}
html.light-theme .save-status.error{background:rgba(196,64,64,.06);border-color:rgba(196,64,64,.2);color:var(--danger)}
html.light-theme .table th{background:rgba(0,0,0,.02);color:var(--muted)}
html.light-theme .table tr:hover{background:rgba(79,108,229,.03)}
html.light-theme .table tbody tr[data-details-for]{background:#fafafa;border-top:1px solid rgba(0,0,0,.06)}
html.light-theme .machine-card{background:#fff;border-color:rgba(0,0,0,.06);box-shadow:0 1px 3px rgba(0,0,0,.05)}
html.light-theme .machine-extras-header{color:var(--muted)}
html.light-theme .machine-extras-table th{background:rgba(0,0,0,.02)}
html.light-theme .stat{background:#fff;border-color:rgba(0,0,0,.06)}
html.light-theme .chart-wrap{background:#fff;border-color:rgba(0,0,0,.06);box-shadow:0 1px 3px rgba(0,0,0,.05)}
html.light-theme .breakdown li{border-bottom:1px dashed rgba(0,0,0,.08)}
html.light-theme .breakdown li:hover{background:rgba(79,108,229,.03);border-bottom-color:rgba(79,108,229,.15)}

/* ========== MOBILE RESPONSIVE — see mobile-responsive.css for complete rules ========== */
@media (max-width: 768px) {
  /* Container & Layout */
  .container { padding: 12px; }
  .topbar-inner { flex-wrap: wrap; padding: 10px 16px; min-height: 56px; }

  /* Show hamburger menu button */
  .icon-btn { display: inline-flex !important; }
}.input-group {
  position: relative;
  display: flex;
  align-items: center;
}

/* Pricing mode row layout */
.pricing-mode-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: end;
}

.input-group input {
  padding-left: 28px; /* Space for symbol on left */
  width: 100%;
}

.input-group .currency-symbol {
  position: absolute;
  left: 10px;
  color: var(--muted);
  pointer-events: none;
  font-size: 0.9em;
  font-weight: 500;
  z-index: 2;
}

.flex-row { display: flex; flex-direction: row; }
.gap-2 { gap: 0.5rem; }

/* Improvements 2026 */
.table-tools { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; gap: 10px; }
.search-box { position: relative; max-width: 300px; width: 100%; }
.search-box input { width: 100%; padding-left: 34px; }
.search-box::before { content: '🔍'; position: absolute; left: 10px; top: 50%; transform: translateY(-50%); opacity: 0.5; font-size: 14px; pointer-events: none; }

.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; opacity: 0.7; }
.empty-icon { font-size: 32px; filter: grayscale(1); opacity: 0.5; }
.empty-icon.info::before { content: '📦'; }
.empty-icon.history::before { content: '📜'; }
.empty-text { font-size: 14px; font-weight: 500; }

@media (max-width: 768px) {
  .grid3 { grid-template-columns: 1fr; }
  .grid2 { grid-template-columns: 1fr; }
  .table-tools { flex-direction: column; align-items: stretch; }
  .search-box { max-width: 100%; }
}

@keyframes flashHighlight {
  0% { background-color: rgba(52, 211, 153, 0.4); }
  100% { background-color: transparent; }
}
.flash-highlight {
  animation: flashHighlight 2s ease-out;
}


/* Auth Pages */
.auth-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 140px);
  padding: 40px 16px;
}

.auth-card {
  width: 100%;
  max-width: 520px;
  padding: 40px 36px 36px;
  background: rgba(26, 29, 36, 0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}

/* Subtle top accent line */
.auth-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(107, 138, 253, 0.2), transparent);
  pointer-events: none;
  z-index: 0;
}

.auth-card > * {
  position: relative;
  z-index: 1;
}

/* Animate in */
.auth-animate {
  animation: authSlideUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes authSlideUp {
  from { opacity: 0; transform: translateY(24px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Logo */
.auth-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}

.auth-logo svg {
  filter: drop-shadow(0 2px 6px rgba(107, 138, 253, 0.15));
}

/* Header */
.auth-header {
  text-align: center;
  margin-bottom: 32px;
}

.auth-title {
  display: block;
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 8px;
  color: var(--text);
  letter-spacing: -0.5px;
  line-height: 1.2;
}

.auth-subtitle {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
  max-width: 300px;
  margin: 0 auto;
}

/* Auth Row (Stacked) */
.auth-row {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px;
  margin-bottom: 20px;
  width: 100%;
}
.auth-row label {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  text-align: left;
}
.auth-row .input-icon-wrap {
  width: 100%;
}

/* Input groups (legacy, kept for reference but unused in login/reg) */
.auth-card .input-group {
  margin-bottom: 22px;
}

.auth-card .input-group label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

/* Input with icon wrapper */
.input-icon-wrap {
  position: relative;
  display: block;
}

.input-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  color: var(--muted);
  pointer-events: none;
  z-index: 2;
  opacity: 0.6;
  transition: opacity 0.2s, color 0.2s;
}

.input-icon-wrap input {
  width: 100%;
  padding: 13px 44px 13px 44px;
  background: rgba(2, 6, 23, 0.5);
  font-size: 15px;
  border-radius: 12px;
  border: 1px solid var(--border);
  color: var(--text);
  transition: all 0.25s ease;
  outline: none;
}

.input-icon-wrap input::placeholder {
  color: rgba(167, 176, 192, 0.4);
}

.input-icon-wrap input:focus {
  background: rgba(2, 6, 23, 0.8);
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(107, 138, 253, 0.1);
}

.input-icon-wrap input:focus ~ .input-icon,
.input-icon-wrap input:focus + .input-icon,
.input-icon-wrap:focus-within .input-icon {
  opacity: 1;
  color: var(--primary);
}

/* Toggle password button */
.toggle-pass {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  padding: 6px;
  opacity: 0.6;
  transition: opacity 0.2s, color 0.2s;
  z-index: 2;
  border-radius: 999px;
}

.toggle-pass:hover {
  opacity: 1;
  color: var(--primary);
}

/* Auth button */
.auth-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
  font-size: 16px;
  font-weight: 700;
  margin-top: 8px;
  border-radius: 14px;
  gap: 8px;
  cursor: pointer;
  transition: all 0.25s ease;
  min-height: 50px;
}

.auth-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(107, 138, 253, 0.2);
}

.auth-btn:active:not(:disabled) {
  transform: translateY(0);
}

.auth-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.auth-btn-loader svg {
  animation: authSpin 0.8s linear infinite;
}

@keyframes authSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Alert boxes */
.auth-alert {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 8px;
  line-height: 1.5;
}

.auth-alert.alert-danger {
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #fca5a5;
}

.auth-alert.alert-success {
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.2);
  color: #86efac;
}

.auth-alert.shake {
  animation: authShake 0.4s ease;
}

@keyframes authShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

/* Footer link */
.auth-footer {
  margin-top: 28px;
  text-align: center;
  font-size: 14px;
  color: var(--muted);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding-top: 22px;
}

.auth-footer a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  transition: all 0.2s;
  margin-left: 4px;
}

.auth-footer a:hover {
  color: #93c5fd;
  text-decoration: underline;
}

/* Password strength indicator */
.password-strength {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}

.strength-bars {
  display: flex;
  gap: 4px;
  flex: 1;
}

.strength-bar {
  height: 4px;
  flex: 1;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
  transition: background 0.3s ease;
}

.strength-text {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  min-width: 55px;
  text-align: right;
  transition: color 0.3s ease;
}

/* Divider */
.or-divider {
  display: flex;
  align-items: center;
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  margin: 24px 0;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.or-divider::before, .or-divider::after {
  content: '';
  flex: 1;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.or-divider:not(:empty)::before { margin-right: 15px; }
.or-divider:not(:empty)::after { margin-left: 15px; }

/* Light theme overrides */
.light-theme .auth-card {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(0, 0, 0, 0.06);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.light-theme .auth-card::before {
  background: linear-gradient(90deg, transparent, rgba(79, 108, 229, 0.15), transparent);
}

.light-theme .input-icon-wrap input {
  background: rgba(241, 245, 249, 0.8);
  border-color: rgba(0, 0, 0, 0.1);
  color: #1e293b;
}

.light-theme .input-icon-wrap input:focus {
  background: #fff;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(79, 108, 229, 0.08);
}

.light-theme .input-icon-wrap input::placeholder {
  color: rgba(100, 116, 139, 0.5);
}

.light-theme .auth-alert.alert-danger {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.15);
  color: #dc2626;
}

.light-theme .auth-alert.alert-success {
  background: rgba(34, 197, 94, 0.08);
  border-color: rgba(34, 197, 94, 0.15);
  color: #16a34a;
}

.light-theme .strength-bar {
  background: rgba(0, 0, 0, 0.06);
}

.light-theme .auth-footer {
  border-top-color: rgba(0, 0, 0, 0.06);
}

/* Responsive */
@media (max-width: 480px) {
  .auth-wrapper { padding: 24px 12px; }
  .auth-card { padding: 28px 22px 24px; border-radius: 20px; }
  .auth-title { font-size: 24px; }
  .auth-btn { padding: 13px; font-size: 15px; }
}

/* Light card explicit helper (forces the white card regardless of body theme) */
.auth-card.light {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.06);
  box-shadow: 0 10px 40px rgba(16, 24, 40, 0.06);
}

.auth-card.light::before {
  background: radial-gradient(ellipse at 50% 0%, rgba(59,130,246,0.06) 0%, transparent 60%);
}

.auth-card.light .auth-title { color: #0f172a; }
.auth-card.light .auth-subtitle { color: #64748b; }
.auth-card.light .input-icon { color: #94a3b8; opacity: 1; }
.auth-card.light .input-icon-wrap input { background: #f8fafc; color: #0f172a; border-color: rgba(15,23,42,0.06); }
.auth-card.light .input-icon-wrap input::placeholder { color: #94a3b8; }
.auth-card.light .input-icon-wrap input:focus { box-shadow: 0 0 0 2px rgba(79,108,229,0.08); }

/* Row layout for labels on the left */
.form-row { display: flex; align-items: center; gap: 18px; }
.form-row label { width: 140px; text-transform: uppercase; font-size: 12px; color: #64748b; font-weight: 700; letter-spacing: 0.8px; }
.form-row .input-icon-wrap { flex: 1; }

/* Make inputs pill-like on light card */
.auth-card.light .input-icon-wrap input { padding: 12px 48px 12px 44px; border-radius: 999px; }

/* Prominent blue primary button for light card */
.auth-card.light .auth-btn {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(79,108,229,0.15);
}

.auth-card.light .auth-footer { color: #64748b; }
.auth-card.light .auth-footer a { color: var(--primary); }

@media (max-width: 520px) {
  .form-row { flex-direction: column; align-items: stretch; }
  .form-row label { width: 100%; margin-bottom: 6px; }
  .auth-card.light .input-icon-wrap input { border-radius: 12px; }
}


@import url('admin_styles.css');

/* --- Admin & General Utilities --- */
.d-flex{display:flex}
.flex-column{flex-direction:column}
.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}
.align-center{align-items:center}
.gap-2{gap:8px}
.gap-3{gap:12px}
.gap-4{gap:16px}
.w-100{width:100%}
.mb-2{margin-bottom:8px}
.mb-3{margin-bottom:12px}
.mb-4{margin-bottom:16px}
.mt-4{margin-top:16px}
.text-muted{color:var(--muted)}
.fw-bold{font-weight:700}
.text-center{text-align:center}

/* List Group */
.list-group{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:rgba(2,6,23,.25)}
.list-group-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text);text-decoration:none;transition:background .2s ease}
.list-group-item:last-child{border-bottom:none}
.list-group-item:hover{background:rgba(107,138,253,.04);color:var(--primary)}
.list-group-item .badge{margin-left:auto}

/* Badge */
.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff;background:var(--primary)}
.badge.secondary{background:rgba(255,255,255,.15);color:var(--muted)}

/* Pagination */
.pagination{display:flex;list-style:none;padding:0;margin:0;gap:4px}
.pagination .page-item a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);font-size:13px;transition:all .2s ease;background:rgba(2,6,23,.25)}
.pagination .page-item.active a{background:var(--primary);color:#06101f;border-color:var(--primary)}
.pagination .page-item.disabled a{opacity:.4;pointer-events:none}
.pagination .page-item a:hover:not(.active){border-color:var(--primary);color:var(--primary)}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:8px;list-style:none;padding:0;margin:0 0 16px 0;font-size:13px;color:var(--muted)}
.breadcrumb-item a{color:var(--muted);text-decoration:none;transition:color .2s ease}
.breadcrumb-item a:hover{color:var(--primary)}
.breadcrumb-item.active{color:var(--text);font-weight:600}
.breadcrumb-item + .breadcrumb-item::before{content:"/";margin-right:8px;color:rgba(255,255,255,.2)}

/* Admin specific overrides */
.admin-header{margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:16px}
.admin-card-header{padding:12px 16px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--border);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.table-responsive{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}
.table-responsive .table{border:none;border-radius:0}
.table td { vertical-align: middle; }
.search-input-group{position:relative;display:flex}
.search-input-group input{border-radius:10px 0 0 10px;border-right:none}
.search-input-group .btn{border-radius:0 10px 10px 0}

.grid2-bias-left{display:grid;grid-template-columns:2fr 1fr;gap:12px;animation:fadeInUp .5s ease}
@media (max-width:900px){.grid2-bias-left{grid-template-columns:1fr}}

.activity-list{padding:6px;max-height:250px;overflow-y:auto}
.activity-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border)}
.activity-item:last-child{border-bottom:none}
.activity-icon{font-size:18px;margin-right:10px;width:24px;text-align:center}
.activity-details{flex:1;display:flex;flex-direction:column}
.activity-title{font-weight:600;font-size:13px;color:var(--text)}
.activity-meta{font-size:11px;color:var(--muted)}
.activity-amount{font-weight:700;color:var(--text);font-size:13px}

/* Modal Styles */
.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.7); backdrop-filter: blur(5px); z-index: 2000; display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.modal-overlay.open { opacity: 1; visibility: visible; }
.modal-overlay[style*="display: flex"], .modal-overlay[style*="display:flex"] { opacity: 1; visibility: visible; }
.modal { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 30px; width: 90%; max-width: 600px; max-height: 80vh; overflow-y: auto; box-shadow: 0 8px 24px rgba(0,0,0,0.3); transform: scale(0.95); transition: transform 0.3s ease; position: relative; }
.modal-overlay.open .modal { transform: scale(1); }
.modal-content { background: var(--card-bg, #fff); border: 1px solid var(--border, #ddd); border-radius: 12px; padding: 24px; width: 90%; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.dark-theme .modal-content { background: var(--card-bg, #1e293b); }
.modal-close { position: absolute; top: 15px; right: 15px; background: none; border: none; color: var(--muted); font-size: 24px; cursor: pointer; transition: color 0.2s; }
.modal-close:hover { color: white; }
.modal-header h3 { font-size: 1.15em; }

/* Data Table (Modernized to match .table) */
.data-table { width: 100%; border-collapse: separate; border-spacing: 0; margin-top: 8px; font-variant-numeric: tabular-nums; }
.data-table th, .data-table td { padding: 14px 16px; border-bottom: 1px solid var(--border); transition: background .15s ease; }
.data-table th { font-size: 11px; font-weight: 600; color: var(--muted); text-align: left !important; background: transparent; text-transform: uppercase; letter-spacing: 0.8px; border-bottom: 1px solid var(--border); user-select: none; padding-top: 16px; padding-bottom: 16px; }
.data-table tr:hover td { background-color: rgba(255,255,255,0.02); }
.data-table tr:last-child td { border-bottom: none; }
.data-table .badge { font-size: 10px; padding: 4px 8px; border-radius: 6px; }


/* Page header */
.page-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; margin-bottom: 20px; }

/* Button sizes */
.btn-sm { padding: 3px 8px; font-size: 0.85em; }
.btn-ghost { background: transparent; border: none; cursor: pointer; color: var(--text, inherit); padding: 4px 8px; border-radius: 4px; }
.btn-ghost:hover { background: var(--bg-soft, #f0f0f0); }
.dark-theme .btn-ghost:hover { background: rgba(255,255,255,0.08); }

