/* =========================================================================
   Autopark Paneli — mobil uygulama görünümü
   ========================================================================= */
:root{
  --bg:#eef2f7; --app-bg:#f7f9fc; --card:#ffffff;
  --text:#0f172a; --muted:#64748b; --border:#e2e8f0;
  --accent:#e40917; --accent-d:#c00714;
  --green:#16a34a; --amber:#d97706; --danger:#dc2626;
  --radius:14px; --shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.04);
  --appbar-h:56px; --tabbar-h:64px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--text); -webkit-text-size-adjust:100%;
}
a{color:var(--accent);text-decoration:none}

/* App çerçevesi — masaüstünde telefon kolonu gibi ortalanır */
.app{
  max-width:640px; margin:0 auto; min-height:100vh; background:var(--app-bg);
  position:relative; padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 14px);
  box-shadow:0 0 40px rgba(15,23,42,.06);
}

/* Üst bar */
.appbar{
  position:sticky; top:0; z-index:40; height:var(--appbar-h);
  background:#0f172a; color:#fff; display:flex; align-items:center;
  padding:0 18px; padding-top:env(safe-area-inset-top);
}
.appbar-title{display:none;font-size:18px;font-weight:700;letter-spacing:.2px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ab-logo{height:30px;width:auto;max-width:200px;object-fit:contain;margin:0 auto;
  background:linear-gradient(180deg,var(--accent),var(--accent-d));border-radius:9px;padding:6px 13px;
  box-shadow:0 6px 16px -8px rgba(0,0,0,.6)}
.ab-profile{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:38px;height:38px;display:flex;align-items:center;justify-content:center;color:#fff;border-radius:50%;background:rgba(255,255,255,.14)}
.ab-profile svg{width:21px;height:21px}
.ab-profile.active{background:#fff;color:var(--accent)}

.content{padding:16px}

/* Alt tab bar */
.tabbar{
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:640px; height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:#fff; border-top:1px solid var(--border);
  display:flex; align-items:center; z-index:50;
}
.tab-group{flex:1;display:flex;align-items:center;justify-content:space-around}
.tab{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  color:var(--muted); font-size:11px; font-weight:600; padding:8px 2px;
}
.tab-icon svg{width:24px;height:24px;display:block}
.tab.active{color:var(--accent)}
.tab-center .tab-icon{
  width:52px;height:52px;border-radius:50%; margin-top:-26px;
  background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 16px rgba(228,9,23,.45); border:4px solid var(--app-bg);
}
.tab-center .tab-icon svg{width:26px;height:26px}
.tab-center{flex:0 0 auto;color:var(--accent)}

/* Selamlama */
.hello{font-size:15px;color:var(--muted);margin:2px 0 14px}
.hello strong{color:var(--text)}

/* Anasayfa hızlı arama (plaka / müşteri / telefon) */
.dash-search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);
  border-radius:14px;padding:6px 6px 6px 14px;box-shadow:var(--shadow);margin-bottom:16px}
.dash-search svg{width:21px;height:21px;color:var(--muted);flex:0 0 auto}
.dash-search input{flex:1;min-width:0;border:0;outline:none;background:transparent;font-size:16px;padding:11px 4px;color:var(--text)}
.dash-search button{flex:0 0 auto;background:var(--accent);color:#fff;border:0;border-radius:10px;padding:11px 20px;font-weight:800;font-size:15px;cursor:pointer}
.dash-search button:hover{background:var(--accent-d)}

/* İstatistik kartları */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow)}
.stat-num{font-size:30px;font-weight:800;line-height:1}
.stat-num.accent{color:var(--accent)} .stat-num.green{color:var(--green)} .stat-num.amber{color:var(--amber)}
.stat-label{margin-top:6px;font-size:13px;color:var(--muted);font-weight:600}

/* Bölüm başlığı */
.section-head{display:flex;align-items:center;justify-content:space-between;margin:18px 2px 10px}
.section-head h2{font-size:16px;margin:0}
.link{font-size:14px;font-weight:600}

/* Kart */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);margin-bottom:12px}

/* Liste */
.list{display:flex;flex-direction:column;gap:8px}
.list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:13px 15px;box-shadow:var(--shadow);color:var(--text)}
.li-title{font-size:16px;font-weight:700;letter-spacing:.5px}
.li-sub{font-size:13px;color:var(--muted);margin-top:2px}
.li-side{text-align:right;flex-shrink:0}
.li-date{font-size:12px;color:var(--muted);margin-top:5px}

