*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --primary:#1a7f5a;--pk:#0f5c40;--plt:#e1f5ee;--pmd:#b2deca;
  --accent:#f5c200;--adk:#b38f00;
  --danger:#c0392b;--dlt:#fdecea;
  --warn:#e67e22;--wlt:#fef3e2;
  --bg:#f2f5f4;--surf:#fff;--s2:#f0f3f2;--s3:#e8eceb;
  --bdr:#e0e5e3;--bdr2:#c8cecc;
  --txt:#1a2220;--t2:#4a5754;--t3:#8a9896;
  --hh:60px;--nh:56px;--sbw:240px;
  --r:12px;--rs:8px;--rpill:99px;
  --shad:0 1px 4px rgba(0,0,0,.07);--shad2:0 4px 16px rgba(0,0,0,.1);
}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--txt);font-size:15px;line-height:1.5;overflow:hidden}

/* ══ LOGIN ══ */
.login-screen{position:fixed;inset:0;background:linear-gradient(135deg,var(--pk) 0%,var(--primary) 60%,#2ea87a 100%);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}
.login-box{background:var(--surf);border-radius:20px;padding:28px 24px;width:100%;max-width:360px;box-shadow:var(--shad2)}
.login-logo{text-align:center;margin-bottom:24px}
.login-logo-icon{font-size:48px;margin-bottom:8px}
.login-brand{font-size:22px;font-weight:700;color:var(--txt)}
.login-sub{font-size:13px;color:var(--t3);margin-top:2px}
.login-error{color:var(--danger);font-size:13px;margin-top:8px;min-height:18px;text-align:center}
.login-footer{text-align:center;font-size:11px;color:var(--t3);margin-top:16px}

/* ══ APP LAYOUT ══ */
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:1100px;margin:0 auto;position:relative;background:var(--bg)}

/* ══ HEADER ══ */
.header{background:var(--primary);height:var(--hh);display:flex;align-items:center;justify-content:space-between;padding:0 14px;flex-shrink:0;z-index:30;gap:10px}
.hdr-left{display:flex;align-items:center;gap:10px}
.hdr-menu-btn{background:rgba(255,255,255,.15);border:none;color:#fff;font-size:18px;cursor:pointer;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand{font-size:16px;font-weight:700;color:#fff}
.hdr-sub{font-size:11px;color:rgba(255,255,255,.7)}
.hdr-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.sync-pill{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.15);border-radius:var(--rpill);padding:4px 9px;flex-shrink:0}
.sync-pill span:last-child{font-size:11px;color:#fff}
.sdot{width:7px;height:7px;border-radius:50%;background:#888;flex-shrink:0}
.sdot.online{background:var(--accent);animation:pulse 2s infinite}
.sdot.synced{background:#5ce878;animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hdr-user-btn{background:rgba(255,255,255,.15);border:none;color:#fff;font-size:12px;font-weight:600;cursor:pointer;border-radius:var(--rpill);padding:5px 11px;white-space:nowrap;font-family:inherit}

/* ══ USER MENU ══ */
.user-menu{position:absolute;top:calc(var(--hh) + 6px);right:12px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--shad2);z-index:100;min-width:180px;overflow:hidden}
.user-menu-info{padding:12px 14px;border-bottom:1px solid var(--bdr);font-size:13px}
.user-menu-item{display:block;width:100%;text-align:left;padding:11px 14px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--txt);font-family:inherit}
.user-menu-item:hover{background:var(--s2)}
.user-menu-item.red{color:var(--danger)}

/* ══ SIDEBAR ══ */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:39;display:none}
.sidebar-overlay.show{display:block}
.sidebar{position:fixed;top:0;left:0;width:var(--sbw);height:100%;background:var(--surf);box-shadow:var(--shad2);z-index:40;transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto;display:flex;flex-direction:column}
.sidebar.open{transform:translateX(0)}
.sidebar-header{background:var(--primary);padding:20px 16px 16px;flex-shrink:0}
.sidebar-brand{color:#fff;font-size:16px;font-weight:700}
.sidebar-version{color:rgba(255,255,255,.6);font-size:11px;margin-top:2px}
.sidebar-section{font-size:10px;font-weight:700;color:var(--t3);letter-spacing:.7px;text-transform:uppercase;padding:14px 16px 6px}
.sb-item{display:block;width:100%;text-align:left;padding:11px 16px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--t2);font-family:inherit;border-left:3px solid transparent;transition:all .15s}
.sb-item:hover{background:var(--s2);color:var(--txt)}
.sb-item.active{background:var(--plt);color:var(--primary);border-left-color:var(--primary);font-weight:600}

/* ══ BOTTOM NAV ══ */
.bot-nav{display:flex;background:var(--surf);border-top:1px solid var(--bdr);height:var(--nh);flex-shrink:0;z-index:20}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--t3);min-width:0;padding:4px 2px;font-family:inherit}
.nb svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nb span{font-size:9px;font-weight:500;white-space:nowrap}
.nb.active{color:var(--primary)}

