/* =====================================================================
   VALE OPS — BFL tasarım dili (mavi #2563eb + amber #f59e0b, koyu lacivert)
   Şablonlardaki mevcut sınıf adları korunarak tüm sayfalar bu temaya geçer.
   ===================================================================== */
:root{
  --blue:#2563eb; --blue-700:#1d4ed8; --blue-bg:#eff6ff;
  --ink:#0f172a; --slate:#475569; --muted:#64748b; --faint:#94a3b8;
  --line:#e2e8f0; --bg:#f8fafc; --bg2:#f1f5f9; --surface:#fff;
  --page:#efe9da; --card-line:#e6dfcd; --card-shadow:0 1px 2px rgba(15,23,42,.05),0 3px 10px rgba(15,23,42,.06);
  --amber:#f59e0b; --amber-bg:#fffbeb;
  --green:#16a34a; --green-bg:#f0fdf4;
  --red:#dc2626; --red-bg:#fef2f2;
  --accent:var(--blue);
  --r-sm:12px; --r:14px; --r-lg:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--page);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;
}
a{color:var(--blue);text-decoration:none}
h1,h2,h3{margin:0}

/* ---------- uygulama iskeleti ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:236px;flex-shrink:0;background:var(--ink);color:#e2e8f0;padding:18px 14px;
  display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow:auto;
}
.brand{font-weight:900;letter-spacing:.05em;font-size:17px;color:#fff;display:flex;align-items:center;gap:9px;padding:4px 6px 16px}
.brand .dot{width:11px;height:11px;border-radius:3px;background:var(--amber);display:inline-block}
.nav{display:flex;flex-direction:column;gap:3px}
.nav a{display:block;color:#cbd5e1;padding:10px 12px;border-radius:var(--r-sm);font-weight:700;font-size:13.5px;transition:.15s}
.nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.nav a.active{background:var(--blue);color:#fff}
.nav .group{font-size:10.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);padding:14px 12px 6px}
.main{flex:1;min-width:0;padding:18px 22px 48px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.topbar h1{font-size:20px;font-weight:900;letter-spacing:-.01em}
.menu-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:10px;width:40px;height:40px;font-size:20px;cursor:pointer;color:var(--ink)}
.user-chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:12.5px;font-weight:700;color:var(--slate)}
.user-chip b{color:var(--ink)}

/* ---------- kart / grid ---------- */
.card{background:var(--surface);border:1px solid var(--card-line);border-radius:var(--r-lg);padding:16px;margin-bottom:14px;box-shadow:var(--card-shadow)}
.card h3{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.03em;margin-bottom:12px;color:var(--ink)}
.grid{display:grid;gap:14px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.muted{color:var(--muted)}
.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.empty-state,.card.muted{padding:18px;text-align:center;color:var(--faint);font-weight:700;font-size:13px;
  background:var(--bg);border-radius:var(--r);border:1px dashed var(--line)}

/* ---------- başlık barları (form bölümleri) ---------- */
.section-title{font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;
  padding-left:10px;border-left:4px solid var(--faint);margin-bottom:12px;color:var(--ink)}
.section-title.blue{border-color:var(--blue)} .section-title.green{border-color:var(--green)}
.section-title.red{border-color:var(--red)} .section-title.amber{border-color:var(--amber)}

/* ---------- formlar ---------- */
label{display:block;font-size:12px;font-weight:800;color:var(--slate);margin-bottom:6px;margin-top:10px}
input,select,textarea{
  width:100%;border:1px solid var(--line);background:#fff;border-radius:var(--r);
  padding:11px 13px;font-size:13.5px;font-weight:700;color:var(--ink);outline:none;font-family:inherit;transition:.15s}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}
textarea{resize:vertical}
input[type=checkbox],input[type=radio]{width:auto}

/* ---------- butonlar ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;cursor:pointer;
  font-weight:800;border-radius:var(--r);padding:10px 16px;font-size:13.5px;transition:.15s;font-family:inherit;line-height:1.1}
.btn.accent,.btn-primary{background:var(--blue);color:#fff}
.btn.accent:hover{background:var(--blue-700)}
.btn.ghost,.btn-secondary{background:#fff;color:var(--slate);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn.success{background:var(--green);color:#fff}
.btn.dark{background:var(--ink);color:#fff}
.btn.sm{padding:7px 12px;font-size:12px;border-radius:10px}
.btn.full{width:100%}
.btn.xl{padding:15px;font-size:15px;border-radius:var(--r-lg)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- rozetler ---------- */
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 11px;font-size:11px;font-weight:900}
.b-ok,.badge-success{background:var(--green-bg);color:var(--green)}
.b-info,.badge-info{background:var(--blue-bg);color:var(--blue)}
.b-warn,.badge-warn{background:var(--amber-bg);color:var(--amber)}
.b-danger,.badge-danger{background:var(--red-bg);color:var(--red)}
.b-mute,.badge-neutral{background:var(--bg2);color:var(--slate)}
.plate{display:inline-block;background:var(--ink);color:#fff;font-weight:900;letter-spacing:.04em;
  border-radius:8px;padding:3px 9px;font-size:12.5px}
