/* Full Stack Developer Hakan Sevim */
:root{
  --bg:#f4f6fa;--surface:#ffffff;--surface-2:#fafbfd;--ink:#1b2533;--muted:#64728a;
  --line:#e5e9f1;--line-2:#eef1f7;--accent:#2563eb;--accent-soft:#eaf1ff;
  --green:#0f9d58;--green-soft:#e6f6ee;--amber:#d97706;--amber-soft:#fdf3e3;
  --red:#dc2626;--red-soft:#fdecec;--teal:#0d9488;--radius:12px;--radius-sm:8px;
  --shadow:0 1px 2px rgba(20,30,50,.04),0 4px 16px rgba(20,30,50,.05);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.layout{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--surface);border-right:1px solid var(--line);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:40}
.brand{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--line);font-weight:700;font-size:15px;letter-spacing:-.01em}
.brand .logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--teal));display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto}
.nav{flex:1;overflow-y:auto;padding:10px 12px}
.nav-group{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:14px 12px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--ink);font-weight:500;margin-bottom:2px}
.nav a:hover{background:var(--surface-2);text-decoration:none}
.nav a.active{background:var(--accent-soft);color:var(--accent)}
.nav a.active svg{color:var(--accent)}
.nav a svg{width:18px;height:18px;color:var(--muted);flex:0 0 auto}
.main{flex:1;margin-left:248px;display:flex;flex-direction:column;min-width:0}
.topbar{height:60px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:30}
.topbar h1{font-size:17px;font-weight:650;margin:0;letter-spacing:-.01em}
.topbar .right{display:flex;align-items:center;gap:14px}
.user-chip{display:flex;align-items:center;gap:9px;font-weight:500}
.user-chip .avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600}
.content{padding:24px;flex:1}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.page-head .title{font-size:20px;font-weight:680;letter-spacing:-.02em;margin:0}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:20px}
.card-head{padding:16px 20px;border-bottom:1px solid var(--line-2);font-weight:620;display:flex;align-items:center;justify-content:space-between}
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.kpi .label{font-size:12.5px;color:var(--muted);font-weight:500;display:flex;align-items:center;gap:8px}
.kpi .label svg{width:16px;height:16px}
.kpi .value{font-size:28px;font-weight:720;margin-top:8px;letter-spacing:-.02em}
.kpi.alarm .value{color:var(--red)}
.kpi.good .value{color:var(--green)}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:9px 15px;border-radius:var(--radius-sm);font-weight:560;font-size:13.5px;cursor:pointer;font-family:inherit;transition:.12s}
.btn:hover{background:var(--surface-2);text-decoration:none}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:#1d4ed8}
.btn-danger{background:var(--red);border-color:var(--red);color:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-ghost{border-color:transparent;background:transparent}
.btn-sm{padding:6px 11px;font-size:12.5px}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:11px 16px;border-bottom:1px solid var(--line)}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface-2)}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;background:var(--line-2);color:var(--muted)}
.badge.green{background:var(--green-soft);color:var(--green)}
.badge.amber{background:var(--amber-soft);color:var(--amber)}
.badge.red{background:var(--red-soft);color:var(--red)}
.badge.blue{background:var(--accent-soft);color:var(--accent)}
.form-row{margin-bottom:16px}
.form-row label{display:block;font-weight:560;font-size:13px;margin-bottom:6px}
.form-row .hint{font-size:12px;color:var(--muted);margin-top:5px}
input[type=text],input[type=password],input[type=email],input[type=number],input[type=time],input[type=date],input[type=search],select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;background:var(--surface);color:var(--ink);transition:.12s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
textarea{resize:vertical;min-height:84px}
.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cols-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.check-line{display:flex;align-items:center;gap:9px;padding:8px 0}
.check-line input{width:auto}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar .grow{flex:1}
.flash{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:18px;font-weight:540;display:flex;align-items:center;gap:10px}
.flash.success{background:var(--green-soft);color:var(--green)}
.flash.error{background:var(--red-soft);color:var(--red)}
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty svg{width:42px;height:42px;opacity:.4;margin-bottom:12px}
.pill-methods{display:flex;gap:5px;flex-wrap:wrap}
.muted{color:var(--muted)}
.right{text-align:right}
.flex{display:flex;align-items:center;gap:10px}
.gap{gap:10px}
.mt{margin-top:16px}.mb{margin-bottom:16px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--muted)}
.dot.on{background:var(--green)}
.list-actions{display:flex;gap:6px;justify-content:flex-end}
.split{display:grid;grid-template-columns:2fr 1fr;gap:16px}
#map{height:calc(100vh - 160px);border-radius:var(--radius);border:1px solid var(--line);overflow:hidden}
.alert-item{padding:12px 16px;border-bottom:1px solid var(--line-2);display:flex;gap:10px;align-items:flex-start}
.alert-item:last-child{border-bottom:none}
.alert-item .ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.alert-item .ic.critical{background:var(--red-soft);color:var(--red)}
.alert-item .ic.warning{background:var(--amber-soft);color:var(--amber)}
.alert-item .ic.info{background:var(--accent-soft);color:var(--accent)}
.alert-item .msg{font-weight:540;font-size:13.5px}
.alert-item .meta{font-size:12px;color:var(--muted);margin-top:2px}
.progress{height:6px;background:var(--line-2);border-radius:99px;overflow:hidden;min-width:90px}
.progress > i{display:block;height:100%;background:var(--accent);border-radius:99px}
.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.qr-cell{border:1px solid var(--line);border-radius:var(--radius);padding:16px;text-align:center}
.qr-cell .qbox{display:flex;justify-content:center;margin-bottom:10px}
@media(max-width:880px){
  .sidebar{transform:translateX(-100%);transition:.2s}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .cols-2,.cols-3,.split{grid-template-columns:1fr}
}
/* Full Stack Developer Hakan Sevim */

