:root{
  --navy:#193847; --navy2:#275671; --gold:#BB9549; --teal:#3CA9AF; --indigo:#3C56A6; --steel:#3F7DA3;
  --bg:#f3f5f7; --line:#e3e7ea; --ok:#1d8a4c; --warn:#BB9549; --danger:#b3261e;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:#1d2b33;line-height:1.5}
.topbar{background:#fff;color:var(--navy);display:flex;align-items:center;justify-content:space-between;padding:10px 18px;flex-wrap:wrap;gap:8px;border-bottom:3px solid var(--gold)}
.brand-wrap{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-logo{height:38px;width:auto;display:block}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand b{font-size:17px;letter-spacing:.14em;color:var(--navy);font-weight:bold}

.nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.nav a{color:var(--navy);text-decoration:none;font-size:14px}
.nav a:hover{color:var(--navy2);text-decoration:underline}
.who{font-size:13px;color:var(--navy2)}
.container{max-width:940px;margin:18px auto;padding:0 14px}
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:16px}
.card.login{max-width:380px;margin:7vh auto;text-align:center}
.login-logo{height:64px;margin:4px auto 6px}
.login-title{letter-spacing:.18em;color:var(--navy);font-weight:bold;margin:0}
.login-sub{letter-spacing:.34em;color:var(--gold);font-size:11px;margin:0 0 8px}
h1{font-size:20px;margin:0 0 14px;color:var(--navy)}
h2{font-size:17px;margin:18px 0 10px;color:var(--navy)}
h3{font-size:15px;margin:16px 0 8px;color:var(--navy2)}
label{display:block;font-size:13px;color:#566;margin:10px 0 4px}
input,select,textarea{width:100%;padding:9px 10px;border:1px solid #c7ccd0;border-radius:7px;font-size:15px;background:#fff;color:#1d2b33}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--steel);box-shadow:0 0 0 3px rgba(63,125,163,.15)}
input[readonly]{background:#f3f3f3}
.row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:8px}
.row input,.row select{width:auto}
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.grid2 .end{display:flex;align-items:flex-end}
.btn{display:inline-block;background:#fff;border:1px solid var(--navy);color:var(--navy);padding:9px 16px;border-radius:7px;font-size:14px;cursor:pointer;text-decoration:none}
.btn:hover{background:#eef2f5}
.btn.primary{background:var(--navy);color:#fff;margin-top:12px;border-color:var(--navy)}
.btn.primary:hover{background:#0f2630}
.link{background:none;border:none;color:var(--navy2);cursor:pointer;font-size:13px;padding:0 4px;text-decoration:underline}
.link.danger{color:var(--danger)}
.inline{display:inline}
.seg{display:flex;gap:18px;margin:6px 0}
.opt{display:flex;align-items:center;gap:6px;font-size:15px}
.opt input{width:auto}
.timebox{margin:10px 0;font-size:15px}
.alert{padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:14px}
.alert.ok{background:#e7f6ec;color:var(--ok);border:1px solid #bfe6cd}
.alert.err{background:#fdecea;color:var(--danger);border:1px solid #f5c6c2}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0 14px}
.metric{background:#eef3f6;border-radius:8px;padding:12px;text-align:center}
.ml{font-size:12px;color:#789}
.mv{font-size:26px;font-weight:bold;color:var(--navy)}
.mv.ok{color:var(--ok)}.mv.warn{color:var(--gold)}
.ok{color:var(--ok)}.warn{color:var(--gold)}.muted{color:#889}.small{font-size:12px}
.map{height:320px;width:100%;border-radius:8px;border:1px solid var(--line);margin:6px 0}
.tbl{width:100%;border-collapse:collapse;font-size:14px;margin:6px 0}
.tbl th,.tbl td{border:1px solid var(--line);padding:6px 9px;text-align:left}
.tbl thead th{background:var(--navy);color:#fff}
.pending{columns:2;font-size:14px}
.route{border:1px solid var(--line);border-radius:8px;padding:10px;margin-bottom:12px;border-left:4px solid var(--gold)}
.route-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.badge{font-size:12px;padding:2px 8px;border-radius:10px}
.badge.on{background:#e7f6ec;color:var(--ok)}
.badge.off{background:#f6efe1;color:var(--gold)}
.nowrap{white-space:nowrap}
.driver-assign{border:1px solid var(--line);border-radius:8px;padding:10px;margin-bottom:10px}
.checks{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0}
.chk{display:flex;align-items:center;gap:6px;font-size:13px;width:auto}
.chk input{width:auto}
.foot{text-align:center;color:#9aa;font-size:12px;padding:18px}

/* --- card-based UI --- */
.routehdr{display:flex;align-items:center;gap:8px;margin:14px 0 8px;font-size:15px;font-weight:bold;color:var(--accent)}
.routehdr .ln{flex:1;height:2px;background:var(--accent);opacity:.4}
.stopcard{border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;margin-bottom:10px;background:var(--card-bg)}
.stopcard-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.stopcard-name{font-weight:bold;display:flex;align-items:center;gap:6px}
.pill{font-size:13px;background:#eef3f6;color:var(--navy);padding:3px 12px;border-radius:20px;white-space:nowrap}
.person{font-size:14px;color:var(--text);padding:2px 0;display:flex;align-items:center;gap:8px}
.person .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}
.pendingbox{border:1px solid #f0e0b8;background:#fff8ec;border-radius:var(--radius);padding:12px}
.pendingbox h2{color:var(--accent);margin:0 0 6px;font-size:15px}
.ico{width:16px;height:16px;flex:none;color:var(--accent)}
.decl{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:8px 12px;margin-bottom:8px}
.decl .d-date{font-weight:bold}
.decl .d-meta{font-size:13px;color:var(--text);opacity:.85}
.badge.work{background:#e7f6ec;color:#1d8a4c}
.badge.off{background:#eee;color:#666}

/* --- cohesive card-app polish (όλες οι σελίδες) --- */
.card{box-shadow:0 1px 3px rgba(0,0,0,.06)}
.topbar{position:sticky;top:0;z-index:20}
.card h2{position:relative;padding-left:12px}
.card h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:3px;border-radius:2px;background:var(--accent)}
.card h1{position:relative;padding-left:12px}
.card h1::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:4px;border-radius:2px;background:var(--accent)}
.btn{transition:background .15s,transform .05s}
.btn:active{transform:scale(.98)}
.card.login{box-shadow:0 4px 16px rgba(0,0,0,.08)}

/* --- tabs (admin sections) --- */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;position:sticky;top:58px;z-index:15;background:var(--page-bg);padding:6px 0}
.tabs button{background:var(--card-bg);border:1px solid var(--line);color:var(--text);padding:8px 16px;border-radius:var(--radius);cursor:pointer;font-size:14px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.tabs button.active{background:var(--primary);color:var(--primary-text);border-color:var(--primary)}
.tab{display:none}
.tab.active{display:block}

/* --- sortable route order --- */
.sortlist{list-style:none;padding:0;margin:0 0 10px}
.sortlist li{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:6px;background:var(--card-bg);cursor:move}
.sortlist li.dragging{opacity:.5;border-color:var(--accent)}
.sortlist .grip{color:var(--accent);cursor:grab;font-size:18px;line-height:1}
.sortlist .ord-btns{margin-left:auto;display:flex;gap:4px}
.sortlist .ord-btns button{border:1px solid var(--line);background:var(--card-bg);border-radius:6px;cursor:pointer;padding:2px 8px;color:var(--text)}

td.grip{cursor:grab;color:var(--accent);font-size:16px;text-align:center}
.sortrows tr{cursor:move}
.sortrows tr.dragging{opacity:.5}
.ord-mini{border:1px solid var(--line);background:var(--card-bg);border-radius:5px;cursor:pointer;padding:1px 6px;color:var(--text);font-size:12px}

/* --- contact modal --- */
.who-link{color:var(--link);cursor:pointer;text-decoration:underline}
.cmodal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;align-items:center;justify-content:center;padding:16px}
.cbox{background:var(--card-bg);border-radius:var(--radius);padding:18px 20px;max-width:340px;width:100%;position:relative;box-shadow:0 8px 30px rgba(0,0,0,.25)}
.cbox h3{color:var(--navy)}
.cclose{position:absolute;top:6px;right:10px;border:none;background:none;font-size:22px;cursor:pointer;color:var(--text)}

/* --- icon buttons --- */
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:28px;border:1px solid var(--line);background:var(--card-bg);border-radius:6px;color:var(--navy2);cursor:pointer;text-decoration:none;vertical-align:middle}
.iconbtn:hover{background:var(--page-bg)}
.iconbtn.danger{color:var(--danger)}
.acts{display:flex;gap:4px;align-items:center}

.ntrow{display:inline-flex;align-items:center;gap:6px;margin:0 8px 6px 0}

.seatwrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.seatchip{font-size:13px;background:var(--page-bg);border:1px solid var(--line);border-radius:20px;padding:3px 10px}
.seatchip.full{background:#fdecea;border-color:#f3c2bd;color:#a3261e}

.da-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.checks2{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:6px}

/* --- week calendar --- */
.weekcal{margin:6px 0}
.wc-nav{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.wc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
@media(max-width:720px){.wc-grid{grid-template-columns:repeat(2,1fr)}}
.wc-cell{display:block;border:1px solid var(--line);border-radius:var(--radius);padding:8px;min-height:80px;text-decoration:none;color:var(--text);background:var(--card-bg)}
.wc-cell:hover{border-color:var(--accent)}
.wc-cell.today{border-color:var(--accent);box-shadow:0 0 0 2px rgba(187,149,73,.25)}
.wc-day{font-size:12px;color:var(--navy2);font-weight:bold;margin-bottom:4px}
.wc-line{font-size:12px;opacity:.85;margin-top:3px}

/* bigger calendar + per-route card accent */
.wc-cell{min-height:118px;padding:10px}
.wc-day{font-size:13px}
.wc-line{font-size:12px;line-height:1.5}
.route-card{border-top:3px solid var(--accent)}
