/* ============================================================
   ALOCS v3 · Atlantic Location Support
   app.css — All styles
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --black:#07090d;--dark:#0c1018;--card:#111620;--card2:#161d2b;
  --border:#1c2640;--muted:#263350;--text2:#546080;--text1:#96a8c8;
  --white:#ccd8f0;--amber:#f0a020;--amber2:#ffc050;
  --green:#1ed870;--red:#e03535;--blue:#2e88f0;--purple:#8855ee;--teal:#0eb8a0;
  --radius:14px;--safe-b:env(safe-area-inset-bottom,0px);
}
html,body{height:100%;overflow:hidden;background:var(--black);font-family:'DM Sans',sans-serif;color:var(--white)}
#app{max-width:480px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;background:var(--dark);position:relative;overflow:hidden}
h1,h2,h3,h4{font-family:'Bebas Neue',sans-serif;letter-spacing:.05em}
.screen{display:none;flex:1;flex-direction:column;overflow:hidden}
.screen.active{display:flex;animation:fadeUp .22s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.dp{position:fixed;inset:0;max-width:480px;margin:0 auto;background:var(--dark);z-index:200;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}
.dp.open{transform:translateX(0)}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 16px 24px;display:flex;flex-direction:column;gap:12px}
/* LOGIN */
/* login-screen style moved to new login logo section below */
.logo-wrap{text-align:center}
.logo-wrap h1{font-size:76px;line-height:1;color:var(--amber);text-shadow:0 0 80px rgba(240,160,32,.3)}
.logo-sub{font-size:11px;color:var(--text2);letter-spacing:.2em;text-transform:uppercase;margin-top:5px}
.lcard{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;display:flex;flex-direction:column;gap:14px}
.tab-row{display:flex;background:var(--black);border-radius:10px;overflow:hidden;border:1px solid var(--border)}
.tab-btn{flex:1;padding:11px;background:transparent;border:none;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.tab-btn.on{background:var(--amber);color:var(--black)}
/* FORMS */
.f{display:flex;flex-direction:column;gap:5px}
.f label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.09em}
.f input,.f select,.f textarea{background:var(--black);border:1px solid var(--border);border-radius:9px;padding:12px 13px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border .2s;width:100%}
.f input:focus,.f select:focus,.f textarea:focus{border-color:var(--amber)}
.f select option{background:var(--dark)}
.f textarea{resize:vertical;min-height:72px;line-height:1.6}
.mrow{display:flex;gap:9px}.mrow .f{flex:1}
/* BUTTONS */
.btn{width:100%;padding:14px;border-radius:10px;border:none;font-family:'Bebas Neue',sans-serif;font-size:21px;letter-spacing:.07em;cursor:pointer;transition:all .18s}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--amber);color:var(--black)}.btn-primary:hover{background:var(--amber2)}
.btn-ghost{background:var(--border);color:var(--text1)}
.btn-red{background:var(--red);color:#fff}
.btn-sm{padding:8px 16px;font-size:15px;border-radius:8px;width:auto}
.err{color:var(--red);font-size:13px;text-align:center;min-height:16px}
.ibtn{background:var(--border);border:none;border-radius:8px;padding:8px 12px;cursor:pointer;color:var(--text1);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.ibtn:active{background:var(--muted)}
.ibtn.amber{background:var(--amber);color:var(--black);font-weight:700}
.ibtn.green{background:rgba(30,216,112,.15);color:var(--green);border:1px solid rgba(30,216,112,.3)}
.ibtn.red{background:rgba(224,53,53,.15);color:var(--red);border:1px solid rgba(224,53,53,.3)}
.ibtn.blue{background:rgba(46,136,240,.15);color:var(--blue);border:1px solid rgba(46,136,240,.3)}
/* HEADER */
.hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--dark);flex-shrink:0;z-index:10}
.hdr-logo{font-size:26px;color:var(--amber)}
.hdr-right{display:flex;align-items:center;gap:8px}
.hdr-user{display:flex;flex-direction:column;align-items:flex-end;gap:1px}
.hdr-role{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.08em}
.hdr-name{font-size:12px;font-weight:600;color:var(--white)}
.back-btn{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--amber);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;padding:0}
/* BOTTOM NAV */
.bnav{display:flex;border-top:1px solid var(--border);background:var(--dark);flex-shrink:0;padding-bottom:var(--safe-b)}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px;background:none;border:none;cursor:pointer;color:var(--text2);transition:color .2s;position:relative}
.nb.on{color:var(--amber)}
.nb-icon{font-size:20px;line-height:1}
.nb-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.nb-badge{position:absolute;top:6px;right:50%;transform:translateX(10px);background:var(--red);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 4px}
/* STATS */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stats-grid.three{grid-template-columns:1fr 1fr 1fr}
.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:13px 12px}
.stat.amber{border-color:rgba(240,160,32,.25);background:rgba(240,160,32,.06)}
.stat.green{border-color:rgba(30,216,112,.25);background:rgba(30,216,112,.06)}
.stat.red{border-color:rgba(224,53,53,.25);background:rgba(224,53,53,.06)}
.stat.blue{border-color:rgba(46,136,240,.25);background:rgba(46,136,240,.06)}
.stat.purple{border-color:rgba(136,85,238,.25);background:rgba(136,85,238,.06)}
.stat-n{font-family:'Bebas Neue',sans-serif;font-size:38px;line-height:1}
.stat.amber .stat-n{color:var(--amber)}.stat.green .stat-n{color:var(--green)}.stat.red .stat-n{color:var(--red)}.stat.blue .stat-n{color:var(--blue)}.stat.purple .stat-n{color:var(--purple)}
.stat-l{font-size:10px;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.07em;margin-top:1px}
/* SECTION */
.sec{display:flex;flex-direction:column;gap:8px}
.sec-head{display:flex;align-items:center;justify-content:space-between}
.sec-head h3{font-size:18px;color:var(--white)}
/* ALERT CARDS */
.alert-card{border-radius:var(--radius);padding:12px 14px;display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.alert-card.warn{background:rgba(240,160,32,.08);border:1px solid rgba(240,160,32,.25)}
.alert-card.danger{background:rgba(224,53,53,.08);border:1px solid rgba(224,53,53,.25)}
.alert-card.info{background:rgba(46,136,240,.08);border:1px solid rgba(46,136,240,.2)}
.alert-icon{font-size:20px;flex-shrink:0;margin-top:1px}
.alert-body{flex:1;min-width:0}
.alert-title{font-size:13px;font-weight:700;color:var(--white)}
.alert-sub{font-size:12px;color:var(--text2);margin-top:2px;line-height:1.4}
/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;display:flex;flex-direction:column;gap:8px}
.card.tap{cursor:pointer;transition:border .15s}
.card.tap:active{border-color:var(--amber);background:var(--card2)}
.card-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.card-name{font-size:15px;font-weight:600;color:var(--white);line-height:1.25}
.card-id{font-family:'DM Mono',monospace;font-size:11px;color:var(--amber);letter-spacing:.06em}
.card-sub{font-size:12px;color:var(--text2)}
/* SHOW CARDS */
.show-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border .15s}
.show-card:active{border-color:var(--amber)}
.show-accent{height:3px}
.show-accent.active{background:var(--green)}.show-accent.wrapped{background:var(--muted)}.show-accent.quoted{background:var(--amber)}
.show-body{padding:13px 15px;display:flex;flex-direction:column;gap:10px}
.show-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.show-name{font-size:15px;font-weight:700;color:var(--white)}
.show-meta{font-size:11px;color:var(--text2);margin-top:2px;line-height:1.4}
.show-stats{display:flex;gap:14px}
.show-stat{display:flex;flex-direction:column;gap:1px}
.show-stat-n{font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:1}
.show-stat-l{font-size:9px;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
.show-stat.out .show-stat-n{color:var(--amber)}.show-stat.ret .show-stat-n{color:var(--green)}.show-stat.dmg .show-stat-n{color:var(--red)}
.po-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;font-family:'DM Mono',monospace}
.po-chip.ok{color:var(--green);background:rgba(30,216,112,.1);border:1px solid rgba(30,216,112,.25)}
.po-chip.missing{color:var(--red);background:rgba(224,53,53,.1);border:1px solid rgba(224,53,53,.25)}
/* PEOPLE CARDS */
.people-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;cursor:pointer;transition:border .15s;display:flex;gap:12px;align-items:flex-start}
.people-card:active{border-color:var(--amber)}
.people-avatar{width:40px;height:40px;border-radius:10px;background:var(--muted);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--amber);flex-shrink:0}
.people-body{flex:1;min-width:0}
.people-name{font-size:14px;font-weight:700;color:var(--white)}
.people-sub{font-size:12px;color:var(--text2);margin-top:2px}
.disc-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-top:4px}
.disc-standard{background:rgba(84,96,128,.2);color:var(--text2)}
.disc-preferred{background:rgba(46,136,240,.15);color:var(--blue);border:1px solid rgba(46,136,240,.25)}
.disc-vip{background:rgba(240,160,32,.15);color:var(--amber);border:1px solid rgba(240,160,32,.25)}
/* QUOTE CARDS */
.quote-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border .15s}
.quote-card:active{border-color:var(--amber)}
.quote-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:13px 15px 10px}
.quote-num{font-family:'DM Mono',monospace;font-size:11px;color:var(--text2)}
.quote-total{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--amber);line-height:1}
.quote-card-mid{padding:0 15px 10px;display:flex;flex-direction:column;gap:3px}
.quote-show{font-size:13px;font-weight:600;color:var(--white)}
.quote-co{font-size:12px;color:var(--text2)}
.quote-pipeline{display:flex;align-items:flex-start;gap:0;padding:8px 15px;border-top:1px solid var(--border);overflow-x:auto}
.qp-step{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:52px}
.qp-dot{width:8px;height:8px;border-radius:50%;border:1px solid var(--border);background:var(--dark);transition:all .2s;margin:0 auto}
.qp-dot.done{background:var(--green);border-color:var(--green)}
.qp-dot.active{background:var(--amber);border-color:var(--amber);box-shadow:0 0 6px rgba(240,160,32,.5)}
.qp-line{width:100%;height:1px;background:var(--border);margin-top:3px}
.qp-line.done{background:var(--green)}
.qp-lbl{font-size:8px;color:var(--text2);text-transform:uppercase;letter-spacing:.04em;margin-top:3px;text-align:center}
/* BADGES */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;flex-shrink:0}
.badge-out{background:rgba(240,160,32,.14);color:var(--amber);border:1px solid rgba(240,160,32,.28)}
.badge-in{background:rgba(30,216,112,.14);color:var(--green);border:1px solid rgba(30,216,112,.28)}
.badge-dmg{background:rgba(224,53,53,.14);color:var(--red);border:1px solid rgba(224,53,53,.28)}
.badge-add{background:rgba(46,136,240,.14);color:var(--blue);border:1px solid rgba(46,136,240,.28)}
.badge-active{background:rgba(30,216,112,.14);color:var(--green);border:1px solid rgba(30,216,112,.28)}
.badge-wrapped{background:rgba(84,96,128,.2);color:var(--text2);border:1px solid var(--border)}
.badge-draft{background:rgba(84,96,128,.2);color:var(--text2);border:1px solid var(--border)}
.badge-sent{background:rgba(46,136,240,.14);color:var(--blue);border:1px solid rgba(46,136,240,.28)}
.badge-approved{background:rgba(136,85,238,.14);color:var(--purple);border:1px solid rgba(136,85,238,.28)}
.badge-invoiced{background:rgba(240,160,32,.14);color:var(--amber);border:1px solid rgba(240,160,32,.28)}
.badge-closed{background:rgba(30,216,112,.14);color:var(--green);border:1px solid rgba(30,216,112,.28)}
.badge-overdue{background:rgba(224,53,53,.14);color:var(--red);border:1px solid rgba(224,53,53,.28)}
/* INVENTORY */
.inv-counts{display:flex;gap:12px;flex-shrink:0}
.inv-ct{display:flex;flex-direction:column;align-items:center;gap:1px}
.inv-ct .n{font-family:'Bebas Neue',sans-serif;font-size:22px;line-height:1}
.inv-ct .l{font-size:9px;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
.n-avail{color:var(--green)}.n-out{color:var(--amber)}.n-dmg{color:var(--red)}
.prog{height:4px;background:var(--border);border-radius:99px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--amber2));border-radius:99px;transition:width .5s}
/* SCAN */
.scan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sa{background:var(--card);border:2px solid var(--border);border-radius:var(--radius);padding:18px 12px;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;transition:all .2s;text-align:center}
.sa:active{transform:scale(.97)}.sa.on{border-color:var(--amber);background:rgba(240,160,32,.07)}.sa.full{grid-column:1/-1}
.sa-icon{font-size:32px}.sa-lbl{font-family:'Bebas Neue',sans-serif;font-size:17px;color:var(--white);letter-spacing:.04em}.sa-sub{font-size:11px;color:var(--text2)}
.cam{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;aspect-ratio:1;border:2px solid var(--border);cursor:pointer;transition:border .2s}
.cam.live{border-color:var(--amber)}
#qr-video{width:100%;height:100%;object-fit:cover;display:block}
.cam-over{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(7,9,13,.88);pointer-events:none}
.cam-over.hide{opacity:0}
.cam-frame{width:140px;height:140px;position:relative}
.cf{position:absolute;width:22px;height:22px;border-color:var(--amber);border-style:solid}
.cf-tl{top:0;left:0;border-width:3px 0 0 3px;border-radius:4px 0 0 0}.cf-tr{top:0;right:0;border-width:3px 3px 0 0;border-radius:0 4px 0 0}
.cf-br{bottom:0;right:0;border-width:0 3px 3px 0;border-radius:0 0 4px 0}.cf-bl{bottom:0;left:0;border-width:0 0 3px 3px;border-radius:0 0 0 4px}
.scan-beam{position:absolute;left:6px;right:6px;height:2px;background:linear-gradient(90deg,transparent,var(--amber),transparent);animation:beam 2s ease-in-out infinite}
@keyframes beam{0%,100%{top:8%;opacity:0}20%{opacity:1}80%{opacity:1}50%{top:84%}}
.cam-hint{font-size:12px;color:var(--text2);text-align:center;padding:0 16px;line-height:1.5}
.cam-tap-btn{background:var(--amber);color:var(--black);border:none;border-radius:9px;padding:11px 24px;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.06em;cursor:pointer;pointer-events:all}
.inline-in{background:var(--black);border:1px solid var(--border);border-radius:9px;padding:11px 13px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:14px;outline:none;width:100%;transition:border .2s}
.inline-in:focus{border-color:var(--amber)}
.found-card{background:rgba(240,160,32,.06);border:1px solid rgba(240,160,32,.3);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:7px}
.found-chips{display:flex;gap:10px;flex-wrap:wrap}
.found-chip{font-size:12px;display:flex;align-items:center;gap:4px}
.cam-err{background:rgba(46,136,240,.08);border:1px solid rgba(46,136,240,.2);border-radius:9px;padding:9px 12px;font-size:12px;color:var(--blue)}
.suggestion{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:9px 13px;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.suggestion:active{border-color:var(--amber)}
/* DAMAGE TIERS */
.tier-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.tier-btn{padding:10px 6px;border-radius:10px;border:2px solid var(--border);background:var(--black);cursor:pointer;text-align:center;transition:all .2s}
.tier-btn.on{border-color:var(--amber);background:rgba(240,160,32,.07)}
.tier-icon{font-size:22px;margin-bottom:4px}.tier-lbl{font-size:11px;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.05em}.tier-price{font-family:'DM Mono',monospace;font-size:11px;color:var(--amber);margin-top:2px}
/* QUOTE BUILDER */
.qb-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.qb-section-hdr{padding:9px 14px;background:rgba(240,160,32,.06);border-bottom:1px solid var(--border);font-family:'Bebas Neue',sans-serif;font-size:15px;color:var(--amber);letter-spacing:.06em}
.qb-section-body{padding:11px 14px;display:flex;flex-direction:column;gap:9px}
.li-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border)}
.li-row:last-child{border-bottom:none}
.li-name{flex:2;min-width:0}
.li-name-text{font-size:13px;font-weight:600;color:var(--white);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.li-id{font-family:'DM Mono',monospace;font-size:10px;color:var(--text2)}
.li-qty input,.li-rate input{background:var(--black);border:1px solid var(--border);border-radius:7px;padding:6px 8px;color:var(--white);font-family:'DM Mono',monospace;font-size:12px;outline:none;text-align:right}
.li-qty{width:48px}.li-qty input{text-align:center;font-family:'DM Sans',sans-serif}
.li-rate{width:78px}
.li-sub{width:72px;text-align:right;font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--amber)}
.li-del{width:26px;flex-shrink:0;background:none;border:none;color:var(--text2);cursor:pointer;font-size:16px;padding:4px;border-radius:5px}
.li-del:active{background:rgba(224,53,53,.2);color:var(--red)}
.quote-totals{background:var(--black);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:7px}
.tot-row{display:flex;justify-content:space-between;align-items:center}
.tot-lbl{font-size:13px;color:var(--text2)}.tot-val{font-family:'DM Mono',monospace;font-size:13px;color:var(--white)}
.tot-row.discount .tot-val{color:var(--green)}.tot-row.grand{padding-top:8px;border-top:1px solid var(--border)}
.tot-row.grand .tot-lbl{font-size:16px;font-weight:700;color:var(--white);font-family:'Bebas Neue',sans-serif;letter-spacing:.05em}
.tot-row.grand .tot-val{font-size:22px;color:var(--amber);font-family:'Bebas Neue',sans-serif;letter-spacing:.05em}
/* FILTERS */
.pills{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
.pill{padding:5px 12px;border-radius:99px;border:1px solid var(--border);font-size:11px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;background:transparent;color:var(--text2);transition:all .2s;white-space:nowrap;flex-shrink:0}
.pill.on{background:var(--amber);color:var(--black);border-color:var(--amber)}
.search{background:var(--black);border:1px solid var(--border);border-radius:10px;padding:10px 13px;color:var(--white);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;width:100%;transition:border .2s}
.search:focus{border-color:var(--amber)}.search::placeholder{color:var(--muted)}
.sync-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;font-size:12px;background:var(--card);border:1px solid var(--border);color:var(--text2)}
.sdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sdot.ok{background:var(--green);box-shadow:0 0 8px rgba(30,216,112,.5)}.sdot.err{background:var(--red)}.sdot.wait{background:var(--amber);animation:pulse 1.2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
/* ACTION STRIP */
.action-strip{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--dark);flex-shrink:0}
.action-strip .ibtn{flex:1;justify-content:center;padding:9px 6px;font-size:11px}
/* SHOW DETAIL ITEMS */
.show-item-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.show-item-row:last-child{border-bottom:none}
.show-item-name{font-size:13px;font-weight:600;color:var(--white)}
.show-item-id{font-family:'DM Mono',monospace;font-size:10px;color:var(--text2)}
.show-item-qty{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--amber);line-height:1}
/* TX ROW */
.tx{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}
.tx:last-child{border-bottom:none}
.tx-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.tx-dot.out{background:var(--amber)}.tx-dot.in{background:var(--green)}.tx-dot.damage{background:var(--red)}.tx-dot.add{background:var(--blue)}
.tx-b{flex:1;min-width:0}
.tx-title{font-size:13px;font-weight:600;color:var(--white)}
.tx-meta{font-size:11px;color:var(--text2);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tx-time{font-size:10px;color:var(--muted);font-family:'DM Mono',monospace;margin-top:1px}
/* NOTES */
.note-item{padding:10px 0;border-bottom:1px solid var(--border)}
.note-item:last-child{border-bottom:none}
.note-text{font-size:13px;color:var(--white);line-height:1.5}
.note-meta{font-size:10px;color:var(--muted);margin-top:3px;font-family:'DM Mono',monospace}
/* WRAP CHECKLIST */
.wrap-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.wrap-item:last-child{border-bottom:none}
.wrap-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);background:var(--black);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:13px;transition:all .2s}
.wrap-check.done{background:var(--green);border-color:var(--green)}
.wrap-item-name{flex:1;font-size:13px;font-weight:600;color:var(--white)}
.wrap-item-qty{font-size:12px;color:var(--text2)}
/* MAINTENANCE */
.mnt-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.mnt-stripe{height:3px}.mnt-stripe.ok{background:var(--green)}.mnt-stripe.warn{background:var(--amber)}.mnt-stripe.over{background:var(--red)}
.mnt-body{padding:12px 14px;display:flex;flex-direction:column;gap:7px}
/* FAQ */
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer}
.faq-item.open{border-color:var(--amber)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px}
.faq-q-text{font-size:13px;font-weight:600;color:var(--white);line-height:1.3}
.faq-chevron{font-size:11px;color:var(--text2);transition:transform .2s;flex-shrink:0}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:500px}
.faq-a-inner{padding:0 14px 14px;font-size:13px;color:var(--text1);line-height:1.7;white-space:pre-line;border-top:1px solid var(--border)}
/* QR */
.qr-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.qr-label{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;align-items:center;gap:8px}
.qr-canvas{width:96px;height:96px;background:white;border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.qr-item-name{font-size:11px;font-weight:700;color:var(--white);text-align:center;line-height:1.3}
.qr-item-id{font-family:'DM Mono',monospace;font-size:12px;color:var(--amber);font-weight:700}
/* REPORTS */
.report-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.report-row:last-child{border-bottom:none}
.report-rank{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--muted);width:24px;flex-shrink:0;text-align:right}
.report-body{flex:1;min-width:0}
.report-name{font-size:13px;font-weight:600;color:var(--white)}
.report-sub{font-size:11px;color:var(--text2);margin-top:1px}
.report-bar-wrap{height:4px;background:var(--border);border-radius:99px;overflow:hidden;margin-top:4px}
.report-bar{height:100%;background:linear-gradient(90deg,var(--amber),var(--amber2));border-radius:99px}
.report-val{font-family:'Bebas Neue',sans-serif;font-size:20px;color:var(--amber);text-align:right;flex-shrink:0}
/* EMPTY */
.empty{display:flex;flex-direction:column;align-items:center;gap:9px;padding:32px 20px;color:var(--text2);text-align:center}
.e-icon{font-size:38px;opacity:.3}.empty p{font-size:13px;line-height:1.5}
/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:500;display:none;align-items:flex-end;justify-content:center;max-width:480px;margin:0 auto}
.modal-bg.open{display:flex}
.modal{background:var(--dark);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;padding:16px 16px max(40px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:12px;max-height:85dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:99px;margin:0 auto 4px}
.modal h2{font-size:28px;color:var(--amber)}
/* TOAST */
#toast{position:fixed;top:18px;left:50%;transform:translateX(-50%) translateY(-90px);background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px 20px;font-size:13px;font-weight:600;z-index:9999;white-space:nowrap;box-shadow:0 20px 50px rgba(0,0,0,.6);transition:transform .32s cubic-bezier(.34,1.56,.64,1);max-width:calc(100vw - 32px);text-align:center}
#toast.show{transform:translateX(-50%) translateY(0)}
#toast.success{border-color:var(--green);color:var(--green)}.#toast.error{border-color:var(--red);color:var(--red)}.#toast.info{border-color:var(--blue);color:var(--blue)}
.spin{display:inline-block;width:17px;height:17px;border:2px solid var(--border);border-top-color:var(--amber);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.sub-tabs{display:flex;background:var(--black);border-radius:10px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}
.sub-tab{flex:1;padding:9px;background:transparent;border:none;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}
.sub-tab.on{background:var(--amber);color:var(--black)}
.client-hero{background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(240,160,32,.1),transparent),var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.client-hero h2{font-size:30px;color:var(--amber)}.client-hero p{font-size:12px;color:var(--text2);margin-top:3px}
.dmg-warn{background:rgba(224,53,53,.1);border:1px solid rgba(224,53,53,.25);border-radius:9px;padding:9px 12px;font-size:13px;color:var(--red)}
/* PRINT */
#print-area{display:none}
@media print{
  #app{display:none!important}
  #print-area{display:block!important;font-family:Arial,sans-serif;color:#111;background:#fff}
  .pa-page{width:100%;padding:28px 32px}
  .pa-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:18px;border-bottom:2px solid #111;margin-bottom:18px}
  .pa-company{font-size:26px;font-weight:800;color:#111}
  .pa-tagline{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.15em;margin-top:2px}
  .pa-contact{font-size:11px;color:#444;margin-top:8px;line-height:1.6}
  .pa-quote-block{text-align:right}
  .pa-quote-title{font-size:22px;font-weight:800;color:#111}
  .pa-quote-num{font-size:12px;color:#444;margin-top:4px;font-family:monospace}
  .pa-quote-dates{font-size:11px;color:#666;margin-top:4px;line-height:1.6}
  .pa-bill{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
  .pa-bill-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:5px}
  .pa-bill-co{font-size:13px;font-weight:700;color:#111}
  .pa-bill-show{font-size:12px;color:#333;margin-top:2px}
  .pa-bill-attn{font-size:12px;color:#555;margin-top:2px}
  .pa-bill-po{font-size:11px;color:#777;margin-top:3px;font-family:monospace}
  .pa-table{width:100%;border-collapse:collapse;margin-bottom:18px}
  .pa-table th{background:#111;color:#fff;padding:7px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;text-align:left;font-weight:600}
  .pa-table th:last-child,.pa-table td:last-child{text-align:right}
  .pa-table td{padding:7px 10px;font-size:12px;border-bottom:1px solid #eee;color:#111}
  .pa-table tr:nth-child(even) td{background:#f8f8f8}
  .pa-totals-wrap{display:flex;justify-content:flex-end;margin-bottom:22px}
  .pa-totals{width:240px}
  .pa-tot-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;color:#333;border-bottom:1px solid #eee}
  .pa-tot-row.grand{border-top:2px solid #111;border-bottom:none;padding-top:8px;font-size:15px;font-weight:700;color:#111}
  .pa-terms{margin-bottom:20px;padding:10px 12px;background:#f5f5f5;border-radius:4px}
  .pa-terms-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#888;margin-bottom:5px}
  .pa-terms-text{font-size:10px;color:#555;line-height:1.6}
  .pa-sig{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:18px;padding-top:18px;border-top:1px solid #ddd}
  .pa-sig-line{height:1px;background:#111;margin-bottom:4px;margin-top:30px}
  .pa-sig-lbl{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.1em}
}

/* ── LOGIN LOGO ─────────────────────────────────────────── */
#login-screen{align-items:center;justify-content:center;padding:28px 22px;gap:22px;background:radial-gradient(ellipse 80% 55% at 50% 0%,rgba(240,160,32,.12),transparent),var(--dark)}
.login-logo-wrap{width:100%;display:flex;justify-content:center}
.login-logo-banner{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px 24px;width:100%}
.login-logo-mark{font-family:'Bebas Neue',sans-serif;font-size:52px;line-height:1;color:var(--amber);text-shadow:0 0 40px rgba(240,160,32,.4);letter-spacing:.05em}
.login-logo-name{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--white);line-height:1;letter-spacing:.08em}
.login-logo-sub{font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.18em;margin-top:3px}

/* ── HOME ACTION BUTTONS ─────────────────────────────────── */
.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.home-action-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .18s;font-family:'DM Sans',sans-serif}
.home-action-btn:active{border-color:var(--amber);background:rgba(240,160,32,.08);transform:scale(.97)}
.home-action-icon{font-size:26px;line-height:1}
.home-action-lbl{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:.05em;color:var(--white)}

/* ── SMALL BUTTON VARIANT ───────────────────────────────── */
.btn-xs{padding:3px 8px !important;font-size:11px !important;border-radius:6px !important;min-width:0 !important;line-height:1.4}

/* ── INVENTORY CATEGORY TILES ───────────────────────────── */
#inv-cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 16px}
.inv-cat-tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .18s;text-align:center}
.inv-cat-tile:active{border-color:var(--amber);background:rgba(240,160,32,.08);transform:scale(.97)}
.inv-cat-all{border-style:dashed;grid-column:1/-1}
.inv-cat-icon{font-size:28px;line-height:1}
.inv-cat-name{font-size:12px;font-weight:700;color:var(--white);line-height:1.2}
.inv-cat-counts{font-size:11px;color:var(--text2)}

/* ── QUOTE BUILDER ──────────────────────────────────────── */
.qb-show-bar{background:var(--card);border:1px solid var(--amber);border-radius:var(--radius);padding:12px 14px;margin-bottom:4px}
.qb-show-name{font-size:14px;font-weight:700;color:var(--white)}
.qb-show-meta{font-size:11px;color:var(--text2);margin-top:3px}
.qb-cat-section{margin-bottom:6px;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.qb-cat-hdr{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;background:var(--card);user-select:none}
.qb-cat-hdr:active{background:var(--card2)}
.qb-cat-icon{font-size:18px;flex-shrink:0}
.qb-cat-name{font-size:13px;font-weight:700;color:var(--white);flex:1}
.qb-cat-badge{background:var(--amber);color:var(--black);font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;font-family:'DM Mono',monospace}
.qb-cat-arrow{font-size:11px;color:var(--text2);flex-shrink:0}
.qb-cat-body{background:var(--dark)}
.qb-item-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-top:1px solid var(--border);cursor:pointer;transition:background .15s}
.qb-item-row:active{background:rgba(240,160,32,.05)}
.qb-item-check{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--black);flex-shrink:0;transition:all .15s}
.qb-item-check.on{background:var(--amber);border-color:var(--amber)}
.qb-item-info{flex:1;min-width:0}
.qb-item-name{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qb-item-price{font-size:11px;color:var(--text2)}
.qb-item-qty-wrap{flex-shrink:0}
.qb-item-qty-input{width:52px;background:var(--black);border:1px solid var(--amber);border-radius:7px;padding:5px 8px;color:var(--white);font-family:'DM Mono',monospace;font-size:14px;text-align:center;outline:none}
.qb-lines-header{display:flex;gap:6px;padding:6px 0;border-bottom:1px solid var(--border);font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.06em}
.li-rate-type{width:80px}
.li-rate-type select{font-size:10px;padding:4px 5px !important}

/* ── SHOW DETAIL SCANNER BUTTON ─────────────────────────── */
#scan-trigger-btn{font-size:18px;letter-spacing:.06em}

/* ── LM SUGGESTIONS IN SHOW MODAL ──────────────────────── */
#sh-lm-suggestions{background:var(--card);border:1px solid var(--border);border-radius:9px;overflow:hidden;margin-top:-8px}

#dp-qb .scroll{padding-bottom:90px}

/* ── INV LAYOUT FIX ─────────────────────────────────────── */
#t-inventory{height:calc(100dvh - 60px)}
#inv-categories,#inv-list-wrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
#inv-cat-grid{padding-bottom:24px}
#inv-list{padding-bottom:24px}

/* ── LOGIN LOGO IMAGE ───────────────────────────────────── */
.login-logo-img{max-width:280px;width:85%;height:auto;object-fit:contain}
.hdr-logo-img{height:28px;width:auto;object-fit:contain;max-width:140px}
/* Remove old text-based logo styles that no longer apply */
.login-logo-mark,.login-logo-name,.login-logo-sub{display:none}

/* ── DETAIL PANEL SCROLL PADDING ───────────────────────── */
.dp .scroll{padding-bottom:32px}

/* ── CUSTOMERS TAB ──────────────────────────────────────── */
#t-customers{height:calc(100dvh - 60px)}
#customer-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