/* ===== Full Stack Developer Hakan Sevim — Canlı İzleme ===== */
.live-status{display:flex;align-items:center;gap:8px;font-size:13px}
.live-dot{width:9px;height:9px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:livePulse 2s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.kpi.alarm .value{color:#dc2626}
.kpi.alarm{border-color:#fbd5d5}

.live-grid{display:grid;grid-template-columns:1fr 372px;gap:16px;align-items:start}
.live-map-wrap{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--border,#e5e9f1);box-shadow:0 1px 3px rgba(16,24,40,.06)}
#map{height:600px;width:100%}
.map-recenter{position:absolute;top:12px;right:12px;z-index:5;width:40px;height:40px;border-radius:10px;border:1px solid var(--border,#e5e9f1);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(16,24,40,.12);color:#2563eb}
.map-recenter:hover{background:#f5f8ff}

.live-side{display:flex;flex-direction:column;gap:16px}
.side-scroll{max-height:200px;overflow-y:auto;padding:6px}
.live-side .card:first-child .side-scroll{max-height:230px}

.guard-row{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:10px;cursor:pointer;transition:background .15s}
.guard-row:hover{background:#f5f8ff}
.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;background:#94a3b8;flex:0 0 auto;position:relative}
.avatar.on{background:#22c55e}.avatar.idle{background:#f59e0b}.avatar.off{background:#94a3b8}.avatar.sos{background:#dc2626;animation:livePulse 1.3s infinite}
.gr-main{flex:1;min-width:0}
.gr-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gr-sub{display:flex;align-items:center;gap:6px;font-size:12px;color:#8e97a6;margin-top:1px}
.st-dot{width:7px;height:7px;border-radius:50%;background:#94a3b8;flex:0 0 auto}
.st-dot.on{background:#22c55e}.st-dot.idle{background:#f59e0b}.st-dot.off{background:#94a3b8}.st-dot.sos{background:#dc2626}
.battery{position:relative;width:46px;height:20px;border:1.5px solid #cbd5e1;border-radius:4px;flex:0 0 auto;display:flex;align-items:center;overflow:hidden}
.battery::after{content:"";position:absolute;right:-4px;top:5px;width:3px;height:8px;background:#cbd5e1;border-radius:0 2px 2px 0}
.bat-fill{position:absolute;left:0;top:0;bottom:0;background:#22c55e;opacity:.25}
.battery.low .bat-fill{background:#dc2626}.battery.mid .bat-fill{background:#f59e0b}
.battery i{position:relative;width:100%;text-align:center;font-style:normal;font-size:10px;font-weight:700;color:#475569}
.battery.low i{color:#dc2626}

.run-row{padding:10px;border-radius:10px;background:#f8fafc;margin-bottom:7px}
.run-row:last-child{margin-bottom:0}
.rr-top{display:flex;justify-content:space-between;align-items:center}
.rr-tour{font-weight:600;font-size:14px}
.rr-count{font-size:12px;font-weight:700;color:#2563eb}
.rr-site{font-size:12px;color:#8e97a6;margin:2px 0 8px}
.rr-bar{height:7px;background:#e8edf5;border-radius:99px;overflow:hidden}
.rr-bar i{display:block;height:100%;background:#2563eb;border-radius:99px;transition:width .5s}

.alert-row{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;margin-bottom:7px;border-left:3px solid #94a3b8;background:#f8fafc}
.alert-row:last-child{margin-bottom:0}
.alert-row.critical{border-left-color:#dc2626;background:#fef4f4}
.alert-row.warning{border-left-color:#f59e0b;background:#fffaf2}
.alert-row.info{border-left-color:#2563eb;background:#f5f8ff}
.ar-main{flex:1;min-width:0}
.ar-msg{font-size:13.5px;font-weight:500;line-height:1.35}
.ar-meta{font-size:11.5px;color:#8e97a6;margin-top:2px}
.ar-ack{flex:0 0 auto;border:1px solid #d6dde9;background:#fff;color:#475569;font-size:12px;font-weight:600;padding:6px 11px;border-radius:8px;cursor:pointer}
.ar-ack:hover{background:#2563eb;color:#fff;border-color:#2563eb}
.ar-ack:disabled{opacity:.5}

.guard-marker{display:flex;align-items:center;gap:5px;cursor:pointer;transform:translateX(-7px)}
.guard-marker .gm-dot{width:14px;height:14px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.35);background:#94a3b8;flex:0 0 auto}
.guard-marker.on .gm-dot{background:#22c55e}.guard-marker.idle .gm-dot{background:#f59e0b}.guard-marker.off .gm-dot{background:#94a3b8}
.guard-marker.sos .gm-dot{background:#dc2626;animation:livePulse 1.2s infinite}
.guard-marker .gm-label{background:rgba(255,255,255,.95);padding:2px 8px;border-radius:99px;font-size:12px;font-weight:600;color:#1b2533;white-space:nowrap;box-shadow:0 1px 4px rgba(0,0,0,.18)}
.site-marker{width:13px;height:13px;border-radius:3px;background:#6366f1;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.sos-marker{width:22px;height:22px;border-radius:50%;background:rgba(220,38,38,.25);border:2px solid #dc2626;animation:livePulse 1.2s infinite}

@media(max-width:980px){.live-grid{grid-template-columns:1fr}#map{height:380px}.side-scroll{max-height:240px}}
/* ===== Full Stack Developer Hakan Sevim ===== */

