/* TaxiMeter ZG – styles */
:root{
  --bg:#0a0a0a;--surface:#111;--surface2:#1a1a1a;--border:#2a2a2a;
  --accent:#f0c040;--green:#30c060;--red:#e03030;--text:#f0f0f0;--muted:#606060;
  --fare-day:#f0c040;--fare-night:#6080ff
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{background:var(--bg);color:var(--text);font-family:'IBM Plex Sans',sans-serif;min-height:100vh;max-width:480px;margin:0 auto;overflow-x:hidden}

/* HEADER */
.header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border)}
.logo{font-family:'Bebas Neue',cursive;font-size:24px;letter-spacing:3px;color:var(--accent)}
.logo span{color:var(--text)}
.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.live-clock{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:600;color:var(--accent);letter-spacing:2px}
.tariff-badge{font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:600;padding:3px 10px;border-radius:20px;letter-spacing:1px}
.tariff-day{background:rgba(240,192,64,.15);color:var(--fare-day);border:1px solid rgba(240,192,64,.3)}
.tariff-night{background:rgba(96,128,255,.15);color:var(--fare-night);border:1px solid rgba(96,128,255,.3)}
.tariff-dogovor{background:rgba(48,192,96,.15);color:var(--green);border:1px solid rgba(48,192,96,.3)}

/* FUEL BAR */
.fuel-bar{background:var(--surface2);border-bottom:1px solid var(--border);padding:7px 20px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.fuel-info{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--muted);display:flex;gap:12px;flex-wrap:wrap}
.fuel-val{color:var(--text);font-weight:600}
.fuel-ok{color:var(--green);font-size:9px}
.fuel-old{color:var(--accent);font-size:9px}
.fuel-reload{background:none;border:1px solid var(--border);color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:9px;padding:3px 8px;border-radius:3px;cursor:pointer}
.fuel-reload:hover{color:var(--accent);border-color:var(--accent)}

/* METER */
.meter-section{padding:20px 20px 12px;text-align:center}
.meter-label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.meter-price{font-family:'Bebas Neue',cursive;font-size:84px;line-height:1;letter-spacing:2px;color:var(--accent);text-shadow:0 0 40px rgba(240,192,64,.3)}
.meter-price.running{animation:pulse 1s ease-in-out infinite alternate}
@keyframes pulse{from{text-shadow:0 0 20px rgba(240,192,64,.2)}to{text-shadow:0 0 60px rgba(240,192,64,.6)}}
.meter-currency{font-family:'IBM Plex Mono',monospace;font-size:20px;color:var(--muted);margin-left:4px;vertical-align:super}

/* STATS */
.stats-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);margin-bottom:1px}
.stat-box{background:var(--surface);padding:12px 10px;text-align:center}
.stat-value{font-family:'IBM Plex Mono',monospace;font-size:18px;font-weight:600;color:var(--text)}
.stat-label{font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:3px}

/* RATES */
.rates-panel{background:var(--surface);padding:11px 20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:1px}
.rates-title{font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}
.rates-values{font-family:'IBM Plex Mono',monospace;display:flex;gap:16px}
.rate-item{display:flex;flex-direction:column;align-items:center;gap:2px}
.rate-num{font-size:13px;font-weight:600;color:var(--text)}
.rate-lbl{font-size:9px;color:var(--muted);letter-spacing:1px}

/* GPS */
.gps-bar{background:var(--surface);padding:8px 20px;display:flex;align-items:center;gap:10px;margin-bottom:1px}
.gps-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0;transition:background .3s}
.gps-dot.active{background:var(--green);box-shadow:0 0 6px var(--green);animation:blink 1.5s infinite}
.gps-dot.searching{background:var(--accent);animation:blink .5s infinite}
.gps-dot.error{background:var(--red)}
@keyframes blink{50%{opacity:.3}}
.gps-text{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);flex:1}
.gps-dot.active~.gps-text{color:var(--green)}
.gps-coords{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--border)}