.plate a{color:#fff}

/* ---------- tablo ---------- */
.table-wrap{overflow:auto;border:1px solid var(--card-line);border-radius:var(--r);background:#fff;box-shadow:var(--card-shadow)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--bg);text-align:left;padding:10px 12px;font-size:11px;font-weight:900;
  letter-spacing:.03em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line)}
tbody td{padding:11px 12px;border-bottom:1px solid var(--bg2);font-weight:600}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--bg)}

/* ---------- tanım listesi ---------- */
dl.kv{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;margin:0}
dl.kv dt{color:var(--faint);font-weight:800;font-size:11.5px;text-transform:uppercase;letter-spacing:.02em}
dl.kv dd{margin:0;font-weight:700}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px}
.kpi .v{font-size:25px;font-weight:900;letter-spacing:-.02em}
.kpi .l{color:var(--muted);font-size:12px;font-weight:700;margin-top:2px}

/* ---------- araç özet ---------- */
.vehicle-summary{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.vehicle-summary>div{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:9px 11px;display:flex;flex-direction:column;gap:2px}
.vehicle-summary span{font-size:10.5px;font-weight:800;color:var(--faint);text-transform:uppercase;letter-spacing:.03em}
.vehicle-summary b{font-size:13.5px;color:var(--ink)}

/* ---------- flash ---------- */
.flash{padding:11px 14px;border-radius:var(--r);font-weight:700;font-size:13px;margin-bottom:12px;border:1px solid}
.flash.error{background:var(--red-bg);color:var(--red);border-color:#fecaca}
.flash.ok,.flash.success{background:var(--green-bg);color:var(--green);border-color:#bbf7d0}
.flash.info{background:var(--blue-bg);color:var(--blue);border-color:#bfdbfe}

/* ---------- aranabilir araç seçici ---------- */
.veh-search-box{position:relative}
.veh-results{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:40;background:#fff;
  border:1px solid var(--line);border-radius:var(--r);box-shadow:0 12px 30px rgba(15,23,42,.12);max-height:300px;overflow:auto}
/* ---------- toplu seçim çubuğu ---------- */
.bulk-bar{position:sticky;bottom:14px;margin-top:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:12px 18px;box-shadow:0 10px 30px rgba(15,23,42,.35);z-index:50}
.bulk-bar b{color:var(--amber)}

/* ---------- genel yardımcılar ---------- */
.hidden{display:none !important}

/* ---------- araç liste görünümü ---------- */
.veh-list{display:flex;flex-direction:column;gap:10px}
.veh-item{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--card-line);border-radius:var(--r-lg);padding:12px 14px;box-shadow:var(--card-shadow)}
.veh-item .thumb-img{width:72px;height:54px;border-radius:10px;object-fit:cover;background:var(--bg2);flex-shrink:0}
.veh-item .thumb-ph{width:72px;height:54px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--faint);font-size:24px;flex-shrink:0}
.veh-item .vi-main{flex:1;min-width:0}
.veh-item .vi-main .vi-meta{color:var(--muted);font-size:12.5px;font-weight:700;margin-top:3px;display:flex;flex-wrap:wrap;gap:6px 14px}
.veh-item .vi-actions{display:flex;gap:8px;flex-shrink:0}
@media(max-width:640px){.veh-item{flex-wrap:wrap}.veh-item .vi-actions{width:100%}}

/* ---------- veh-results (yeniden) ---------- */
.veh-results.hidden{display:none}
.veh-row{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--bg2)}
.veh-row:last-child{border-bottom:0}.veh-row:hover,.veh-row.active{background:var(--blue-bg)}
.veh-row .vp{font-weight:900;font-size:12.5px;background:var(--ink);color:#fff;border-radius:7px;padding:3px 8px}
.veh-row .vmeta{font-size:12px;color:var(--slate);font-weight:700}
.veh-hint{padding:10px 12px;font-size:11.5px;color:var(--faint);font-weight:700}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--blue-bg);border:1px solid #bfdbfe;
  border-radius:999px;padding:6px 8px 6px 12px;font-weight:800;font-size:12.5px;color:var(--blue)}