/* ══ MAIN / TABS ══ */
#main{flex:1;overflow:hidden;position:relative}
.tab{position:absolute;inset:0;display:none;flex-direction:column}
.tab.active{display:flex}
.scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:14px 14px 0}
.scroll::-webkit-scrollbar{width:4px}
.scroll::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:4px}

/* ══ TYPOGRAPHY / LABELS ══ */
.page-title{font-size:18px;font-weight:700;color:var(--txt)}
.field-label{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.mb12{margin-bottom:12px}.mt8{margin-top:8px}.mt10{margin-top:10px}.mt12{margin-top:12px}.mt14{margin-top:14px}.mt16{margin-top:16px}.mb10{margin-bottom:10px}
.opt{font-size:10px;font-weight:400;background:var(--s2);border-radius:4px;padding:1px 5px;text-transform:none;letter-spacing:0;margin-left:4px}
.pb{height:14px}

/* ══ TOOLBAR ══ */
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:8px;flex-wrap:wrap}
.tb-left{display:flex;align-items:center;gap:10px}
.tb-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.search-input{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rpill);padding:7px 12px;font-size:13px;color:var(--txt);font-family:inherit;outline:none;width:120px}
.search-input:focus{border-color:var(--primary)}
.date-filter{width:140px;padding:7px 12px;font-size:13px}

