/* ═══════════════════════════════════
   MEATKA — style.css
   Mobile-first / iPhone
═══════════════════════════════════ */
:root {
  --bg:    #0a0a0a;
  --bg2:   #141414;
  --bg3:   #1c1c1c;
  --bg4:   #242424;
  --bd:    #272727;
  --bd2:   #333;
  --txt:   #f0f0f0;
  --txt2:  #999;
  --txt3:  #555;
  --red:   #e63946;
  --blue:  #457b9d;
  --teal:  #2a9d8f;
  --gold:  #e9c46a;
  --safe-t: env(safe-area-inset-top,0px);
  --safe-b: env(safe-area-inset-bottom,0px);
  --r: 12px;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { height:100%; -webkit-text-size-adjust:100%; }
body {
  background:var(--bg); color:var(--txt);
  font-family:'DM Sans',sans-serif;
  min-height:100%; min-height:-webkit-fill-available;
  overflow:hidden;
}
input,select,textarea { font-size:16px!important; font-family:'DM Sans',sans-serif; }
button { cursor:pointer; font-family:'DM Sans',sans-serif; -webkit-tap-highlight-color:transparent; }
code { font-family:'DM Mono',monospace; font-size:12px; background:rgba(233,196,106,.12); color:var(--gold); padding:2px 6px; border-radius:4px; }

/* ═══ PAGE SYSTEM ═══ */
#app { width:100vw; height:100vh; height:-webkit-fill-available; overflow:hidden; position:relative; }
.page {
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  background:var(--bg);
  transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  will-change:transform;
  overflow:hidden;
}
.page.active { transform:translateX(0); }
.page.slide-out { transform:translateX(-30%); }

/* ═══ HOME ═══ */
#pg-home { transform:translateX(0); }
.home-inner {
  flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding: calc(var(--safe-t) + 48px) 24px calc(var(--safe-b) + 24px);
  display:flex; flex-direction:column; gap:32px;
}
.home-logo-wrap { text-align:center; padding-top:8px; }
.home-logo-icon { font-size:52px; display:block; margin-bottom:8px; }
.home-logo-name {
  font-family:'Bebas Neue',sans-serif; font-size:52px;
  letter-spacing:6px; color:#fff; line-height:1;
}
.home-clock { font-family:'DM Mono',monospace; font-size:13px; color:var(--txt3); margin-top:6px; }

/* HOME BUTTONS */
.home-btns { display:flex; flex-direction:column; gap:14px; }
.hbtn {
  display:flex; align-items:center; gap:18px;
  padding:22px 24px; border-radius:var(--r);
  border:none; color:#fff; font-size:20px; font-weight:700;
  font-family:'Bebas Neue',sans-serif; letter-spacing:2px;
  text-align:left; transition:transform .15s, opacity .15s;
  position:relative; overflow:hidden;
}
.hbtn:active { transform:scale(.97); opacity:.9; }
.hbtn-red  { background:linear-gradient(135deg,#e63946,#c1121f); }
.hbtn-blue { background:linear-gradient(135deg,#457b9d,#1d3557); }
.hbtn-gold { background:linear-gradient(135deg,#e9c46a,#c9a227); color:#111; }
.hbtn-icon { font-size:28px; flex-shrink:0; }
.hbtn-label { flex:1; }

/* HOME ALERTS */
.home-alerts { background:var(--bg2); border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; }
.hal-title { padding:12px 16px; font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--txt3); border-bottom:1px solid var(--bd); }
.hal { padding:11px 16px; font-size:13px; border-bottom:1px solid var(--bd); line-height:1.5; }
.hal:last-child { border-bottom:none; }
.hal.red    { border-left:3px solid var(--red); }
.hal.yellow { border-left:3px solid var(--gold); }
.hal.blue   { border-left:3px solid var(--teal); }

/* ═══ PAGE HEADER ═══ */
.pg-header {
  display:flex; align-items:center; gap:12px;
  padding:0 16px;
  padding-top:calc(var(--safe-t) + 12px);
  padding-bottom:12px;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd);
  flex-shrink:0; z-index:10;
}
.back-btn {
  width:38px; height:38px; border-radius:50%;
  background:var(--bg3); border:1px solid var(--bd2);
  color:var(--txt); font-size:22px; font-weight:300;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all .15s;
}
.back-btn:active { background:var(--bd2); }
.pg-title {
  font-family:'Bebas Neue',sans-serif; font-size:26px;
  letter-spacing:3px; color:#fff; flex:1;
}
.pg-body {
  flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:16px;
  padding-bottom:calc(var(--safe-b) + 16px);
}

/* ═══ MENU GRID (Δρομολόγια 4 επιλογές) ═══ */
.menu-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
  padding:8px 0;
}
.mbtn {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:10px;
  padding:28px 16px; border-radius:var(--r);
  border:none; color:#fff;
  transition:transform .15s, opacity .15s;
  aspect-ratio:1;
}
.mbtn:active { transform:scale(.95); opacity:.85; }
.mbtn-red  { background:linear-gradient(145deg,#e63946,#b01020); }
.mbtn-blue { background:linear-gradient(145deg,#457b9d,#1d3557); }
.mbtn-teal { background:linear-gradient(145deg,#2a9d8f,#1a6b60); }
.mbtn-gold { background:linear-gradient(145deg,#e9c46a,#c9a227); color:#111; }
.mbtn-icon { font-size:32px; }
.mbtn-lbl  { font-family:'Bebas Neue',sans-serif; font-size:18px; letter-spacing:2px; }

/* ═══ ΟΔΗΓΙΕΣ 2 κουμπιά ═══ */
.menu-grid-2 { display:flex; flex-direction:column; gap:16px; padding:8px 0; }
.mbtn2 {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:8px;
  padding:36px 24px; border-radius:var(--r);
  border:none; color:#fff;
  transition:transform .15s, opacity .15s;
}
.mbtn2:active { transform:scale(.97); opacity:.85; }
.mbtn2-red  { background:linear-gradient(135deg,#e63946,#c1121f); }
.mbtn2-blue { background:linear-gradient(135deg,#457b9d,#1d3557); }
.mbtn2-icon { font-size:40px; }
.mbtn2-lbl  { font-family:'Bebas Neue',sans-serif; font-size:26px; letter-spacing:3px; }
.mbtn2-sub  { font-size:12px; opacity:.75; }

/* ═══ ΟΔΗΓΟΙ ═══ */
.driver-list { display:flex; flex-direction:column; gap:10px; }
.driver-card {
  display:flex; align-items:center; gap:14px;
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--r); padding:16px;
  border-left:4px solid var(--dc,#333);
  width:100%; text-align:left;
  transition:background .15s;
}
.driver-card:active { background:var(--bg3); }
.dc-avatar {
  width:48px; height:48px; border-radius:50%;
  font-family:'Bebas Neue',sans-serif; font-size:24px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0;
}
.dc-info { flex:1; min-width:0; }
.dc-name { font-size:17px; font-weight:700; color:#fff; }
.dc-meta { font-size:12px; color:var(--gold); margin-top:2px; font-family:'DM Mono',monospace; }
.dc-area { font-size:11px; color:var(--txt2); margin-top:3px; }
.dc-arr  { font-size:22px; color:var(--txt3); flex-shrink:0; }

/* ═══ ROUTE INFO CARD ═══ */
.route-info-card {
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--r); padding:16px; margin-bottom:16px;
}
.ric-top { display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.ric-badge {
  width:52px; height:52px; border-radius:10px;
  font-family:'Bebas Neue',sans-serif; font-size:30px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0;
}
.ric-title { font-size:18px; font-weight:700; color:#fff; }
.ric-sub   { font-size:12px; color:var(--txt2); margin-top:2px; }
.ric-tags  { display:flex; gap:6px; flex-wrap:wrap; }
.ric-tag   { font-size:11px; padding:3px 10px; border-radius:20px; background:var(--bg4); color:var(--txt2); border:1px solid var(--bd2); }
.ric-tag.gold { background:rgba(233,196,106,.12); color:var(--gold); border-color:rgba(233,196,106,.3); }

/* ═══ PELATES LIST ═══ */
.section-label {
  font-size:10px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; color:var(--txt3);
  margin-bottom:10px; padding-left:2px;
}
.pelates-list { display:flex; flex-direction:column; gap:6px; }
.pel-item {
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:9px; padding:12px 14px;
  display:flex; align-items:center; gap:10px;
}
.pel-item.has-nick { border-color:rgba(233,196,106,.25); background:rgba(233,196,106,.04); }
.pel-item.has-warn { border-color:rgba(230,57,70,.3); background:rgba(230,57,70,.05); }
.pel-name { font-size:14px; color:var(--txt); flex:1; }
.pel-nick { font-size:11px; color:var(--gold); background:rgba(233,196,106,.12); padding:2px 7px; border-radius:4px; white-space:nowrap; }
.pel-warn { font-size:10px; color:var(--red); background:rgba(230,57,70,.12); padding:2px 7px; border-radius:4px; white-space:nowrap; }
.pel-area { font-size:11px; color:var(--txt3); }

/* ═══ SEARCH RESULTS ═══ */
.big-search {
  width:100%; padding:14px 16px; margin-bottom:14px;
  background:var(--bg2); border:1px solid var(--bd2);
  border-radius:var(--r); color:var(--txt); outline:none;
  transition:border-color .2s;
}
.big-search:focus { border-color:var(--red); }
.big-search::placeholder { color:var(--txt3); }
.results-list { display:flex; flex-direction:column; gap:8px; }
.res-card {
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--r); padding:14px 16px;
  border-left:4px solid var(--rc,#555);
}
.res-name { font-size:15px; font-weight:600; color:#fff; margin-bottom:4px; }
.res-nick { font-size:12px; color:var(--gold); margin-bottom:8px; }
.res-tags { display:flex; gap:6px; flex-wrap:wrap; }
.res-tag  { font-size:11px; padding:3px 9px; border-radius:20px; background:var(--bg4); color:var(--txt2); border:1px solid var(--bd2); }
.no-results { text-align:center; padding:40px 20px; color:var(--txt3); font-size:14px; }

/* ═══ ΠΕΡΙΟΧΗ ═══ */
.area-list { display:flex; flex-direction:column; gap:10px; }
.area-btn {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; background:var(--bg2); border:1px solid var(--bd);
  border-left:4px solid var(--ac,#555);
  border-radius:var(--r); padding:18px 16px;
  color:var(--txt); font-size:14px; text-align:left;
  transition:background .15s;
}
.area-btn:active { background:var(--bg3); }
.area-badge {
  width:32px; height:32px; border-radius:6px;
  font-family:'Bebas Neue',sans-serif; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0;
}

/* ═══ ΣΕΙΡΑ CARDS ═══ */
.seira-cards { display:flex; flex-direction:column; gap:10px; }
.seira-card {
  display:flex; align-items:center; gap:14px;
  background:var(--bg2); border:1px solid var(--bd);
  border-left:4px solid var(--sc,#555);
  border-radius:var(--r); padding:18px 16px;
  width:100%; text-align:left;
  transition:background .15s;
}
.seira-card:active { background:var(--bg3); }
.sc-letter {
  width:52px; height:52px; border-radius:10px;
  font-family:'Bebas Neue',sans-serif; font-size:30px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; flex-shrink:0;
}
.sc-name { font-size:15px; font-weight:700; color:#fff; }
.sc-sub  { font-size:12px; color:var(--txt2); margin-top:3px; }

/* ═══ GUIDE CARDS ═══ */
.guide-card {
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--r); margin-bottom:12px; overflow:hidden;
}
.guide-card.gc-red  { border-top:3px solid var(--red); }
.guide-card.gc-blue { border-top:3px solid var(--blue); }
.guide-card.gc-teal { border-top:3px solid var(--teal); }
.guide-card.gc-gold { border-top:3px solid var(--gold); }
.gc-hdr {
  padding:13px 16px; font-size:13px; font-weight:600;
  color:#fff; background:rgba(255,255,255,.03);
  border-bottom:1px solid var(--bd);
}
.gc-body { padding:12px 16px; }
.step {
  display:flex; align-items:flex-start; gap:8px;
  padding:7px 0; font-size:13px; color:var(--txt2);
  border-bottom:1px solid var(--bd); line-height:1.55;
}
.step:last-child { border-bottom:none; }
.sn {
  flex-shrink:0; width:22px; height:22px; border-radius:50%;
  background:var(--bg4); font-size:10px; font-weight:700;
  color:var(--txt3); display:flex; align-items:center; justify-content:center; margin-top:1px;
}
.mt8 { margin-top:8px; }
.kv  { display:flex; align-items:center; gap:8px; padding:6px 0; font-size:13px; border-bottom:1px solid var(--bd); }
.kv:last-child { border-bottom:none; }
.kk  { font-size:10px; color:var(--txt3); text-transform:uppercase; letter-spacing:.5px; width:90px; flex-shrink:0; }
.code-grid { display:flex; flex-direction:column; gap:0; }
.cg-row { display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid var(--bd); font-size:13px; color:var(--txt2); }
.cg-row:last-child { border-bottom:none; }
.badge-r { font-size:11px; background:rgba(230,57,70,.15); color:#ff6b6b; padding:2px 7px; border-radius:4px; font-weight:600; }

/* ═══ ΟΙΚΟΔΟΜΗ ═══ */
.oi-toolbar { display:flex; gap:10px; margin-bottom:16px; align-items:center; }
.oi-search-inp {
  flex:1; padding:13px 16px;
  background:var(--bg2); border:1px solid var(--bd2);
  border-radius:var(--r); color:var(--txt); outline:none;
  transition:border-color .2s;
}
.oi-search-inp:focus { border-color:var(--red); }
.oi-search-inp::placeholder { color:var(--txt3); }
.oi-add-btn {
  background:var(--red); border:none;
  border-radius:var(--r); color:#fff;
  padding:13px 18px; font-size:14px; font-weight:600;
  white-space:nowrap; transition:all .15s; flex-shrink:0;
}
.oi-add-btn:active { transform:scale(.96); }

/* SYN LIST */
.syn-list { display:flex; flex-direction:column; gap:10px; }
.syn-card {
  background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--r); overflow:hidden;
  transition:border-color .2s;
}
.syn-card-main {
  display:flex; align-items:center; gap:12px;
  padding:16px;
}
.syn-avatar {
  width:46px; height:46px; border-radius:50%;
  background:var(--bg4); border:1px solid var(--bd2);
  font-size:20px; display:flex; align-items:center;
  justify-content:center; flex-shrink:0;
}
.syn-info { flex:1; min-width:0; }
.syn-name  { font-size:15px; font-weight:600; color:#fff; }
.syn-eidos { font-size:12px; color:var(--gold); margin-top:2px; }
.syn-phone { font-size:12px; color:var(--txt2); margin-top:2px; }
.syn-expand-btn {
  background:none; border:none; color:var(--txt3);
  font-size:20px; padding:4px; transition:transform .25s; flex-shrink:0;
}
.syn-expand-btn.open { transform:rotate(180deg); }
.syn-detail-body {
  max-height:0; overflow:hidden;
  transition:max-height .3s ease;
  border-top:0px solid var(--bd);
}
.syn-detail-body.open {
  max-height:800px;
  border-top:1px solid var(--bd);
}
.syn-detail-inner { padding:14px 16px; }
.sd-row { font-size:13px; color:var(--txt2); margin-bottom:6px; display:flex; gap:8px; }
.sd-lbl { color:var(--txt3); font-size:11px; text-transform:uppercase; letter-spacing:.5px; width:70px; flex-shrink:0; }
.sd-notes {
  font-size:12px; color:var(--txt2);
  background:var(--bg3); border-left:2px solid var(--bd2);
  padding:8px 12px; border-radius:0 6px 6px 0;
  margin:10px 0; line-height:1.6;
}
.sd-files { display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.sd-file {
  width:72px; height:72px; border-radius:8px;
  object-fit:cover; border:1px solid var(--bd2);
  cursor:pointer;
}
.sd-file-doc {
  width:72px; height:72px; border-radius:8px;
  background:var(--bg3); border:1px solid var(--bd2);
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; font-size:10px; color:var(--txt3);
  gap:4px; cursor:pointer;
}
.syn-actions { display:flex; gap:6px; padding-top:12px; border-top:1px solid var(--bd); margin-top:12px; }
.syn-actions button {
  flex:1; padding:9px; font-size:12px; font-weight:600;
  border-radius:8px; transition:all .15s;
}
.btn-edit { background:rgba(69,123,157,.15); border:1px solid rgba(69,123,157,.3); color:#7fb3d3; }
.btn-del  { background:rgba(230,57,70,.1);   border:1px solid rgba(230,57,70,.25);  color:#ff6b6b; }

/* ═══ FORM ═══ */
.form-wrap { max-width:560px; }
.field { margin-bottom:16px; }
.flbl { display:block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.8px; color:var(--txt3); margin-bottom:6px; }
.finp {
  display:block; width:100%;
  background:var(--bg2); border:1px solid var(--bd2);
  border-radius:var(--r); padding:13px 15px;
  color:var(--txt); outline:none; transition:border-color .2s;
}
.finp:focus { border-color:var(--red); }
.fta { min-height:100px; resize:vertical; }

/* UPLOAD */
.upload-area {
  border:2px dashed var(--bd2); border-radius:var(--r);
  padding:24px; text-align:center; cursor:pointer;
  transition:border-color .2s, background .2s;
  background:var(--bg2);
}
.upload-area:active { background:var(--bg3); border-color:var(--red); }
.ua-icon { font-size:32px; margin-bottom:8px; }
.ua-text { font-size:13px; color:var(--txt2); line-height:1.5; }
.ua-text span { font-size:11px; color:var(--txt3); }
.file-previews { display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.fp-img { width:72px; height:72px; border-radius:8px; object-fit:cover; border:1px solid var(--bd2); }
.fp-doc {
  width:72px; height:72px; border-radius:8px;
  background:var(--bg3); border:1px solid var(--bd2);
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; font-size:10px; color:var(--txt3); gap:4px;
}

.save-btn {
  width:100%; background:var(--red); border:none;
  border-radius:var(--r); color:#fff;
  padding:16px; font-size:16px; font-weight:700;
  font-family:'Bebas Neue',sans-serif; letter-spacing:2px;
  transition:all .15s; margin-top:8px;
}
.save-btn:active { transform:scale(.98); opacity:.9; }

/* ═══ EMPTY STATE ═══ */
.empty-state { text-align:center; padding:48px 20px; color:var(--txt3); }
.ei { font-size:48px; margin-bottom:14px; }
.empty-state p { font-size:14px; margin-bottom:4px; }

/* ═══ TOAST ═══ */
.toast {
  position:fixed; bottom:calc(var(--safe-b) + 24px); left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--bg3); border:1px solid var(--bd2);
  border-radius:12px; padding:13px 22px;
  font-size:14px; color:#fff; white-space:nowrap;
  box-shadow:0 8px 32px rgba(0,0,0,.5);
  z-index:9999; opacity:0; transition:all .25s; pointer-events:none;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.ok  { border-left:4px solid var(--teal); }
.toast.err { border-left:4px solid var(--red); }

/* ═══ RESPONSIVE ═══ */
@media(min-width:600px) {
  .home-btns { max-width:400px; margin:0 auto; }
  .home-alerts { max-width:400px; margin:0 auto; }
  .menu-grid { max-width:380px; margin:0 auto; }
  .menu-grid-2 { max-width:480px; margin:0 auto; }
  .pg-body { max-width:560px; margin:0 auto; }
}