/* LOCATION PANEL */
.location-panel{background:var(--surface);padding:12px 20px;display:none;margin-bottom:1px}
.location-panel.visible{display:block}
.loc-row{display:flex;align-items:flex-start;gap:10px;padding:7px 0}
.loc-row+.loc-row{border-top:1px solid var(--border)}
.loc-icon{font-size:14px;flex-shrink:0;margin-top:1px}
.loc-content{flex:1;min-width:0}
.loc-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;margin-bottom:2px}
.loc-address{font-size:12px;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.loc-address.loading{color:var(--muted);font-style:italic}
.loc-coords{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--muted);margin-top:1px}
.loc-line{width:1px;height:12px;background:repeating-linear-gradient(to bottom,var(--border) 0,var(--border) 4px,transparent 4px,transparent 8px);margin:0 0 0 24px}

/* RIDE MAP */
#rideMapWrap{background:var(--surface);padding:0 20px 12px;display:none;margin-bottom:1px}
#rideMapWrap.visible{display:block}
#rideMap{width:100%;height:220px;border-radius:4px;border:1px solid var(--border)}
.ride-map-label{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;padding:10px 0 6px}

/* GPS FALLBACK */
.gps-fallback{background:var(--surface2);border:1px solid #e08030;border-radius:4px;padding:12px 16px;margin:0 20px 10px;font-family:'IBM Plex Mono',monospace;font-size:11px;display:none;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.gps-fallback.visible{display:flex}

/* CONTROLS */
.controls{padding:14px 20px;display:flex;flex-direction:column;gap:10px}
.btn-main{width:100%;padding:18px;border:none;border-radius:4px;font-family:'Bebas Neue',cursive;font-size:26px;letter-spacing:3px;cursor:pointer;transition:opacity .15s}
.btn-main:active{opacity:.85}
.btn-start{background:var(--green);color:#000}
.btn-stop{background:var(--red);color:#fff}
.btn-reset{background:var(--surface2);color:var(--muted);border:1px solid var(--border);font-size:16px;padding:13px}
.btn-print{background:var(--accent);color:#000;font-size:18px;padding:13px}
.btn-dogovor{background:#1a4a2a;color:var(--green);border:1px solid rgba(48,192,96,.4);font-size:18px;padding:13px}
.btn-row{display:flex;gap:10px}
.btn-row .btn-main{flex:1}

/* MAP shared */
.map-overlay{position:absolute;bottom:8px;left:8px;z-index:1000;background:rgba(0,0,0,.82);border:1px solid rgba(240,192,64,.3);border-radius:4px;padding:7px 10px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--accent);pointer-events:none;line-height:1.6}
.map-overlay span{color:var(--text)}

/* ESTIMATE PANEL */
.estimate-panel{background:var(--surface);padding:12px 20px;margin-bottom:1px}
.estimate-title{font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.estimate-toggle{background:none;border:1px solid var(--border);color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:9px;padding:3px 8px;border-radius:3px;cursor:pointer;letter-spacing:1px}
.estimate-toggle:hover,.estimate-toggle.open{color:var(--accent);border-color:var(--accent)}
.estimate-body{display:none}
.estimate-body.open{display:block}
.est-lbl{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;margin-bottom:4px}
.est-from{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:9px 14px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:10px}
.est-input-wrap{position:relative;margin-bottom:8px}
.est-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:10px 34px 10px 14px;color:var(--text);font-family:'IBM Plex Mono',monospace;font-size:13px;outline:none;transition:border-color .2s}
.est-input:focus{border-color:var(--accent)}
.est-input::placeholder{color:var(--muted)}
.est-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;display:none}
.est-suggestions{position:absolute;top:100%;left:0;right:0;z-index:500;background:var(--surface2);border:1px solid var(--border);border-top:none;border-radius:0 0 4px 4px;max-height:180px;overflow-y:auto}
.est-sugg{padding:9px 14px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--text);cursor:pointer;border-bottom:1px solid var(--border);line-height:1.4}
.est-sugg:last-child{border-bottom:none}
.est-sugg:hover,.est-sugg.hi{background:var(--surface);color:var(--accent)}
.est-sugg small{color:var(--muted);font-size:10px;display:block;margin-top:1px}
.est-btn{width:100%;padding:11px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:'Bebas Neue',cursive;font-size:17px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.est-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.est-btn:disabled{opacity:.35;cursor:default}
.est-result{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:12px;margin-top:10px;display:none}
.est-result.visible{display:block}
.est-row{display:flex;justify-content:space-between;padding:4px 0;font-family:'IBM Plex Mono',monospace;font-size:11px}
.est-row-l{color:var(--muted)}
.est-row-v{color:var(--text);font-weight:600}
.est-total{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--border);margin-top:8px;padding-top:10px}
.est-total-lbl{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.est-total-val{font-family:'Bebas Neue',cursive;font-size:32px;color:var(--accent);line-height:1}
.est-range{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--muted);text-align:right;margin-top:2px}
.est-note{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--muted);text-align:center;margin-top:8px}
.est-spin{text-align:center;padding:10px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);display:none}
.est-spin.visible{display:block}
.est-err{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--red);padding:6px 0;display:none;text-align:center}
.est-err.visible{display:block}
#estMap{width:100%;height:240px;border-radius:4px;margin-top:10px;border:1px solid var(--border);display:none;position:relative}
#estMap.visible{display:block}