.chip .vp{background:var(--blue);color:#fff;border-radius:6px;padding:2px 7px;font-size:11.5px}
.chip .x{border:0;background:transparent;color:var(--blue);font-weight:900;cursor:pointer;font-size:15px;line-height:1}

/* ---------- demirbaş ---------- */
.equip-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.equip-item{display:flex;align-items:center;justify-content:space-between;border-radius:var(--r);padding:11px 13px;
  font-size:12.5px;font-weight:800;cursor:pointer;user-select:none;border:1px solid var(--line)}
.equip-on{background:var(--green-bg);border-color:#bbf7d0;color:#15803d}
.equip-off{background:var(--bg);color:var(--muted)}

/* ---------- foto slotları ---------- */
.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.upload-card{position:relative;border:1.5px dashed var(--line);border-radius:var(--r);background:var(--bg);padding:12px;min-height:96px;display:flex;flex-direction:column;gap:8px;transition:.15s}
.upload-card.has-files{border-style:solid;border-color:#bfdbfe;background:#fff}
.upload-card .slot-head{display:flex;align-items:center;justify-content:space-between}
.upload-card .slot-head b{font-size:12.5px}
.upload-card .slot-head .add{font-size:11px;font-weight:900;color:var(--blue);background:var(--blue-bg);border:0;border-radius:8px;padding:5px 9px;cursor:pointer}
.slot-empty{font-size:11.5px;color:var(--faint);font-weight:700}
.slot-thumbs{display:flex;flex-wrap:wrap;gap:7px}
.thumb{position:relative;width:60px;height:60px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#fff}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb .del{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:0;background:rgba(220,38,38,.92);color:#fff;font-size:12px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.upload-big{min-height:120px}.upload-big .thumb{width:86px;height:86px}

/* ---------- hasar ---------- */
.damage-row{border:1px solid var(--line);border-radius:var(--r);padding:11px;margin-bottom:10px;background:var(--bg)}
.damage-row .dr-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.damage-row .dr-head b{font-size:12px;color:var(--red);font-weight:900}
.damage-row .rm{border:0;background:var(--red-bg);color:var(--red);border-radius:8px;padding:5px 9px;font-weight:900;cursor:pointer;font-size:11px}

/* ---------- imza ---------- */
canvas.sig-pad{width:100%;height:180px;background:#fff;border:1.5px dashed var(--line);border-radius:var(--r);touch-action:none;display:block}

/* ---------- foto galeri (detay) ---------- */
.tm-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}
.tm-photo-card{margin:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.tm-photo-card img{width:100%;height:110px;object-fit:cover;display:block}
.tm-photo-card figcaption{padding:7px 9px;font-size:11px;font-weight:800;color:var(--slate)}

/* ---------- akış afişi ---------- */
.flow-banner{display:flex;align-items:center;gap:10px;background:var(--blue-bg);border:1px solid #bfdbfe;border-radius:var(--r);padding:11px 13px;margin-bottom:14px;font-size:12.5px;font-weight:800;color:var(--blue)}
.flow-banner .step{background:var(--blue);color:#fff;border-radius:999px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:900;flex-shrink:0}

/* ---------- yıldız ---------- */
.stars{display:flex;flex-direction:row-reverse;justify-content:center;gap:6px;margin:8px 0}
.stars input{display:none}
.stars label{font-size:38px;color:var(--line);cursor:pointer;line-height:1;margin:0}
.stars input:checked ~ label,.stars label:hover,.stars label:hover ~ label{color:var(--amber)}

/* ---------- herkese açık sayfalar ---------- */
.public-wrap{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:24px 16px}
.public-card{width:100%;max-width:460px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 20px;box-shadow:0 8px 30px rgba(15,23,42,.06)}
.public-card .brand{color:var(--ink)}
.public-card h2{font-size:19px;margin-bottom:4px}
.public-card .sub{color:var(--muted);font-size:14px;margin-bottom:16px;font-weight:600}
.big-btn{display:block;width:100%;text-align:center;padding:15px;border-radius:var(--r);border:0;font-size:16px;font-weight:800;cursor:pointer;margin-top:10px}
.big-btn.accent{background:var(--blue);color:#fff}.big-btn.ok{background:var(--green);color:#fff}
.big-btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}

/* ---------- mobil ---------- */
@media(max-width:860px){
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center}
  .sidebar{position:fixed;z-index:60;left:-260px;transition:left .2s;box-shadow:0 0 40px rgba(0,0,0,.3)}
  .sidebar.open{left:0}
  .main{padding:14px}
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}
  .topbar h1{font-size:17px}
}

/* ---------- numaralı sayfalama ---------- */
.pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;margin-top:18px}
.pg{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;
  background:#fff;border:1px solid var(--card-line);border-radius:10px;font-weight:800;font-size:13px;
  color:var(--slate);text-decoration:none;box-shadow:var(--card-shadow)}
.pg:hover{border-color:var(--blue);color:var(--blue)}
.pg.cur{background:var(--blue);color:#fff;border-color:var(--blue)}
.pg.dots{box-shadow:none;border:none;background:transparent;min-width:20px;color:var(--faint)}

/* ---------- KPI kartları ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.kpi-card{background:#fff;border:1px solid var(--card-line);border-radius:var(--r-lg);padding:16px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:6px}
.kpi-label{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.kpi-value{font-size:28px;font-weight:900;color:var(--ink);line-height:1}