/* Rozet */
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.badge-amber{background:#fef3c7;color:#b45309}
.badge-green{background:#dcfce7;color:#15803d}
.badge-gray{background:#e2e8f0;color:#475569}
.badge-red{background:#fee2e2;color:#b91c1c}
.tag-mini{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.02em;padding:1px 6px;border-radius:6px;background:rgba(228,9,23,.1);color:var(--accent);vertical-align:middle}
/* Basit kart-form (PPF ürün / stok girişi) */
.card-form{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:18px}
.card-form .btn-block{margin-top:16px}
.form-grid2{display:grid;grid-template-columns:1fr;gap:0 14px}
@media(min-width:560px){.form-grid2{grid-template-columns:1fr 1fr}}
.chk-line{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--ink);margin:14px 0 0;cursor:pointer}
.chk-line input{width:18px;height:18px;accent-color:var(--accent)}
/* PPF sevkiyat — tarayıcı + okutulan seri listesi */
.scan-box{margin:14px 0 6px}
.scan-region{width:100%;max-width:340px;margin:10px auto;border-radius:14px;overflow:hidden;background:#0b1220}
.scan-region.flash-ok{animation:sf-ok .45s ease}
.scan-region.flash-err{animation:sf-err .55s ease}
@keyframes sf-ok{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 4px #22c55e}}
@keyframes sf-err{0%,100%{box-shadow:none}20%,60%{box-shadow:0 0 0 4px #ef4444}}
.scan-manual{display:flex;gap:8px;margin-top:10px}
.scan-manual .field{flex:1}
.scan-msg{margin-top:9px;padding:9px 12px;border-radius:10px;font-size:13px;font-weight:700}
.scan-msg.ok{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}
.scan-msg.err{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.ship-list-head{display:flex;align-items:center;justify-content:space-between;margin:16px 0 8px;font-weight:800;font-size:14px;color:var(--ink)}
.ship-list{display:flex;flex-direction:column;gap:7px}
.ship-chip{display:flex;align-items:center;gap:10px;justify-content:space-between;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.ship-chip .sc-serial{font-family:'Courier New',monospace;font-weight:800;font-size:13.5px;letter-spacing:.03em;color:var(--ink)}
.ship-chip .sc-prod{font-size:12px;color:var(--muted)}
.ship-chip .sc-x{flex:none;width:30px;height:30px;border:0;border-radius:8px;background:#fef2f2;color:#b91c1c;font-size:20px;line-height:1;cursor:pointer}
/* Garanti formu — PPF seri bölümü */
.ppf-serial-sec{margin-top:20px;padding-top:14px;border-top:1px dashed var(--border)}
.ppf-half{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--muted);margin-top:6px;cursor:pointer}
.ppf-half input{width:15px;height:15px;accent-color:var(--accent)}
.ship-chip.ppf-chip-saved{background:#f0fdf4;border-color:#bbf7d0}
/* PPF rapor merkezi — masaüstünde dengeli ızgara */
.rep-wrap{max-width:1040px}
.rep-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:12px;margin-bottom:8px}
.rep-kpis .stat{margin:0}
.rep-links{display:grid;grid-template-columns:1fr;gap:10px;margin:6px 0 4px}
@media(min-width:680px){.rep-links{grid-template-columns:1fr 1fr}}
.rep-link{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:14px;background:#fff;text-decoration:none;transition:border-color .15s,box-shadow .15s}
.rep-link:hover{border-color:var(--accent);box-shadow:0 8px 22px -12px rgba(228,9,23,.4)}
.rep-link .rl-t{font-weight:800;font-size:15px;color:var(--ink)}
.rep-link .rl-s{font-size:12.5px;color:var(--muted);margin-top:3px}
.rep-link .rl-go{flex:none;color:var(--accent);font-weight:800;font-size:18px}
/* PPF Stok aksiyon çubuğu — Stok Girişi sağda */
.ppf-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.ppf-actions .ppf-add{margin-left:auto}
/* Hatırlatmalar (yaklaşan bitişler) */
.rem-list{display:flex;flex-direction:column;gap:10px}
.rem-item{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:12px 14px}
.rem-main{min-width:0;flex:1}
.rem-top{display:flex;align-items:center;gap:10px;margin-bottom:3px}
.rem-plate{font-weight:800;font-size:16px;color:var(--text);text-decoration:none}
.rem-plate:hover{color:var(--accent)}
.rem-actions{display:flex;gap:8px;flex:0 0 auto;align-items:center}
.rem-actions form{margin:0}
@media(max-width:560px){.rem-item{flex-direction:column;align-items:stretch}.rem-actions{justify-content:flex-end}}
/* Denetim günlüğü / işlem geçmişi */
.audit-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.audit-item{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.audit-item .badge{flex:0 0 auto;margin-top:1px}
.audit-main{min-width:0;flex:1}
.audit-detail{font-size:14px;color:var(--text);word-break:break-word}
.audit-detail a{color:var(--accent);font-weight:700;text-decoration:none}
.audit-meta{font-size:12px;color:var(--muted);margin-top:2px}

/* Butonlar */
.btn{display:inline-block;text-align:center;background:var(--accent);color:#fff;border:0;
  border-radius:12px;padding:12px 18px;font-size:15px;font-weight:700;cursor:pointer}
.btn:hover{background:var(--accent-d)}
.btn-block{display:block;width:100%}
.btn-lg{padding:15px;font-size:16px}
.btn-new{margin:4px 0 4px}
.btn-outline{background:#fff;color:var(--accent);border:1.5px solid var(--accent)}
.btn-outline:hover{background:#eff6ff}
.btn-danger{background:var(--danger)} .btn-danger:hover{filter:brightness(.94)}

/* Boş durum */
.empty{text-align:center;padding:34px 18px;color:var(--muted)}
.empty-icon{font-size:34px;margin-bottom:8px}
.empty-title{font-size:16px;font-weight:700;color:var(--text)}
.empty-desc{font-size:14px;margin-top:6px;line-height:1.5}

/* Uyarı kutuları (flash) */
.alert{padding:12px 14px;border-radius:12px;font-size:14px;margin-bottom:12px;border:1px solid transparent}
.alert-success{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}
.alert-error{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.alert-warning{background:#fffbeb;color:#b45309;border-color:#fde68a}
.alert-info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}

/* Form alanları */
.field-label{display:block;font-size:13px;font-weight:600;margin:14px 0 6px;color:#334155}
.field{width:100%;padding:13px 14px;border:1px solid #cbd5e1;border-radius:12px;
  font-size:16px;background:#fff;color:var(--text)}
.field:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,9,23,.15)}

/* Hesap / profil */
.profile{display:flex;align-items:center;gap:14px}
.avatar{width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800}
.profile-name{font-size:17px;font-weight:700}
.profile-role{font-size:13px;color:var(--muted);margin-top:2px}
.menu{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--radius);
  overflow:hidden;border:1px solid var(--border);margin-bottom:18px}
.menu-item{display:flex;align-items:center;justify-content:space-between;background:#fff;
  padding:15px 16px;font-size:15px;font-weight:600;color:var(--text)}
.menu-item.danger{color:var(--danger)}
.menu-item.disabled{color:var(--muted);font-weight:600}
.chev{color:var(--muted);font-size:20px;line-height:1}
.soon-tag{font-size:11px;background:#e2e8f0;color:#475569;padding:2px 8px;border-radius:999px;font-weight:700}
.app-version{text-align:center;color:var(--muted);font-size:12px;margin-top:6px}

/* Giriş ekranı (tab bar yok) */
html:has(.auth-body){height:100%}
.auth-body{position:relative;margin:0;overflow:hidden;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:#0b0e13}
.auth-body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(900px 520px at 85% -12%,rgba(228,9,23,.5),transparent 60%),
            radial-gradient(720px 520px at -12% 112%,rgba(228,9,23,.28),transparent 55%),
            linear-gradient(160deg,#0b0e13,#11161f);
  background-repeat:no-repeat}
.auth-orb{display:none}
.auth-orb.a{width:430px;height:430px;background:#E40917;top:-150px;right:-110px;opacity:.30}
.auth-orb.b{width:340px;height:340px;background:#E40917;bottom:-120px;left:-110px;opacity:.16}
.auth-wrap{width:100%;max-width:400px;position:relative;z-index:2}
.auth-card{position:relative;background:#fff;border-radius:22px;padding:34px 30px 28px;overflow:hidden;
  box-shadow:0 40px 90px -28px rgba(0,0,0,.7)}
.auth-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,#FF2A37,var(--accent-d))}
.auth-logo{font-size:26px;font-weight:900;text-align:center;color:var(--accent)}
.auth-logo-img{display:block;max-width:240px;max-height:84px;margin:4px auto 0;object-fit:contain}
.auth-title{text-align:center;font-size:22px;font-weight:800;letter-spacing:-.01em;margin:18px 0 2px;color:var(--text)}
.auth-sub{text-align:center;color:var(--muted);font-size:13.5px;margin:0 0 22px}
.auth-flabel{display:block;font-size:12.5px;font-weight:700;color:#475569;margin:0 0 6px 2px}
.auth-field{position:relative;margin-bottom:14px}
.auth-field>svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:#94a3b8;pointer-events:none}
.auth-field input{width:100%;padding:14px 14px 14px 44px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;background:#fff;transition:border-color .15s,box-shadow .15s}
.auth-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,9,23,.12)}
.auth-btn{width:100%;margin-top:8px;padding:15px;border:0;border-radius:12px;color:#fff;font-weight:800;font-size:16px;cursor:pointer;
  background:linear-gradient(135deg,#FF2A37,var(--accent-d));box-shadow:0 14px 30px -12px rgba(228,9,23,.7);transition:filter .15s,transform .1s}
.auth-btn:hover{filter:brightness(1.06)}
.auth-btn:active{transform:translateY(1px)}
.auth-link{display:block;text-align:center;margin-top:18px;color:var(--accent);font-weight:700;font-size:14px}
.auth-foot{text-align:center;color:rgba(255,255,255,.5);font-size:12px;margin-top:18px}

/* ====================== Aşama 2 bileşenleri ====================== */
.page-hint{color:var(--muted);font-size:14px;margin-bottom:14px}
.hint{font-size:13px;color:var(--muted);margin-top:6px}
.hint a{font-weight:700}
.req{color:var(--danger)}
.muted-label{font-weight:500;color:var(--muted);font-size:13px}

/* Formlar */
.form-grid{display:grid;grid-template-columns:1fr;gap:0 14px}
@media(min-width:480px){.form-grid{grid-template-columns:1fr 1fr}}
.app-block{border:1px solid var(--border);border-radius:14px;padding:14px 14px 4px;margin-bottom:12px;background:#fbfcfe;position:relative}
.ab-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.ab-title{font-weight:800;font-size:13.5px;color:var(--accent)}
.ab-remove{border:0;background:#fee2e2;color:#b91c1c;width:26px;height:26px;border-radius:8px;font-size:18px;line-height:1;cursor:pointer;font-weight:700}
.ab-remove:hover{background:#fecaca}
.wapp-list{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.wapp{border:1px solid var(--border);border-radius:12px;padding:12px 14px;background:#fff}
.wapp-h{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}
.wapp-type{font-weight:800;font-size:15px;color:var(--text)}
.wapp-brand{font-weight:700;font-size:14px;color:var(--accent)}
.wapp-dur{margin-left:auto;font-size:13px;font-weight:700;color:var(--muted)}
.wapp-sub{font-size:13px;color:#475569;margin-top:5px}
.wapp-terms{font-size:12.5px;color:#475569;line-height:1.5;margin-top:7px;padding-top:7px;border-top:1px dashed var(--border)}
.kunye-card{border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px;background:#fff;box-shadow:0 10px 26px -22px rgba(20,30,60,.4)}
.kunye-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kunye-no{font-weight:800;font-size:15px;color:var(--text)}
.kunye-meta{font-size:13px;color:var(--muted);margin-top:3px}
.wz-bar{display:flex;justify-content:center;gap:8px;margin-bottom:18px}
.wz-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:10px 8px;border-radius:12px;background:#fff;border:1px solid var(--border);font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;white-space:nowrap;overflow:hidden}
.wz-pill b{width:22px;height:22px;border-radius:50%;background:#eef2f7;color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:12px;flex:0 0 auto}
.wz-pill.active{border-color:var(--accent);color:var(--accent)}
.wz-pill.active b{background:var(--accent);color:#fff}
.wz-pill.done b{background:#16a34a;color:#fff}
.wz-nav{display:flex;gap:10px;margin-top:20px}
.wz-nav .btn{flex:1}
@media(max-width:560px){.wz-pill .wz-lbl{display:none}.wz-pill{flex:0 0 auto;width:46px}}
.ai-box{margin:16px 0;padding:14px;border:1px solid var(--border);border-radius:14px;background:#fff}
.ai-head{font-weight:800;font-size:14px;margin-bottom:10px;color:var(--text)}
.ai-img{width:200px;max-width:62%;border-radius:12px;margin-bottom:10px;display:block;cursor:zoom-in;box-shadow:var(--shadow)}
.btn-ai{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff}
.btn-ai:hover{filter:brightness(1.06)}
/* AI üretim tam-ekran yükleme overlay'i */
.ai-overlay{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;background:rgba(8,10,20,.84);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:24px}
.ai-overlay[hidden]{display:none}
.ai-load{max-width:340px;text-align:center;color:#fff}
.ai-spinner{width:64px;height:64px;margin:0 auto 22px;border-radius:50%;border:5px solid rgba(255,255,255,.16);border-top-color:#7c3aed;border-right-color:#e40917;animation:aispin .9s linear infinite}
@keyframes aispin{to{transform:rotate(360deg)}}
.ai-load-title{font-size:20px;font-weight:800;letter-spacing:.3px}
.ai-load-msg{margin-top:8px;font-size:15px;color:#e2e8f0;min-height:21px;transition:opacity .25s}
.ai-load-sub{margin-top:14px;font-size:12.5px;color:#94a3b8;line-height:1.55}
.ai-load-bar{margin:18px auto 0;width:210px;height:5px;border-radius:999px;background:rgba(255,255,255,.14);overflow:hidden}
.ai-load-bar span{display:block;height:100%;width:42%;border-radius:999px;background:linear-gradient(90deg,#7c3aed,#e40917);animation:aibar 1.4s ease-in-out infinite}
@keyframes aibar{0%{transform:translateX(-110%)}100%{transform:translateX(360%)}}
.ai-load-close{margin-top:18px;display:inline-flex;width:auto;padding:11px 26px}
.poster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:6px}
.poster-cell{position:relative;display:block;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#0b0e13;aspect-ratio:4/5}
.poster-cell>a{display:block;width:100%;height:100%}
.poster-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}
.poster-cell:hover img{transform:scale(1.04)}
.poster-del{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:0;background:rgba(15,23,42,.78);color:#fff;font-size:16px;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center}
.poster-del:hover{background:var(--danger,#dc2626)}
.poster-cell .pc-cap{position:absolute;left:0;right:0;bottom:0;padding:6px 8px;font-size:11px;font-weight:700;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.72));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* AI görsel galerisi: bölüm linki, bayi filtresi, sayfalama */
.sec-link{font-size:13px;font-weight:700;color:#e40917;text-decoration:none;white-space:nowrap}
.sec-link:hover{text-decoration:underline}
.filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.filter-bar .field{max-width:280px;flex:1}
.filter-bar .muted-label{font-weight:600}
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px}
.pager-info{font-size:14px;font-weight:700;color:var(--muted)}
.pager-spacer{flex:0 0 92px}
/* Raporlar: grafik kartları */
.chart-card{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:16px;margin-bottom:14px}
.chart-head{font-weight:800;font-size:14px;color:var(--text);margin-bottom:12px}
.chart-wrap{position:relative;height:300px}
.chart-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.chart-2{grid-template-columns:1fr}}
.qr-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(8,12,20,.55);backdrop-filter:blur(11px);-webkit-backdrop-filter:blur(11px)}
.qr-modal[hidden]{display:none}
.qr-card{position:relative;background:#fff;border-radius:20px;padding:28px 24px 22px;box-shadow:0 40px 90px -28px rgba(0,0,0,.6);text-align:center;max-width:340px;width:100%}
.qr-close{position:absolute;top:8px;right:12px;border:0;background:transparent;font-size:28px;line-height:1;color:var(--muted);cursor:pointer}
.qr-close:hover{color:var(--text)}
.qr-title{font-weight:800;font-size:17px;margin-bottom:18px;color:var(--text)}
.qr-box{display:flex;align-items:center;justify-content:center;min-height:240px}
.qr-box canvas,.qr-box img{display:block;margin:0 auto;border-radius:6px}
.qr-hint{margin-top:16px;font-size:13px;color:var(--muted)}
.form-actions{display:flex;flex-direction:column;gap:10px;margin-top:22px}
textarea.field{resize:vertical;min-height:64px;font-family:inherit}
select.field{appearance:none;-webkit-appearance:none;padding-right:36px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8 0 1.4 1.4 0 6 5.2 10.6 0 12 1.4z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center}
.btn-sm{padding:10px 14px;font-size:14px;border-radius:10px}
.btn-ghost-d{background:#fff;color:var(--danger);border:1px solid #fecaca}

/* Foto ızgarası (6 kare) */
.shots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.shot{position:relative;aspect-ratio:1/1;border-radius:14px;border:2px dashed #cbd5e1;background:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}
.shot .shot-plus{display:flex;flex-direction:column;align-items:center;gap:2px;color:#94a3b8}
.shot .shot-plus svg{width:26px;height:26px}
.shot .shot-plus b{font-size:16px;line-height:1;color:#94a3b8}
.shot.active{border-style:solid;border-color:var(--accent);background:#fef2f2;animation:shotpulse 1.6s ease-in-out infinite}
.shot.active .shot-plus,.shot.active .shot-plus b{color:var(--accent)}
.shot.filled{border-style:solid;border-color:var(--border);cursor:default}
.shot.filled img{width:100%;height:100%;object-fit:cover}
.shot-x{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:0;
  background:rgba(15,23,42,.72);color:#fff;font-size:16px;line-height:1;cursor:pointer}
.shot-btn{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,#ff4d4d,var(--accent))}
.shot-btn .i{width:20px;height:20px}
.shot-btn .cnt{font-weight:800;opacity:.9}
.shot-btn:disabled{opacity:.5;cursor:not-allowed}
.shot-actions{display:flex;gap:8px;margin-top:12px}
.shot-actions .shot-btn{margin-top:0;flex:1}
/* Kamera / Galeri seçim sayfası (alt-sheet) */
.pick-sheet{position:fixed;inset:0;z-index:1100;display:flex;align-items:flex-end;justify-content:center;padding:14px;background:rgba(8,12,20,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.pick-sheet[hidden]{display:none}
.pick-card{width:100%;max-width:420px;background:#fff;border-radius:18px;padding:10px;box-shadow:0 -10px 50px rgba(0,0,0,.35);animation:picksheet .2s ease both}
@keyframes picksheet{from{transform:translateY(24px);opacity:.5}to{transform:none;opacity:1}}
.pick-title{font-size:12.5px;font-weight:800;color:var(--muted);text-align:center;padding:8px 0;text-transform:uppercase;letter-spacing:.04em}
.pick-opt{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px;border:0;border-radius:13px;background:#f4f6fa;color:var(--text);font-weight:800;font-size:15.5px;cursor:pointer;margin-bottom:8px}
.pick-opt svg{width:22px;height:22px}
.pick-cam{background:var(--accent);color:#fff}
.pick-cancel{width:100%;padding:13px;border:0;border-radius:13px;background:transparent;color:var(--muted);font-weight:700;font-size:15px;cursor:pointer}
@media(min-width:560px){.pick-sheet{align-items:center}}
/* Tek görsel seçici (logo/imza) */
.img-pick{margin-top:6px}
.img-pick-box{display:block;width:100%;aspect-ratio:5/2;border:2px dashed #cbd5e1;border-radius:14px;background:#fff;cursor:pointer;padding:0;overflow:hidden;position:relative}
.img-pick-box.has{border-style:solid;border-color:var(--border)}
.img-pick-img{width:100%;height:100%;object-fit:contain;background:#f8fafc;display:block}
.img-pick-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#94a3b8;font-weight:700;font-size:13px}
.img-pick-ph svg{width:28px;height:28px}
.img-pick-box.has .img-pick-ph{display:none}
@keyframes shotpulse{0%,100%{box-shadow:0 0 0 4px rgba(228,9,23,.14)}50%{box-shadow:0 0 0 8px rgba(228,9,23,.05)}}

/* Liste araç çubuğu */
.toolbar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap} /* dar ekranda seçiciler alta sarar */
.search{flex:1;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;font-size:16px;background:#fff}
.search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,9,23,.15)}
.filters{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.chip{padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:13px;font-weight:700;color:var(--muted)}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Müşteriler — sıralama çipleri, sayaçlar, onay rozetleri */
.sort-chips{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:-2px 0 14px}
.sort-chips .sort-lbl{font-size:12.5px;font-weight:700;color:var(--muted);margin-right:2px}
.sort-chips .chip{text-decoration:none}
.cust-counts{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end;margin-bottom:4px}
.consent-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:6px 0 2px}
.consent-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:700;border:1.5px solid var(--border);color:var(--muted);background:#fff}
.consent-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.5}
.consent-pill.ok{color:#15803d;border-color:#bbf7d0;background:#f0fdf4}
.consent-pill.ok::before{opacity:1}
.consent-pill.no{color:#b91c1c;border-color:#fecaca;background:#fef2f2}
.consent-at{font-size:12px;color:var(--muted)}

/* Liste satırı küçük resim */
.list-item{color:var(--text)}
.li-thumb{width:54px;height:54px;border-radius:12px;overflow:hidden;background:#eef2f7;flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.li-thumb img{width:100%;height:100%;object-fit:cover}
.li-noimg{font-size:24px;opacity:.45}
.li-main{flex:1;min-width:0}
.li-title,.li-sub{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.li-sub.small{font-size:12px;opacity:.85}

/* Detay */
.detail-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}
.detail-plate{font-size:26px;font-weight:800;letter-spacing:.5px}
.detail-sub{color:var(--muted);font-size:14px;margin-top:2px}
.photos{display:grid;grid-template-columns:repeat(auto-fill,108px);gap:8px;margin-bottom:16px;justify-content:start}
.photo-thumb{position:relative;width:108px;aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:#e2e8f0;box-shadow:var(--shadow)}
.photo-thumb a{display:block;width:100%;height:100%;cursor:zoom-in}
.photo-thumb img{width:100%;height:100%;object-fit:cover}
.photo-del{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:0;background:rgba(15,23,42,.72);color:#fff;font-size:16px;line-height:1;cursor:pointer}
/* Tıkla-büyüt lightbox (foto + AI poster) */
.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,.88);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:20px}
.lightbox[hidden]{display:none}
.lightbox img{max-width:96vw;max-height:92vh;border-radius:12px;box-shadow:0 24px 70px rgba(0,0,0,.55);object-fit:contain}
.lb-close{position:absolute;top:14px;right:18px;width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.18);color:#fff;font-size:26px;line-height:1;cursor:pointer}
.lb-close:hover{background:rgba(255,255,255,.30)}
.photos-empty{color:var(--muted);font-size:14px;padding:16px;background:#fff;border:1px dashed var(--border);border-radius:12px;text-align:center;margin-bottom:16px}
.info-list{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:16px}
.info-line{display:flex;justify-content:space-between;gap:14px;padding:13px 16px;border-bottom:1px solid var(--border);font-size:14px}
.info-line:last-child{border-bottom:0}
.info-line .k{color:var(--muted);font-weight:600;flex:0 0 auto}
.info-line .v{font-weight:700;text-align:right}
.info-line.col{flex-direction:column;gap:4px}
.info-line.col .v{text-align:left;font-weight:500;color:#334155}
.exit-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius);padding:16px;margin-bottom:16px}
.exit-box h3{font-size:15px;margin-bottom:8px;color:#15803d}
.exit-box .info-line{border-bottom-color:#bbf7d0;padding-left:0;padding-right:0}
.exit-box .photos{margin-top:12px;margin-bottom:0}
.detail-meta{font-size:12px;color:var(--muted);text-align:center;margin-bottom:16px}

/* Tanımlar */
.def-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:16px;-webkit-overflow-scrolling:touch}
.def-tab{flex:0 0 auto;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:13px;font-weight:700;color:var(--accent)}
.app-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-bottom:6px}
.app-type-card{display:block;padding:16px;border:1px solid var(--border);border-radius:14px;background:#fff;
  box-shadow:0 10px 26px -20px rgba(20,30,60,.4);transition:transform .15s,box-shadow .15s;border-left:4px solid var(--accent)}
.app-type-card:hover{transform:translateY(-2px);box-shadow:0 16px 34px -22px rgba(20,30,60,.5)}
.app-type-card.passive{opacity:.55;border-left-color:#cbd5e1}
.atc-name{font-weight:800;font-size:16px;color:var(--text);margin-bottom:3px}
.atc-meta{font-size:13px;color:var(--muted);margin-bottom:9px}
.atc-flags{display:flex;flex-wrap:wrap;gap:5px}
.atc-flags span{font-size:11px;font-weight:700;color:#475569;background:#f4f6fa;border:1px solid var(--border);border-radius:6px;padding:2px 7px}
.atc-flags span.off{background:#fee2e2;color:#b91c1c;border-color:#fecaca}
.chk-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.def-cat{margin-bottom:28px;scroll-margin-top:72px}
.def-cat-head h2{font-size:18px}
.def-cat-head .hint{margin:4px 0 12px}
.def-add{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.def-add .field{flex:1;min-width:150px}
.def-list{display:flex;flex-direction:column;gap:8px}
.def-item{display:flex;gap:8px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px;flex-wrap:wrap}
.def-item.passive{opacity:.55}
.def-row{display:flex;gap:8px;align-items:center;flex:1;flex-wrap:wrap}
.def-row .field{flex:1;min-width:120px;padding:9px 12px}
.chk{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap}
.def-empty{color:var(--muted);font-size:14px;padding:10px}

/* ====================== Web / masaüstü: sol sidebar ====================== */
/* Mobil: off-canvas çekmece (drawer); masaüstünde sabit sidebar (aşağıdaki @media). */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:84%;max-width:300px;z-index:200;
  display:flex;flex-direction:column;color:#fff;overflow-y:auto;
  background:linear-gradient(180deg,var(--accent),var(--accent-d));
  transform:translateX(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);
  box-shadow:0 18px 60px rgba(0,0,0,.55)}
body.drawer-open .sidebar{transform:none}
body.drawer-open{overflow:hidden}
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:190;opacity:0;visibility:hidden;transition:opacity .26s,visibility .26s}
body.drawer-open .drawer-backdrop{opacity:1;visibility:visible}
.ab-burger{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.14);border:0;border-radius:50%;cursor:pointer}
.ab-burger svg{width:22px;height:22px}
.sb-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border:0;background:rgba(255,255,255,.16);color:#fff;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}
/* Sidebar/drawer içerik stilleri — hem mobil çekmece hem masaüstü sidebar için */
.sb-brand{display:flex;align-items:center;justify-content:center;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.2)}
.sb-logo-w{display:block;width:100%;height:auto;max-height:42px;object-fit:contain}
.sb-logo{display:block;width:100%;height:auto;max-height:54px;object-fit:contain;background:#fff;border-radius:10px;padding:8px 12px}
.sb-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#ff4d4d,var(--accent));display:flex;align-items:center;justify-content:center;color:#fff}
.sb-mark svg{width:20px;height:20px}
.sb-brand-txt{font-size:19px;font-weight:800;color:#fff;margin-left:10px}
.sb-cta{display:flex;align-items:center;justify-content:center;gap:9px;margin:14px 12px 8px;padding:12px;
  background:#fff;color:var(--accent);border-radius:11px;font-weight:800;font-size:14.5px;box-shadow:0 8px 18px -8px rgba(0,0,0,.5)}
.sb-cta:hover{background:#ffe9eb}
.sb-cta svg{width:19px;height:19px;flex:0 0 auto}
.sb-nav{display:flex;flex-direction:column;gap:2px;padding:4px 10px 12px;flex:1;overflow-y:auto}
.sb-link{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:10px;color:rgba(255,255,255,.85);font-weight:600;font-size:14.5px}
.sb-link svg{width:20px;height:20px;flex:0 0 auto;opacity:.95}
.sb-link:hover{background:rgba(255,255,255,.16);color:#fff}
.sb-link.active{background:#fff;color:var(--accent);font-weight:700;box-shadow:0 4px 12px -4px rgba(0,0,0,.45)}
.sb-link.active svg{opacity:1}
.sb-group-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);padding:14px 13px 5px;margin-top:6px;border-top:1px solid rgba(255,255,255,.16)}
.sb-link-acc{margin-top:auto}
.sb-foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.2)}
.sb-user{font-size:13px;font-weight:700;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-logout{font-size:13px;color:rgba(255,255,255,.85);font-weight:600}
.sb-logout:hover{color:#fff}

@media (min-width:960px){
  .sidebar{display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:240px;
    background:linear-gradient(180deg,var(--accent),var(--accent-d));color:#fff;z-index:60;transform:none;box-shadow:none}
  .drawer-backdrop,.sb-close,.ab-burger{display:none}

  .app{max-width:none;margin-left:240px;margin-right:0;box-shadow:none;padding-bottom:28px}
  .appbar{display:none}
  .content{padding:24px 30px;max-width:none;margin:0}
  .form{max-width:820px}
  .form.wform{max-width:none}
  .wform-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 40px;align-items:start}
  .form.wizard{max-width:920px;margin:0 auto}
  .tabbar{display:none}
  .stats{grid-template-columns:repeat(4,1fr)}
  .btn-block.btn-new{display:inline-flex;width:auto;padding:11px 22px;font-size:14.5px}
}

/* ====================== Garanti / bayi form bileşenleri ====================== */
.form-sec{font-size:14px;font-weight:800;color:var(--text);margin:22px 0 8px;padding-top:14px;border-top:1px solid var(--border);text-transform:uppercase;letter-spacing:.4px}
/* Toplu içe aktarma: eşleştirme + önizleme */
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;margin-bottom:8px}
@media(max-width:560px){.map-grid{grid-template-columns:1fr}}
.map-row{display:flex;flex-direction:column;gap:4px}
.map-label{font-size:13px;font-weight:700;color:var(--text)}
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px;margin-bottom:6px}
.prev-table{border-collapse:collapse;font-size:12.5px;white-space:nowrap;min-width:100%}
.prev-table th,.prev-table td{padding:6px 10px;border-bottom:1px solid var(--border);text-align:left}
.prev-table th{background:#f8fafc;font-weight:700;color:var(--muted)}
.prev-table tr:last-child td{border-bottom:0}
/* Müşteriler/Garantiler — geniş ekran tablo, mobil kart (960px sidebar kırılımı) */
.awx-table-view{display:none}
@media(min-width:960px){
  .awx-table-view{display:block}
  .awx-cards-view{display:none}
  .awx-mobile-only{display:none}
}
/* Müşteriler — Excel/tablo görünümü (kolon-bazlı sortable) */
.data-table{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap;background:var(--card)}
.data-table thead th{background:#f8fafc;border-bottom:1px solid var(--border);padding:0;text-align:left}
.data-table thead th a{display:flex;align-items:center;gap:5px;padding:10px 12px;color:var(--muted);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.4px;text-decoration:none;user-select:none}
.data-table thead th a:hover{color:var(--text);background:#eef2f7}
.data-table thead th.sorted a{color:var(--accent)}
.data-table thead th.r a{justify-content:flex-end}
.data-table th .arr{font-size:9px}
.data-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.data-table tbody td.r{text-align:right;font-variant-numeric:tabular-nums}
.data-table tbody td.muted,.data-table tbody td .muted{color:var(--muted)}
.data-table tbody tr{cursor:pointer}
.data-table tbody tr:hover{background:#f8fafc}
.data-table tbody tr:last-child td{border-bottom:0}
.data-table .c-name{font-weight:700}
.data-table .c-name a{color:var(--text);text-decoration:none}
.data-table .c-name a:hover{color:var(--accent)}
.data-table tbody tr.neg td{background:#fff5f5}
.data-table tbody tr.neg:hover td{background:#ffecec}
.form-sec:first-of-type{border-top:0;padding-top:0;margin-top:6px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip-check{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;border:1.5px solid var(--border);background:#fff;font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;user-select:none}
.chip-check input{position:absolute;opacity:0;width:0;height:0}
.chip-check.on,.chip-check:has(input:checked){background:var(--accent);border-color:var(--accent);color:#fff}
.img-prev{margin:0 0 8px;width:110px;height:66px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#f1f5f9}
.img-prev img{width:100%;height:100%;object-fit:contain}
.tag-ro{display:inline-block;font-size:10px;font-weight:700;background:#e2e8f0;color:#475569;padding:2px 7px;border-radius:999px;vertical-align:middle;margin-left:4px}
.cert-actions{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 16px}
.cert-actions form{display:contents}
.cert-actions .btn{flex:1 1 140px;margin:0;padding:10px 15px;font-size:13.5px;font-weight:600;border-radius:10px}
.cert-actions .btn-block{display:inline-block;width:auto}
@media (min-width:760px){.cert-actions .btn{flex:0 1 auto}}
.kvkk-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:11px 14px;margin:4px 0 16px}
.kvkk-row .kvkk-k{font-weight:700;font-size:13px;color:var(--muted)}
.kvkk-row .kvkk-sub{font-size:12.5px;color:var(--muted)}
.btn-wa2{background:linear-gradient(135deg,#34d399,#22c55e);color:#04210f}

[hidden]{display:none !important}

/* ====================== Autowax Garage ====================== */
.gx-stage{position:relative;background:#0b1220;border-radius:16px;min-height:46vh;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:14px}
.gx-img{width:100%;height:100%;max-height:64vh;object-fit:contain;display:block}
.gx-empty{text-align:center;padding:26px 22px;display:flex;flex-direction:column;align-items:center;gap:8px}
.gx-empty-ic{width:60px;height:60px;border-radius:16px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#cbd5e1}
.gx-empty-ic svg{width:32px;height:32px}
.gx-empty-t{font-weight:800;font-size:16px;color:#e8edf4}
.gx-empty-s{font-size:13px;color:#9fb0c6;max-width:280px;line-height:1.45}
.gx-empty .btn{margin-top:6px}
.gx-change{position:absolute;top:10px;right:10px;width:38px;height:38px;border:0;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}
.gx-change svg{width:20px;height:20px}
.gx-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;padding:5px 11px;border-radius:999px;z-index:2}
.gx-actions{position:absolute;left:0;right:0;bottom:0;display:flex;gap:8px;padding:10px;background:linear-gradient(transparent,rgba(0,0,0,.6));z-index:2}
.gx-act{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 6px;border-radius:11px;border:0;background:rgba(255,255,255,.95);color:#0f172a;font-weight:700;font-size:12.5px;cursor:pointer;text-decoration:none}
.gx-act svg{width:17px;height:17px;flex:0 0 auto}
.gx-act.gx-wa{background:linear-gradient(135deg,#34d399,#22c55e);color:#04210f}
.gx-act.done{background:#dcfce7;color:#15803d}
.gx-pills{display:flex;gap:8px;margin-bottom:12px}
.gx-pill{flex:1;padding:11px;border-radius:12px;border:1.5px solid var(--border);background:#fff;color:var(--muted);font-weight:700;font-size:14px;cursor:pointer}
.gx-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
.gx-grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,auto);gap:12px 10px;overflow-x:auto;padding:4px 2px 12px;scroll-snap-type:x proximity}
.gx-grid::-webkit-scrollbar{height:6px}.gx-grid::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:6px}
.gx-swatch{scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:5px;width:80px;border:0;background:none;cursor:pointer;padding:2px}
.gx-sw-col,.gx-sw-img{width:74px;height:74px;border-radius:13px;border:2px solid transparent;box-shadow:0 4px 12px -5px rgba(20,30,60,.35);background-size:cover;background-position:center}
.gx-swatch.selected .gx-sw-col,.gx-swatch.selected .gx-sw-img{border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,9,23,.18)}
.gx-sw-name{font-size:11px;font-weight:600;color:var(--muted);text-align:center;line-height:1.15;max-width:80px}
.gx-swatch.selected .gx-sw-name{color:var(--ink)}
.gx-controls .hint{margin-top:10px}

/* Garage — müşteri kartı + seçim modalı */
.gx-cust{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:11px 13px;margin-bottom:12px;border:1.5px solid var(--border);border-radius:14px;background:#fff;cursor:pointer}
.gx-cust.on{border-color:var(--accent);box-shadow:0 0 0 3px rgba(228,9,23,.12)}
.gx-cust-ic{flex:none;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;color:var(--accent)}
.gx-cust-ic svg{width:22px;height:22px}
.gx-cust-body{flex:1;min-width:0}
.gx-cust-title{display:block;font-weight:800;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gx-cust-sub{display:block;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gx-cust-act{flex:none;font-size:12.5px;font-weight:800;color:var(--accent);background:#fff;border:1.5px solid var(--accent);border-radius:999px;padding:5px 12px}
.gx-veh{margin-bottom:12px}
.gx-veh-toggle{background:none;border:0;color:var(--accent);font-weight:700;font-size:13px;cursor:pointer;padding:2px 0}
.gx-veh-fields{display:flex;flex-direction:column;gap:8px;margin-top:8px}
@media(min-width:560px){.gx-veh-fields{flex-direction:row}.gx-veh-fields .field{flex:1}}
.gx-cust-modal{position:fixed;inset:0;z-index:210;display:flex;align-items:flex-end;justify-content:center;background:rgba(8,12,20,.55);backdrop-filter:blur(11px);-webkit-backdrop-filter:blur(11px)}
.gx-cust-modal[hidden]{display:none}
.gx-cust-card{position:relative;background:#fff;border-radius:20px 20px 0 0;padding:22px 18px calc(18px + env(safe-area-inset-bottom));width:100%;max-width:520px;max-height:88vh;overflow:auto;box-shadow:0 -20px 60px -20px rgba(0,0,0,.5)}
.gx-cust-card .qr-title{text-align:left;margin-bottom:12px}
.gx-cust-card .field{margin-bottom:10px}
.gx-cust-results{display:flex;flex-direction:column;gap:6px;margin:2px 0 4px}
.gx-cust-row{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:11px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;cursor:pointer}
.gx-cust-row:hover{border-color:var(--accent);background:#fff6f6}
.gx-cr-name{font-weight:700;color:var(--ink)}
.gx-cr-phone{flex:1;font-size:12.5px;color:var(--muted)}
.gx-cr-ok{font-size:11px;font-weight:800;color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:999px;padding:2px 8px}
.gx-cust-empty{font-size:13px;color:var(--muted);padding:8px 2px}
.gx-cust-or{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--muted);font-size:12px;font-weight:700}
.gx-cust-or::before,.gx-cust-or::after{content:"";flex:1;height:1px;background:var(--border)}
.gx-cust-new{margin-top:12px}
.gx-consent-note{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;line-height:1.45;color:#0b3b22;background:#ecfdf3;border:1px solid #bbf7d0;border-radius:11px;padding:11px 12px;margin:10px 0 2px}
.gx-consent-note svg{flex:none;color:#16a34a;margin-top:1px}
.gx-deliver-note{flex-basis:100%;font-size:12px;font-weight:600;color:#fff;background:rgba(0,0,0,.45);border-radius:8px;padding:6px 8px;margin-top:2px}
.gx-act.gx-onay{background:linear-gradient(135deg,#34d399,#22c55e);color:#04210f}
@media (min-width:560px){ .gx-cust-modal{align-items:center} .gx-cust-card{border-radius:20px} }

@media (min-width:760px){ .gx-stage{min-height:420px} }

/* ---- Placeholder taşması: kesilen metin … ile biter (özellikle mobil) ---- */
input::placeholder, textarea::placeholder { text-overflow: ellipsis; }

/* ---- Müşteriler filtresi: mobilde bayi seçimi ÜSTTE, altında arama + Ara ---- */
.cust-filter { flex-wrap: wrap; }
.cust-filter .cf-search { display: flex; gap: 8px; flex: 1; min-width: 220px; }
.cust-filter .cf-search .field { flex: 1; }
@media (max-width: 640px) {
  .cust-filter { flex-direction: column; align-items: stretch; }
  .cust-filter .cf-dealer { width: 100%; max-width: none; }
  .cust-filter .cf-search { width: 100%; }
}

/* ---- Tarih inputu (iOS/Safari): diğer .field'larla eş boyut, sağa taşma yok ---- */
input.field[type="date"] {
  -webkit-appearance: none;
  appearance: none;
  min-width: 0;
  max-width: 100%;
  min-height: 48px;          /* iOS date input içeriğe göre küçülür — diğer inputlarla hizala */
  display: block;
  background: #fff;
  box-sizing: border-box;
}
input.field[type="date"]::-webkit-date-and-time-value { text-align: left; }

/* ---- PPF uygulama bloğu: okutmadan otomatik dolan KİLİTLİ alanlar ---- */
.field[readonly] { background: #f8fafc; color: #475569; }
select.field.lk  { pointer-events: none; background: #f8fafc; color: #475569; }
.app-block.ab-ppf { border-left: 3px solid var(--accent, #E40917); }

/* ---- Klasik checkbox listesi (bayi formu: uygulamalar / modüller / durum) ---- */
.check-list { display: flex; flex-direction: column; gap: 8px; margin-top: 6px; }
.check-list label { display: flex; align-items: flex-start; gap: 12px; padding: 12px 14px; border: 1px solid #e2e8f0; border-radius: 12px; background: #fff; font-weight: 700; font-size: 14.5px; color: var(--text); cursor: pointer; transition: border-color .15s, background .15s; }
.check-list label.on { border-color: var(--accent); background: #fff7f7; }
.check-list input[type="checkbox"] { width: 19px; height: 19px; margin-top: 1px; flex: 0 0 auto; accent-color: var(--accent); }
.check-list span { flex: 1; min-width: 0; }
.check-list small { display: block; font-weight: 500; font-size: 12.5px; color: #64748b; margin-top: 2px; line-height: 1.4; }

/* ---- PPF Stok aksiyonları: mobilde düzenli 2 sütunlu ızgara ---- */
@media (max-width: 640px) {
  .ppf-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .ppf-actions .btn { width: 100%; text-align: center; }
  .ppf-actions .ppf-add { grid-column: 1 / -1; margin-left: 0; }
}

/* ---- Dashboard kartları tıklanabilir ---- */
a.stat { text-decoration: none; color: inherit; display: block; }
a.stat:active { transform: scale(.98); }

/* ---- Hızlı işlem paneli (+ butonu): blurlu arka plan + alt sayfa ---- */
.qa-overlay { position: fixed; inset: 0; z-index: 120; display: flex; align-items: flex-end; justify-content: center; }
.qa-overlay[hidden] { display: none; }
.qa-backdrop { position: absolute; inset: 0; background: rgba(10, 14, 20, .45); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.qa-sheet { position: relative; width: 100%; max-width: 640px; background: #fff; border-radius: 22px 22px 0 0; padding: 18px 16px calc(18px + env(safe-area-inset-bottom)); box-shadow: 0 -18px 60px rgba(0, 0, 0, .25); animation: qaUp .22s ease; }
@keyframes qaUp { from { transform: translateY(26px); opacity: .5; } to { transform: none; opacity: 1; } }
.qa-title { font-weight: 800; font-size: 15px; margin: 0 4px 12px; color: var(--text); }
.qa-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.qa-item { display: flex; align-items: center; gap: 10px; padding: 13px 12px; border: 1px solid #e2e8f0; border-radius: 14px; background: #fff; font-weight: 700; font-size: 13.5px; color: var(--text); text-decoration: none; }
.qa-item:active { background: #fff5f5; border-color: var(--accent); }
.qa-item .ic { width: 34px; height: 34px; border-radius: 10px; background: #fdeaea; color: var(--accent); display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.qa-item .ic svg { width: 18px; height: 18px; }
.qa-close { margin-top: 12px; width: 100%; padding: 12px; border: 0; border-radius: 12px; background: #f1f5f9; font-weight: 700; font-size: 14px; color: #334155; cursor: pointer; }
@media (min-width: 960px) { .qa-overlay { align-items: center; padding: 20px; } .qa-sheet { border-radius: 22px; } }
@media (prefers-reduced-motion: reduce) { .qa-sheet { animation: none; } }

/* ---- Hızlı işlem: bottom-sheet sürükleme çizgisi + geçiş ---- */
.qa-handle { width: 44px; height: 5px; border-radius: 99px; background: #d7dde3; margin: -4px auto 12px; cursor: grab; }
.qa-sheet { transition: transform .22s ease; touch-action: pan-y; }

/* ---- Autowax Garage: AI işi farklı dursun — tam genişlik, yanar döner gradient ---- */
.qa-item small { display: block; font-weight: 600; font-size: 11px; opacity: .85; margin-top: 1px; }
.qa-garage {
  grid-column: 1 / -1;
  position: relative; overflow: hidden;
  border: 0; color: #fff;
  background: linear-gradient(115deg, #E40917, #7a0510, #FF5A64, #C00714);
  background-size: 300% 300%;
  animation: qaGlow 4s ease infinite;
  box-shadow: 0 10px 26px rgba(228, 9, 23, .35);
}
.qa-garage .ic { background: rgba(255, 255, 255, .18); color: #fff; }
.qa-garage:active { transform: scale(.985); }
.qa-garage::after { /* parlama süpürmesi */
  content: ""; position: absolute; top: 0; left: -60%; width: 40%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255, 255, 255, .35), transparent);
  animation: qaShine 2.8s ease infinite;
}
@keyframes qaGlow  { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
@keyframes qaShine { to { left: 130%; } }
@media (prefers-reduced-motion: reduce) { .qa-garage, .qa-garage::after { animation: none; } }