/* HISTORY */
.history-section{padding:0 20px 30px}
.section-title{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;padding:14px 0 10px;display:flex;align-items:center;justify-content:space-between}
.clear-btn{background:none;border:1px solid var(--border);color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:10px;padding:3px 8px;border-radius:3px;cursor:pointer}
.clear-btn:hover{color:var(--red);border-color:var(--red)}
.history-list{display:flex;flex-direction:column;gap:1px}
.history-item{background:var(--surface);padding:12px 14px;display:grid;grid-template-columns:1fr auto;gap:4px;border-left:3px solid transparent}
.history-item.tariff-day{border-color:var(--fare-day)}
.history-item.tariff-night{border-color:var(--fare-night)}
.history-item.tariff-dogovor{border-color:var(--green)}
.h-time{font-size:12px;color:var(--text);font-family:'IBM Plex Mono',monospace}
.h-meta{font-size:11px;color:var(--muted);font-family:'IBM Plex Mono',monospace;margin-top:3px}
.h-addr{font-size:10px;color:#555;font-family:'IBM Plex Mono',monospace;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
.h-amount{font-family:'Bebas Neue',cursive;font-size:26px;color:var(--accent);text-align:right}
.h-tariff{font-size:9px;font-family:'IBM Plex Mono',monospace;text-align:right;letter-spacing:1px;margin-top:2px}
.h-print{background:none;border:1px solid var(--border);color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:9px;padding:3px 7px;border-radius:3px;cursor:pointer;margin-top:6px;width:100%}
.h-print:hover{color:var(--accent);border-color:var(--accent)}
.empty-history{text-align:center;padding:30px;color:var(--border);font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:1px}
.status-bar{text-align:center;padding:8px;font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--border);letter-spacing:1px}