/* ══ INPUTS ══ */
.txt-input{width:100%;background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--rs);padding:10px 12px;font-size:14px;color:var(--txt);font-family:inherit;outline:none;transition:border-color .15s;appearance:none;-webkit-appearance:none}
.txt-input:focus{border-color:var(--primary);background:#fff}
.txt-input::placeholder{color:var(--t3)}
select.txt-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a9896' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}
.row2{display:flex;gap:10px}
input[type="file"].txt-input{padding:8px 12px;font-size:13px}

/* ══ CAR CARDS ══ */
.car-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.car-card{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:13px 6px 10px;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:all .15s;font-family:inherit}
.car-ico{font-size:26px;line-height:1}
.car-card span:last-child{font-size:13px;font-weight:500;color:var(--t2)}
.car-card.sel{border-color:var(--primary);background:var(--plt)}
.car-card.sel span:last-child{color:var(--primary)}

/* ══ SERVICE ITEMS ══ */
.svc-item{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--rs);padding:11px 13px;display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;cursor:pointer;transition:all .15s}
.svc-item.sel{border-color:var(--primary);background:var(--plt)}
.svc-lft{display:flex;flex-direction:column;gap:2px}
.svc-nm{font-size:14px;font-weight:500}
.svc-item.sel .svc-nm{color:var(--pk)}
.svc-tag{font-size:11px;color:var(--t3)}
.svc-price-badge{background:var(--s2);border-radius:7px;padding:4px 10px;font-size:14px;font-weight:700;color:var(--t2);white-space:nowrap;transition:all .15s}
.svc-item.sel .svc-price-badge{background:var(--primary);color:#fff}
.vip-chip{display:inline-block;background:var(--accent);color:#5a3d00;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;margin-left:5px}

/* ══ ORDER SUMMARY ══ */
.order-summary{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--r);padding:13px;margin-top:14px}
.sum-title{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:9px}
.sum-line{display:flex;justify-content:space-between;padding:4px 0;font-size:14px;color:var(--t2)}
.sum-div{height:1px;background:var(--bdr);margin:9px 0}
.sum-total-row{display:flex;justify-content:space-between;font-size:16px;font-weight:600}
.sum-total{color:var(--primary);font-size:18px}

/* ══ BUTTONS ══ */
.btn-cta{width:100%;background:var(--primary);color:#fff;border:none;border-radius:var(--r);padding:13px;font-size:15px;font-weight:700;cursor:pointer;margin-top:13px;transition:background .15s;font-family:inherit}
.btn-cta:hover:not(:disabled){background:var(--pk)}
.btn-cta:disabled{background:var(--t3);opacity:.5;cursor:not-allowed}
.btn-cta.sm{padding:9px 18px;width:auto;margin-top:0;font-size:14px;border-radius:var(--rs)}
.btn-sm-green{background:var(--primary);color:#fff;border:none;border-radius:var(--rs);padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.btn-outline{background:none;border:1px solid var(--bdr2);border-radius:var(--rs);padding:8px 14px;font-size:13px;color:var(--t2);cursor:pointer;font-family:inherit;width:100%}
.btn-outline-sm{background:none;border:1px solid var(--bdr2);border-radius:var(--rs);padding:5px 12px;font-size:13px;color:var(--t2);cursor:pointer;font-family:inherit}
.btn-cancel{background:none;border:1px solid var(--bdr);border-radius:var(--rs);padding:9px 18px;font-size:14px;color:var(--t2);cursor:pointer;font-family:inherit}
.btn-dashed{width:100%;background:none;border:1.5px dashed var(--pmd);border-radius:var(--rs);padding:10px;font-size:14px;color:var(--primary);cursor:pointer;margin-top:6px;font-family:inherit;font-weight:500}
.btn-dashed:hover{background:var(--plt)}
.btn-danger{width:100%;background:none;border:1px solid #f5b8b8;border-radius:var(--rs);padding:10px;font-size:14px;color:var(--danger);cursor:pointer;font-family:inherit}
.btn-danger.red{border-color:var(--danger)}

/* ══ PILLS & TAGS ══ */
.green-pill{background:var(--primary);color:#fff;font-size:13px;font-weight:700;padding:4px 12px;border-radius:var(--rpill);white-space:nowrap}
.red-pill{background:var(--danger);color:#fff;font-size:13px;font-weight:700;padding:4px 12px;border-radius:var(--rpill)}
.amber-pill{background:var(--accent);color:#5a3d00;font-size:13px;font-weight:700;padding:4px 12px;border-radius:var(--rpill)}
.tag{font-size:11px;background:var(--s2);border-radius:4px;padding:2px 7px;color:var(--t3)}
.tag.vip{background:#fff8d6;color:var(--adk);font-weight:700}
.tag.admin{background:#e8f4fd;color:#1a6fa8;font-weight:600}
.tag.manager{background:#f0e8fd;color:#6a1a9a;font-weight:600}

/* ══ MONTH NAV ══ */
.month-nav-row{display:flex;align-items:center;justify-content:space-between;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:8px 12px;margin-bottom:12px}
.nav-arrow{background:none;border:none;font-size:22px;color:var(--t2);cursor:pointer;padding:0 6px;line-height:1;font-family:inherit}
.nav-label{font-size:14px;font-weight:600;color:var(--txt)}
.period-bar{display:flex;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rpill);padding:3px;margin-bottom:10px}
.period-btn{flex:1;padding:8px;border:none;background:none;border-radius:var(--rpill);font-size:14px;font-weight:500;color:var(--t2);cursor:pointer;font-family:inherit;transition:all .15s}
.period-btn.active{background:var(--primary);color:#fff}

/* ══ KPI ══ */
.kpi-row{display:flex;gap:9px;overflow-x:auto;padding-bottom:2px}
.kpi-row::-webkit-scrollbar{display:none}
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
.kpi-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:13px;box-shadow:var(--shad);flex-shrink:0;min-width:130px}
.kpi-val{font-size:20px;font-weight:800;color:var(--txt)}
.kpi-val.g{color:var(--primary)}
.kpi-val.r{color:var(--danger)}
.kpi-val.a{color:var(--adk)}
.kpi-lbl{font-size:11px;color:var(--t3);margin-top:2px}

/* ══ CHARTS ══ */
.chart-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:13px;box-shadow:var(--shad)}
.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.bar-lbl{font-size:11px;color:var(--t2);width:90px;flex-shrink:0;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;height:22px;background:var(--s2);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;display:flex;align-items:center;justify-content:flex-end;padding-right:7px;min-width:24px;transition:width .5s ease}
.bar-fill.g{background:var(--primary)}.bar-fill.r{background:#e24b4a}.bar-fill.a{background:var(--accent)}
.bar-val{font-size:10px;font-weight:700;color:#fff}.bar-val.dk{color:#5a3d00}
.line-chart{height:110px;display:flex;align-items:flex-end;gap:3px;padding:4px 0 22px;position:relative}
.line-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.line-bar{width:100%;border-radius:3px 3px 0 0;background:var(--primary);min-height:3px;transition:height .4s ease}
.line-x{font-size:9px;color:var(--t3);text-align:center;white-space:nowrap;overflow:hidden;width:100%}
.legend{display:flex;gap:12px;margin-bottom:10px;font-size:12px;color:var(--t2);flex-wrap:wrap}
.leg-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;display:inline-block;margin-right:4px}

/* ══ RECORDS / CARDS ══ */
.rec-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:12px 13px;margin-bottom:8px;box-shadow:var(--shad);position:relative}
.rec-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:5px}
.rec-id{font-size:11px;color:var(--t3)}
.plate-chip{display:inline-block;background:var(--s2);border:1px solid var(--bdr);border-radius:4px;padding:2px 7px;font-size:12px;font-weight:600;color:var(--t2);letter-spacing:.4px;margin-top:3px}
.rec-amt{font-size:20px;font-weight:800;color:var(--primary)}
.rec-svcs{font-size:13px;color:var(--t2);margin-bottom:5px;line-height:1.4}
.rec-footer{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.action-btn{background:none;border:1px solid var(--bdr);border-radius:5px;padding:3px 8px;font-size:12px;color:var(--t2);cursor:pointer;font-family:inherit}
.action-btn.del{color:var(--danger);border-color:#f5b8b8}
.action-btn.del:hover{background:var(--dlt)}

/* ══ PURCHASE / CONSUME / EXPENSE CARDS ══ */
.entry-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:11px 13px;margin-bottom:7px;box-shadow:var(--shad)}
.entry-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}
.entry-name{font-size:14px;font-weight:600;color:var(--txt)}
.entry-cat{font-size:11px;font-weight:700;color:var(--primary);margin-bottom:3px}
.entry-detail{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.entry-amt{font-size:16px;font-weight:800;color:var(--danger);white-space:nowrap}
.entry-actions{display:flex;gap:5px;margin-left:8px;flex-shrink:0}

/* ══ STOCK ══ */
.stock-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:12px 13px;margin-bottom:7px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shad)}
.stock-info{display:flex;flex-direction:column;gap:3px}
.stock-name{font-size:14px;font-weight:600;color:var(--txt)}
.stock-cat{font-size:11px;color:var(--t3)}
.stock-qty-area{text-align:right}
.stock-qty{font-size:18px;font-weight:800}
.stock-qty.ok{color:var(--primary)}.stock-qty.low{color:var(--warn)}.stock-qty.zero{color:var(--danger)}
.stock-unit{font-size:11px;color:var(--t3)}
.stock-bar-mini{height:4px;background:var(--s2);border-radius:2px;margin-top:4px;overflow:hidden}
.stock-bar-fill{height:100%;border-radius:2px;background:var(--primary);transition:width .4s}

/* ══ REPORTS GRID ══ */
.reports-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.report-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:16px 12px;text-align:center;cursor:pointer;transition:all .15s;box-shadow:var(--shad)}
.report-card:hover{border-color:var(--primary);background:var(--plt)}
.report-card.highlight{border-color:var(--primary);background:var(--plt)}
.report-icon{font-size:28px;margin-bottom:6px}
.report-name{font-size:14px;font-weight:600;color:var(--txt)}
.report-desc{font-size:11px;color:var(--t3);margin-top:2px}

/* ══ SETTINGS / ADMIN CARDS ══ */
.card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:15px;margin-bottom:13px;box-shadow:var(--shad)}
.card-hd{font-size:15px;font-weight:700;color:var(--txt);margin-bottom:4px}
.card-sub{font-size:12px;color:var(--t3);margin-bottom:12px}
.danger-card{border-color:#fdd}
.step{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--t2);margin-bottom:8px}
.step-n{width:20px;height:20px;border-radius:50%;background:var(--plt);color:var(--primary);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.connected-row{display:flex;align-items:center;gap:8px;font-size:14px}
.size-tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.sz-tab{background:var(--s2);border:1px solid var(--bdr);border-radius:var(--rpill);padding:5px 13px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;font-family:inherit}
.sz-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
.edit-svc{background:var(--s2);border:1px solid var(--bdr);border-radius:var(--rs);padding:10px;margin-bottom:7px}
.edit-svc-row{display:flex;gap:7px;align-items:center}
.ei-name{flex:1;background:#fff;border:1px solid var(--bdr);border-radius:6px;padding:8px 9px;font-size:13px;color:var(--txt);font-family:inherit;outline:none}
.ei-name:focus{border-color:var(--primary)}
.ei-price{width:70px;background:#fff;border:1px solid var(--bdr);border-radius:6px;padding:8px;font-size:13px;font-weight:700;color:var(--primary);text-align:center;font-family:inherit;outline:none}
.ei-del{width:32px;height:32px;background:none;border:1px solid var(--bdr);border-radius:6px;color:var(--danger);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ei-req{width:32px;height:32px;background:var(--plt);border:1px solid var(--pmd);border-radius:6px;color:var(--primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}
.vip-lbl{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--t2);cursor:pointer}

/* ══ USERS / SITES ══ */
.user-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:12px 13px;margin-bottom:7px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shad)}
.user-info{display:flex;flex-direction:column;gap:3px}
.user-name{font-size:14px;font-weight:600;color:var(--txt)}
.user-meta{font-size:12px;color:var(--t3)}
.site-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:12px 13px;margin-bottom:7px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shad)}

/* ══ APPROVALS ══ */
.approval-card{background:var(--surf);border:1px solid var(--warn);border-radius:var(--rs);padding:12px 13px;margin-bottom:8px;box-shadow:var(--shad)}
.apr-title{font-size:13px;font-weight:600;color:var(--txt);margin-bottom:4px}
.apr-detail{font-size:12px;color:var(--t2);margin-bottom:8px;line-height:1.5}
.apr-btns{display:flex;gap:8px}
.btn-approve{background:var(--primary);color:#fff;border:none;border-radius:var(--rs);padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
.btn-reject{background:none;border:1px solid var(--danger);border-radius:var(--rs);padding:7px 14px;font-size:13px;color:var(--danger);cursor:pointer;font-family:inherit}

/* ══ INFO BANNERS ══ */
.info-banner{background:var(--plt);border:1px solid var(--pmd);border-radius:var(--rs);padding:9px 12px;font-size:12px;color:var(--pk);margin-bottom:12px}
.info-banner.yellow{background:var(--wlt);border-color:#f0c060;color:var(--warn)}

/* ══ MODAL ══ */
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;z-index:50}
.modal{background:var(--surf);border-radius:var(--r) var(--r) 0 0;padding:20px 16px 30px;width:100%;max-height:92vh;overflow-y:auto}
.modal-hd{font-size:17px;font-weight:700;color:var(--txt);margin-bottom:14px}
.modal-btns{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}

/* ══ TOAST ══ */
.toast{position:fixed;bottom:calc(var(--nh) + 14px);left:50%;transform:translateX(-50%) translateY(10px);background:#1a2220;color:#fff;padding:10px 20px;border-radius:var(--rpill);font-size:13px;font-weight:500;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap;z-index:200;max-width:90vw;overflow:hidden;text-overflow:ellipsis}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══ SPINNER ══ */
.overlay-spinner{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:flex;align-items:center;justify-content:center}
.spinner-inner{background:#fff;border-radius:var(--r);padding:20px 28px;font-size:15px;font-weight:500;color:var(--txt)}

/* ══ INSTALL BANNER ══ */
.install-banner{position:fixed;bottom:calc(var(--nh) + 8px);left:50%;transform:translateX(-50%);background:var(--pk);color:#fff;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;z-index:150;border-radius:var(--r);box-shadow:var(--shad2);gap:12px;max-width:420px;width:calc(100% - 28px)}
.btn-install{background:var(--accent);color:#5a3d00;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap}
.btn-dismiss-i{background:none;border:1px solid rgba(255,255,255,.4);border-radius:6px;padding:6px 10px;font-size:13px;color:#fff;cursor:pointer;font-family:inherit}

/* ══ EMPTY STATE ══ */
.empty-st{text-align:center;padding:40px 20px;color:var(--t3);font-size:13px}
.empty-ico{font-size:36px;margin-bottom:8px}

/* ══ ADMIN-ONLY VISIBILITY ══ */
.admin-only{display:none}
.manager-only{display:none}
body.is-admin .admin-only{display:block}
body.is-admin .sb-item.admin-only{display:block}
body.is-admin #sb-admin-section{display:block}
body.is-manager .manager-only{display:block}

/* ══ HIDDEN PRINT AREA ══ */
#print-area{display:none}

/* ── Permission checkboxes ── */
.perm-check-item{display:flex;align-items:center;gap:6px;background:var(--s2);border:1px solid var(--bdr);border-radius:6px;padding:5px 10px;font-size:12px;color:var(--t2);cursor:pointer;white-space:nowrap}
.perm-check-item input{accent-color:var(--primary);cursor:pointer}
.perm-check-item:has(input:checked){background:var(--plt);border-color:var(--pmd);color:var(--pk)}

/* ── Server sync status ── */
.sdot.server{background:#5ce878}
.sync-mode{font-size:10px;color:rgba(255,255,255,.6);margin-left:4px}

/* ── Multi-device banner ── */
.multidev-banner{background:var(--pk);color:#fff;font-size:12px;padding:7px 14px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0}
.multidev-url{font-weight:700;background:rgba(255,255,255,.2);padding:2px 8px;border-radius:4px;letter-spacing:.3px}

/* ── Fixed Costs Cards ── */
.fixed-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rs);padding:12px 13px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:flex-start;box-shadow:var(--shad);transition:opacity .2s}
.fixed-card.inactive{opacity:.55}
.fixed-card-info{flex:1;min-width:0}
.fixed-name{font-size:14px;font-weight:600;color:var(--txt);margin-bottom:3px}
.fixed-meta{font-size:12px;color:var(--t3)}
.fixed-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;margin-left:12px;flex-shrink:0}
.fixed-amount{font-size:18px;font-weight:800;color:var(--primary);white-space:nowrap}
.fixed-period{font-size:11px;font-weight:400;color:var(--t3);margin-left:2px}
.fixed-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.fixed-total-bar{background:var(--plt);border:1px solid var(--pmd);border-radius:var(--rs);padding:8px 12px;font-size:13px;color:var(--pk);margin-bottom:8px}
.action-btn.green{color:var(--primary);border-color:var(--pmd)}
.action-btn.amber{color:var(--warn);border-color:#f0c060}

/* ── Expense filter tabs ── */
.blk-tabs{display:flex;gap:6px;flex-wrap:wrap}
.blk-tab{background:var(--s2);border:1px solid var(--bdr);border-radius:var(--rpill);padding:5px 13px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;font-family:inherit;transition:all .15s}
.blk-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── Network / multi-device banner ── */
.multidev-banner{background:var(--pk);color:#fff;font-size:12px;padding:7px 14px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px;flex-shrink:0;flex-wrap:wrap}
.multidev-url{font-weight:700;background:rgba(255,255,255,.2);padding:2px 9px;border-radius:4px;letter-spacing:.3px;font-size:13px}

/* ── Update steps ── */
.update-steps{display:flex;flex-direction:column;gap:8px;margin:10px 0}

/* ── Sync dot server mode ── */
.sdot.server{background:#5ce878}

/* ── btn-sm-outline ── */
.btn-sm-outline{background:none;border:1px solid var(--primary);border-radius:var(--rs);padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;color:var(--primary);font-family:inherit;white-space:nowrap}