/* RECEIPT MODAL */
#receiptModal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.88);align-items:center;justify-content:center;padding:16px}
#receiptModal.open{display:flex}
.receipt-wrap{background:#fff;color:#111;border-radius:6px;width:100%;max-width:360px;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.receipt-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #eee;background:#f9f9f9;border-radius:0 0 6px 6px;position:sticky;bottom:0}
.btn-receipt{flex:1;padding:12px;border:none;border-radius:4px;font-family:'Bebas Neue',cursive;font-size:18px;letter-spacing:2px;cursor:pointer}
.btn-receipt-pdf{background:#111;color:#fff}
.btn-receipt-close{background:#eee;color:#555}
#receiptContent{padding:24px 20px 16px;font-family:'IBM Plex Mono',monospace}
.rc{text-align:center;margin-bottom:16px;border-bottom:2px solid #111;padding-bottom:12px}
.rc-name{font-family:'Bebas Neue',cursive;font-size:24px;letter-spacing:3px;color:#111}
.rc-sub{font-size:10px;color:#666;margin-top:3px}
.rc-title{text-align:center;font-size:12px;letter-spacing:2px;text-transform:uppercase;margin-bottom:14px;color:#333;border-bottom:1px dashed #ccc;padding-bottom:8px}
.rc-no{text-align:center;font-size:11px;color:#aaa;letter-spacing:1px;margin-bottom:12px}
.rc-row{display:flex;justify-content:space-between;padding:4px 0;font-size:11px}
.rc-row.sep{border-top:1px dashed #ccc;margin-top:5px;padding-top:8px}
.rc-row.total{border-top:2px solid #111;margin-top:6px;padding-top:8px;font-size:14px;font-weight:600}
.rc-lbl{color:#555;flex:1}
.rc-val{color:#111;font-weight:600;text-align:right;max-width:200px;word-break:break-word}
.rc-locs{background:#f5f5f5;border-radius:4px;padding:9px 12px;margin:8px 0;font-size:11px}
.rc-loc-lbl{font-size:9px;color:#888;letter-spacing:1px;text-transform:uppercase;margin-bottom:2px}
.rc-loc-val{color:#222;font-size:11px;line-height:1.4}
.rc-loc-hr{border:none;border-top:1px dashed #ddd;margin:6px 0}
.rc-footer{text-align:center;margin-top:14px;padding-top:10px;border-top:1px dashed #ccc;font-size:10px;color:#999;line-height:1.7}
.rc-dogovor{background:#f0fff4;border:1px solid #b2dfdb;border-radius:4px;padding:10px 12px;margin:10px 0;text-align:center}
.rc-dogovor-lbl{font-size:11px;color:#1a7a3a;font-weight:600}
.rc-dogovor-val{font-family:'Bebas Neue',cursive;font-size:28px;color:#1a7a3a;letter-spacing:2px}
/* Map inside receipt */
#receiptMap{width:100%;height:200px;border-radius:4px;border:1px solid #ddd;margin:10px 0;display:none}
#receiptMap.visible{display:block}
.rc-map-lbl{font-size:9px;color:#888;letter-spacing:1px;text-transform:uppercase;margin:10px 0 4px}

/* DOGOVOR MODAL */
#dogovorModal{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.9);align-items:center;justify-content:center;padding:30px}
#dogovorModal.open{display:flex}
.dogovor-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:28px 24px;width:100%;max-width:300px}
.dogovor-title{font-family:'Bebas Neue',cursive;font-size:22px;letter-spacing:3px;color:var(--accent);margin-bottom:4px}
.dogovor-sub{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:1px;margin-bottom:18px}
.dogovor-meter{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);margin-bottom:12px;text-align:center}
.dogovor-meter span{color:var(--text);font-weight:600}
.dogovor-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:14px;color:var(--text);font-family:'Bebas Neue',cursive;font-size:34px;letter-spacing:2px;outline:none;text-align:center;transition:border-color .2s}
.dogovor-input:focus{border-color:var(--accent)}
.dogovor-cur{text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);margin-top:5px;letter-spacing:1px}
.dogovor-btns{display:flex;gap:10px;margin-top:16px}
.dg-ok{flex:1;padding:14px;border:none;border-radius:4px;font-family:'Bebas Neue',cursive;font-size:18px;letter-spacing:2px;cursor:pointer;background:var(--green);color:#000}
.dg-cancel{flex:1;padding:14px;border:1px solid var(--border);border-radius:4px;font-family:'Bebas Neue',cursive;font-size:18px;letter-spacing:2px;cursor:pointer;background:var(--surface2);color:var(--muted)}

@media print{body>*:not(#receiptModal){display:none!important}#receiptModal{display:block!important;position:static!important;background:none!important;padding:0!important}.receipt-wrap{box-shadow:none!important;max-height:none!important}.receipt-actions{display:none!important}}
