/* Envanter — B-tipi (Claude Design birebir uyumlu)
   Source-of-truth: code_dizayn/B tipi/b-app.css + B TİPİ TASARIM EKRAN GÖRÜNTÜLERİ
   Identity: navy #1c3464 + gold accent + Kırmızı K-logo (kurumsal kimlik) */
:root{
  --b-ink-900:#1a2332;
  --b-ink-800:#2a3a52;
  --b-ink-700:#3d4a63;
  --b-ink-600:#5a6577;
  --b-ink-500:#7a8499;
  --b-ink-400:#a3acbf;
  --b-ink-300:#c8cdd9;
  --b-ink-200:#dde1ea;
  --b-ink-100:#eef0f5;
  --b-ink-50:#f6f7fa;
  --b-navy:#1c3464;
  --b-navy-800:#1c3464;
  --b-navy-700:#26467f;
  --b-navy-600:#2f5594;
  --b-navy-100:#e3e9f3;
  --b-navy-50:#f0f4fa;
  --b-gold:#b08a3a;
  --b-gold-50:#fbf6e7;
  --b-green:#1f7a4a;
  --b-green-50:#e6f3ec;
  --b-amber:#9a6300;
  --b-amber-50:#fcf3df;
  --b-red:#a8201a;
  --b-red-50:#fbe9e8;
  /* Envanter corporate red — yalnız K-logo için */
  --k-red:#b20000;
  --b-mono:'JetBrains Mono','Consolas',monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;font-size:13.5px;color:var(--b-ink-900);background:var(--b-ink-50);line-height:1.45}
a{color:var(--b-navy-700);text-decoration:none}
button{font-family:inherit;font-size:inherit;cursor:pointer}

/* === Üst kurumsal banner (Claude Design B-tipi birebir): navy + gold accent === */
.b-banner{background:var(--b-navy-800);color:#fff;height:54px;display:flex;align-items:center;padding:0 22px;gap:18px;border-bottom:3px solid var(--b-gold)}
/* K-logo: Envanter kurumsal kırmızı (screenshot kanıtlı) + beyaz K */
.b-logo{width:36px;height:36px;background:var(--k-red);color:#fff;font-weight:800;font-size:20px;display:grid;place-items:center;border-radius:3px;letter-spacing:-1px;font-family:'Inter',sans-serif;box-shadow:inset 0 -2px 0 rgba(0,0,0,.18)}
.b-brand{font-size:16px;font-weight:600;letter-spacing:.2px}
.b-brand .sub{font-size:11px;color:#aebcd5;font-weight:400;display:block;margin-top:-2px}
.b-banner-spacer{flex:1}
.b-user{display:flex;align-items:center;gap:10px;font-size:12.5px}
.b-user .nm{font-weight:600}
.b-user .rl{color:#aebcd5;font-size:11px;display:block;margin-top:-2px}
.b-avatar{width:32px;height:32px;border-radius:50%;background:#fff;color:var(--b-navy-800);display:grid;place-items:center;font-weight:700;font-size:12px}
.b-banner a.exit{color:#fff;font-size:12px;opacity:.85;border-left:1px solid rgba(255,255,255,.2);padding-left:14px;margin-left:6px}
.b-banner a.exit:hover{opacity:1}
.b-banner form.exit-form{margin:0;padding:0}
.b-banner form.exit-form button{background:transparent;border:0;color:#fff;font-size:12px;opacity:.85;border-left:1px solid rgba(255,255,255,.2);padding:0 0 0 14px;margin-left:6px;cursor:pointer;font-family:inherit}
.b-banner form.exit-form button:hover{opacity:1}

/* === Yatay menü === */
.b-nav{background:#fff;border-bottom:1px solid var(--b-ink-200);height:42px;display:flex;align-items:center;padding:0 22px;gap:0;position:sticky;top:0;z-index:10}
.b-nav a{display:flex;align-items:center;gap:6px;height:42px;padding:0 16px;font-size:13.5px;font-weight:500;color:var(--b-ink-700);border-bottom:2px solid transparent;margin-bottom:-1px;text-decoration:none}
.b-nav a:hover{color:var(--b-navy-700);background:var(--b-ink-50)}
.b-nav a.act{color:var(--b-navy-800);border-bottom-color:var(--b-gold);font-weight:600}
.b-nav .sep{flex:1}
.b-nav .ctx{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--b-ink-500)}
.b-nav .ctx select{height:28px;border:1px solid var(--b-ink-300);background:#fff;border-radius:3px;padding:0 8px;font-size:12.5px;color:var(--b-ink-800)}

/* === Yatay menü dropdown === */
.b-nav-grp{position:relative;display:flex;align-items:stretch}
.b-nav-grp > a{cursor:pointer}
.b-nav-dd{position:absolute;top:42px;left:0;background:#fff;border:1px solid var(--b-ink-200);border-top:2px solid var(--b-navy-700);box-shadow:0 8px 24px rgba(20,30,55,.12);min-width:220px;z-index:20;display:none;flex-direction:column;padding:4px 0}
.b-nav-grp.open .b-nav-dd{display:flex}
.b-nav-grp:hover .b-nav-dd{display:flex}
.b-nav-dd a{height:32px;display:flex;align-items:center;padding:0 14px;font-size:12.5px;color:var(--b-ink-800);border:0;margin:0}
.b-nav-dd a:hover{background:var(--b-navy-50);color:var(--b-navy-800)}
.b-nav-dd a.act{background:var(--b-navy-50);color:var(--b-navy-800);font-weight:600}
.b-nav-grp .chev{display:inline-flex;align-items:center;margin-left:2px}

/* === Standart detay sayfası kalıbı === */
.b-detail-h{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--b-ink-200)}
.b-detail-h-l{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.b-detail-h-l h1{margin:0;font-size:21px;font-weight:600;color:var(--b-ink-900);letter-spacing:-.2px}
.b-detail-code{font-family:var(--b-mono);font-size:13px;color:var(--b-navy-700);background:var(--b-navy-50);padding:4px 8px;border-radius:3px;font-weight:600;border:1px solid #d1ddee}
.b-detail-grid{display:grid;grid-template-columns:1fr 280px;gap:14px;align-items:start}
.b-detail-main{min-width:0}
.b-detail-aside{display:flex;flex-direction:column;gap:10px;position:sticky;top:56px}
.b-aside-blk{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;overflow:hidden}
.b-aside-blk-h{background:var(--b-ink-50);padding:8px 12px;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--b-ink-700);border-bottom:1px solid var(--b-ink-200)}
.b-aside-blk-b{padding:10px 12px;font-size:12.5px;color:var(--b-ink-800)}
.b-aside-blk-b .row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px dashed var(--b-ink-100);font-size:12px}
.b-aside-blk-b .row:last-child{border-bottom:0}
.b-aside-blk-b .row .lb{color:var(--b-ink-500)}
.b-aside-blk-b .row .vl{font-weight:500;color:var(--b-ink-900)}
.b-aside-blk-b .acts{display:flex;flex-direction:column;gap:6px}
.b-aside-blk-b .acts .b-btn{justify-content:flex-start;width:100%}

/* === Tab content panel === */
.b-tab-body{background:#fff;border:1px solid var(--b-ink-200);border-top:0;border-radius:0 0 4px 4px;padding:14px}
.b-tabs.attached{border-radius:4px 4px 0 0;border:1px solid var(--b-ink-200);border-bottom:1px solid var(--b-ink-200)}

/* === Onay timeline === */
.b-tl{position:relative;padding-left:18px}
.b-tl::before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:1px;background:var(--b-ink-200)}
.b-tl-it{position:relative;padding:6px 0 10px}
.b-tl-it::before{content:"";position:absolute;left:-16px;top:9px;width:9px;height:9px;border-radius:50%;background:#fff;border:2px solid var(--b-ink-300)}
.b-tl-it.ok::before{border-color:var(--b-green);background:var(--b-green)}
.b-tl-it.warn::before{border-color:var(--b-amber);background:var(--b-amber)}
.b-tl-it.danger::before{border-color:var(--b-red);background:var(--b-red)}
.b-tl-it .who{font-size:12.5px;font-weight:600;color:var(--b-ink-900)}
.b-tl-it .when{font-size:11.5px;color:var(--b-ink-500);font-family:var(--b-mono)}
.b-tl-it .nt{font-size:12px;color:var(--b-ink-700);margin-top:2px}

/* === Compare grid (teklif karşılaştırma) === */
.b-cmp{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;overflow:auto}
.b-cmp table{width:100%;border-collapse:collapse;font-size:12.5px}
.b-cmp th{background:var(--b-ink-50);padding:8px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--b-ink-700);border-bottom:1px solid var(--b-ink-200);position:sticky;top:0;text-align:left;font-weight:600}
.b-cmp th.vendor{background:var(--b-navy-50);color:var(--b-navy-800);text-align:right;border-left:1px solid var(--b-ink-200)}
.b-cmp th.vendor.win{background:var(--b-green-50);color:var(--b-green)}
.b-cmp td{padding:7px 10px;border-bottom:1px solid var(--b-ink-100);vertical-align:middle}
.b-cmp td.num{text-align:right;font-family:var(--b-mono);font-variant-numeric:tabular-nums;border-left:1px solid var(--b-ink-100)}
.b-cmp td.num.best{background:var(--b-green-50);color:var(--b-green);font-weight:600}
.b-cmp td.num.worst{color:var(--b-red)}
.b-cmp tfoot td{background:var(--b-ink-50);font-weight:600;border-top:2px solid var(--b-ink-300)}

@media (max-width:1100px){
  .b-detail-grid{grid-template-columns:1fr}
  .b-detail-aside{position:static}
}

/* === Page wrap === */
.b-page{padding:18px 24px 60px;max-width:100%}
.b-bread{font-size:11.5px;color:var(--b-ink-500);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px;font-weight:500}
.b-bread .cur{color:var(--b-navy-800)}
.b-page-h{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px;gap:14px;flex-wrap:wrap}
.b-page-h h1{font-size:22px;margin:0;font-weight:600;color:var(--b-ink-900);letter-spacing:-.2px}
.b-page-h .sub{font-size:12.5px;color:var(--b-ink-500);margin-top:2px}
.b-page-actions{display:flex;gap:6px}

/* === Butonlar === */
.b-btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border:1px solid var(--b-ink-300);background:#fff;color:var(--b-ink-800);border-radius:3px;font-size:12.5px;font-weight:500;line-height:1;white-space:nowrap;text-decoration:none}
.b-btn:hover{background:var(--b-ink-50);border-color:var(--b-ink-400)}
.b-btn.primary{background:var(--b-navy-700);border-color:var(--b-navy-800);color:#fff;font-weight:600}
.b-btn.primary:hover{background:var(--b-navy-800)}
.b-btn.success{background:var(--b-green);border-color:#155835;color:#fff}
.b-btn.danger{background:#fff;border-color:var(--b-red);color:var(--b-red)}
.b-btn.danger:hover{background:var(--b-red-50)}
.b-btn.gold{background:var(--b-gold-50);border-color:var(--b-gold);color:#7a5f1e;font-weight:600}
.b-btn.xs{height:24px;padding:0 8px;font-size:11.5px;border-radius:2px}
.b-btn.lg{height:36px;padding:0 16px;font-size:13.5px}
.b-btn:disabled{opacity:.5;cursor:not-allowed}

/* === Filtre paneli === */
.b-filter{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;padding:10px 12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.b-filter label{font-size:11.5px;color:var(--b-ink-600);font-weight:500;display:flex;align-items:center;gap:5px}
.b-filter .grp{display:flex;align-items:center;gap:5px}
.b-filter input[type="text"],.b-filter input[type="date"],.b-filter input[type="number"],.b-filter select,.b-filter textarea{height:28px;border:1px solid var(--b-ink-300);background:#fff;border-radius:3px;padding:0 8px;font-size:12.5px;color:var(--b-ink-900);font-family:inherit}
.b-filter input[type="text"]:focus,.b-filter input[type="date"]:focus,.b-filter select:focus{outline:0;border-color:var(--b-navy-600);box-shadow:0 0 0 2px var(--b-navy-100)}
.b-filter .search{position:relative}
.b-filter .search input{padding-left:28px;width:240px}
.b-filter .search svg{position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--b-ink-400)}
.b-filter .spacer{flex:1}

/* === Form === */
.b-form input[type="text"],.b-form input[type="email"],.b-form input[type="password"],.b-form input[type="number"],.b-form input[type="date"],.b-form select,.b-form textarea{width:100%;height:32px;border:1px solid var(--b-ink-300);background:#fff;border-radius:3px;padding:0 10px;font-size:13px;color:var(--b-ink-900);font-family:inherit}
.b-form textarea{height:auto;min-height:64px;padding:8px 10px;line-height:1.45}
.b-form input:focus,.b-form select:focus,.b-form textarea:focus{outline:0;border-color:var(--b-navy-600);box-shadow:0 0 0 2px var(--b-navy-100)}
.b-form .field{margin-bottom:10px}
.b-form .field label{display:block;font-size:11.5px;color:var(--b-ink-700);margin-bottom:3px;font-weight:500}
.b-form .field label .req{color:var(--b-red);margin-left:2px}
.b-form .row{display:grid;gap:10px}
.b-form .row.c2{grid-template-columns:1fr 1fr}
.b-form .row.c3{grid-template-columns:1fr 1fr 1fr}
.b-form .row.c4{grid-template-columns:1fr 1fr 1fr 1fr}
.b-form .help{font-size:11px;color:var(--b-ink-500);margin-top:2px}
.b-form .err{font-size:11px;color:var(--b-red);margin-top:2px}

/* === Section panel === */
.b-panel{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;margin-bottom:14px}
.b-panel-h{padding:10px 14px;border-bottom:1px solid var(--b-ink-200);background:var(--b-ink-50);display:flex;align-items:center;justify-content:space-between;border-radius:4px 4px 0 0}
.b-panel-h h3{margin:0;font-size:13.5px;font-weight:600;color:var(--b-ink-800);display:flex;align-items:center;gap:8px}
.b-panel-h .meta{font-size:11.5px;color:var(--b-ink-500)}
.b-panel-b{padding:14px}
.b-panel-b.flush{padding:0}

/* === Tablo === */
.b-tbl-wrap{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;overflow:hidden}
.b-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.b-tbl thead th{background:var(--b-ink-50);text-align:left;font-size:11px;font-weight:600;color:var(--b-ink-700);text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:1px solid var(--b-ink-200);white-space:nowrap;position:sticky;top:0}
.b-tbl tbody td{padding:7px 10px;border-bottom:1px solid var(--b-ink-100);vertical-align:middle}
.b-tbl tbody tr:hover{background:var(--b-navy-50)}
.b-tbl tbody tr:last-child td{border-bottom:0}
.b-tbl .num{text-align:right;font-family:var(--b-mono);font-variant-numeric:tabular-nums;white-space:nowrap}
.b-tbl .code{font-family:var(--b-mono);font-size:11.5px;color:var(--b-navy-700);font-weight:500}
.b-tbl .muted{color:var(--b-ink-500)}
.b-tbl .row-act{display:flex;gap:4px;justify-content:flex-end}
.b-tbl tr.crit td{background:#fff7f0}
.b-tbl tr.crit:hover td{background:#ffeed8}
.b-tbl-foot{padding:7px 12px;border-top:1px solid var(--b-ink-200);background:var(--b-ink-50);display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--b-ink-600)}
.b-tbl-foot .pages{display:flex;gap:2px}
.b-tbl-foot .pg{min-width:24px;height:24px;border:1px solid var(--b-ink-300);background:#fff;display:grid;place-items:center;font-size:11.5px;border-radius:2px;color:var(--b-ink-700);padding:0 6px;cursor:pointer}
.b-tbl-foot .pg.act{background:var(--b-navy-700);color:#fff;border-color:var(--b-navy-800)}

/* === Badge === */
.b-bdg{display:inline-flex;align-items:center;gap:4px;padding:1px 7px;border-radius:2px;font-size:11px;font-weight:600;letter-spacing:.2px;line-height:1.4;border:1px solid transparent;font-family:var(--b-mono)}
.b-bdg .d{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}
.b-bdg.ok{background:var(--b-green-50);color:var(--b-green);border-color:#bfdfcd}
.b-bdg.warn{background:var(--b-amber-50);color:var(--b-amber);border-color:#e8d29e}
.b-bdg.danger{background:var(--b-red-50);color:var(--b-red);border-color:#e8b8b6}
.b-bdg.info{background:var(--b-navy-50);color:var(--b-navy-700);border-color:#bfd0e8}
.b-bdg.neutral{background:var(--b-ink-100);color:var(--b-ink-700);border-color:var(--b-ink-200)}
.b-bdg.gold{background:var(--b-gold-50);color:#7a5f1e;border-color:#d8c177}

/* === KPI tile === */
.b-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.b-kpi{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;padding:12px 14px}
.b-kpi .lb{font-size:11.5px;color:var(--b-ink-600);font-weight:500;text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:6px}
.b-kpi .vl{font-size:24px;font-weight:600;color:var(--b-ink-900);font-variant-numeric:tabular-nums;margin-top:4px;letter-spacing:-.4px}
.b-kpi .sb{font-size:11.5px;color:var(--b-ink-500);margin-top:1px}
.b-kpi.warn{border-left:3px solid var(--b-amber)}
.b-kpi.danger{border-left:3px solid var(--b-red)}
.b-kpi.ok{border-left:3px solid var(--b-green)}
.b-kpi.info{border-left:3px solid var(--b-navy-700)}
.b-kpi.primary{border-left:3px solid var(--b-gold);background:linear-gradient(90deg,var(--b-gold-50) 0%,#fff 30%)}

/* === Helpers === */
.b-empty{padding:32px;text-align:center;color:var(--b-ink-500);font-size:13px}
.b-tag{display:inline-block;padding:1px 6px;background:var(--b-ink-100);color:var(--b-ink-700);border-radius:2px;font-size:11px;font-weight:500}
.b-divider{height:1px;background:var(--b-ink-200);margin:14px 0}
.b-link{color:var(--b-navy-700);font-weight:500}
.b-link:hover{text-decoration:underline}
.b-mono{font-family:var(--b-mono)}
.b-num{font-family:var(--b-mono);font-variant-numeric:tabular-nums}
.b-flex{display:flex;gap:8px;align-items:center}
.b-grid{display:grid;gap:10px}

/* === Login === */
.b-login-wrap{min-height:100vh;background:#f0f3f8 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><path d='M0 .5h40M.5 0v40' fill='none' stroke='%23dde1ea' stroke-width='.5'/></svg>");display:flex;flex-direction:column}
.b-login-card{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;width:380px;margin:auto;box-shadow:0 8px 24px rgba(20,30,55,.07);overflow:hidden}
.b-login-head{background:var(--b-navy-800);color:#fff;padding:18px 20px;border-bottom:3px solid var(--b-gold);display:flex;align-items:center;gap:12px}
.b-login-head .lg{width:42px;height:42px;background:var(--k-red);color:#fff;font-weight:800;font-size:22px;display:grid;place-items:center;border-radius:3px;letter-spacing:-1px;box-shadow:inset 0 -2px 0 rgba(0,0,0,.18)}
.b-login-head h1{margin:0;font-size:16px;font-weight:600}
.b-login-head .sub{font-size:11.5px;color:#aebcd5;margin-top:1px}
.b-login-foot{background:var(--b-ink-50);padding:10px 20px;font-size:11.5px;color:var(--b-ink-500);border-top:1px solid var(--b-ink-200);display:flex;justify-content:space-between}
.b-login-body{display:flex;flex-direction:column;min-height:100vh}

/* === Drawer / Tab === */
.b-drawer{background:#fff;border-left:1px solid var(--b-ink-200)}
.b-drawer .h{padding:12px 14px;border-bottom:1px solid var(--b-ink-200);background:var(--b-ink-50)}
.b-tabs{display:flex;border-bottom:1px solid var(--b-ink-200);background:#fff;padding:0 14px;gap:0}
.b-tabs .tb{padding:9px 14px;font-size:13px;font-weight:500;color:var(--b-ink-600);cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;margin-bottom:-1px;text-decoration:none}
.b-tabs .tb:hover{color:var(--b-navy-700)}
.b-tabs .tb.act{color:var(--b-navy-800);border-bottom-color:var(--b-navy-700);font-weight:600}
.b-tabs .tb .ct{font-size:10.5px;background:var(--b-ink-100);color:var(--b-ink-700);padding:1px 6px;border-radius:2px;font-weight:600;font-family:var(--b-mono)}

/* === Messages === */
.b-messages{list-style:none;padding:0;margin:0 0 12px 0}
.b-msg{padding:8px 12px;border:1px solid var(--b-ink-200);border-radius:3px;font-size:12.5px;margin-bottom:6px;background:#fff}
.b-msg-error,.b-msg-danger{background:var(--b-red-50);border-color:#e8b8b6;color:var(--b-red)}
.b-msg-warning{background:var(--b-amber-50);border-color:#e8d29e;color:var(--b-amber)}
.b-msg-success{background:var(--b-green-50);border-color:#bfdfcd;color:var(--b-green)}
.b-msg-info{background:var(--b-navy-50);border-color:#bfd0e8;color:var(--b-navy-700)}

/* === Error pages === */
.b-error-body{min-height:100vh;display:flex;flex-direction:column;background:var(--b-ink-50)}
.b-error-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;width:100%}
.b-error-card{background:#fff;border:1px solid var(--b-ink-200);border-radius:6px;padding:32px 28px;text-align:center;width:100%;max-width:440px;box-shadow:0 4px 16px rgba(20,30,55,.06)}
.b-error-code{font-size:64px;font-weight:700;color:var(--b-navy-700);letter-spacing:-2px;line-height:1;margin-bottom:8px;font-family:var(--b-mono)}
.b-error-title{font-size:22px;font-weight:600;margin:8px 0 10px;color:var(--b-ink-900);letter-spacing:-.2px}
.b-error-msg{font-size:13.5px;color:var(--b-ink-600);margin:0 0 22px;line-height:1.55}
.b-error-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.b-error-foot{margin-top:20px;font-size:11.5px;color:var(--b-ink-500);text-align:center;padding:0 20px}

/* === Hamburger nav toggle (mobile) === */
.b-nav-toggle{display:none;background:transparent;border:1px solid var(--b-ink-300);border-radius:3px;width:36px;height:32px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0;margin-right:8px}
.b-nav-toggle-bar{display:block;width:18px;height:2px;background:var(--b-ink-700);border-radius:1px}
.b-nav-items{display:contents}

/* === Mobil === */
@media (max-width:768px){
  /* iOS Safari ≥ 16px auto-zoom guard */
  input[type="text"],input[type="email"],input[type="password"],input[type="number"],input[type="date"],input[type="search"],input[type="tel"],input[type="url"],input[type="datetime-local"],input[type="time"],input[type="month"],input[type="week"],select,textarea{font-size:16px}
  /* Touch targets */
  .b-btn{min-height:44px}
  .b-btn.xs{min-height:36px}
  .b-nav a{min-height:44px}
  .b-tabs .tb{min-height:44px}
  .b-tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  /* Hamburger drawer */
  .b-nav-toggle{display:flex}
  .b-nav-items{display:none;position:absolute;top:42px;left:0;right:0;background:#fff;border-bottom:1px solid var(--b-ink-200);flex-direction:column;padding:6px 0;box-shadow:0 4px 12px rgba(20,30,55,.08);z-index:11}
  .b-nav-items.open{display:flex}
  .b-nav-items a{height:auto;padding:10px 16px;border-bottom:1px solid var(--b-ink-100);margin-bottom:0}
  /* Mobile dropdown — inline open */
  .b-nav-items .b-nav-grp{display:flex;flex-direction:column;align-items:stretch}
  .b-nav-items .b-nav-grp > a{padding:10px 16px}
  .b-nav-items .b-nav-dd{position:static;border:0;border-top:1px solid var(--b-ink-100);box-shadow:none;background:var(--b-ink-50);display:none}
  .b-nav-items .b-nav-grp.open .b-nav-dd{display:flex}
  .b-nav-items .b-nav-dd a{padding-left:32px;font-size:12.5px}
  .b-nav-items .b-nav-grp:hover .b-nav-dd{display:none}
  .b-nav-items .b-nav-grp.open:hover .b-nav-dd{display:flex}
  .b-nav{position:relative}
  /* Layout sıkıştırma */
  .b-page{padding:14px}
  .b-kpi-grid{grid-template-columns:1fr 1fr}
  .b-form .row.c2,.b-form .row.c3,.b-form .row.c4{grid-template-columns:1fr}
  .b-page-h{flex-direction:column;align-items:flex-start}
  .b-login-card{width:min(380px,calc(100vw - 32px))}
  .b-error-card{padding:24px 18px;max-width:100%}
  .b-error-code{font-size:52px}
  .b-error-title{font-size:19px}
  .b-error-actions .b-btn{flex:1 1 auto;min-width:140px}
  /* Banner mobile compact */
  .b-banner{padding:0 12px;gap:10px}
  .b-banner .b-brand{font-size:14px}
  .b-banner .b-brand .sub{display:none}
}

/* ===== UI-FIX-2 — B-Form fields ===== */
.b-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px}
.b-form-row{display:flex;flex-direction:column;gap:6px}
.b-form-row.full{grid-column:1/-1}
.b-form-row label{font-size:12.5px;color:var(--b-ink-700);font-weight:600;letter-spacing:.02em}
.b-form-row label .req{color:#c0392b;margin-left:2px}
.b-form-row input[type="text"],
.b-form-row input[type="number"],
.b-form-row input[type="date"],
.b-form-row input[type="email"],
.b-form-row input[type="tel"],
.b-form-row select,
.b-form-row textarea{
  width:100%;padding:9px 11px;border:1px solid var(--b-ink-200);border-radius:6px;
  font-family:inherit;font-size:13px;color:var(--b-ink-900);background:#fff;
  transition:border-color .15s,box-shadow .15s
}
.b-form-row textarea{resize:vertical;min-height:60px;font-family:inherit}
.b-form-row input:focus,.b-form-row select:focus,.b-form-row textarea:focus{
  outline:none;border-color:var(--b-navy-600);box-shadow:0 0 0 3px rgba(28,52,100,.12)
}
.b-form-row.has-error input,.b-form-row.has-error select,.b-form-row.has-error textarea{
  border-color:#c0392b;background:#fdf3f1
}
.b-form-row .err-msg{font-size:12px;color:#c0392b;margin-top:2px}
.b-form-row .hint{font-size:11.5px;color:var(--b-ink-500);margin-top:2px}
.b-card-f{padding:14px 18px;border-top:1px solid var(--b-ink-100);background:var(--b-ink-50);display:flex;gap:10px;justify-content:flex-end;border-radius:0 0 var(--b-r,8px) var(--b-r,8px)}
.b-alert{padding:10px 14px;border-radius:6px;margin-bottom:14px;font-size:13px}
.b-alert.err{background:#fdf3f1;border:1px solid #e8c8c1;color:#9a2a1c}
.b-alert.ok{background:#eef7f0;border:1px solid #c8e6cf;color:#1f6b34}

/* ===== UI-FIX-2 — Detail kv / timeline / stats / empty-state ===== */
.b-kv{display:grid;grid-template-columns:140px 1fr;gap:8px 14px;font-size:13px;margin:0}
.b-kv dt{color:var(--b-ink-500);font-weight:500}
.b-kv dd{margin:0;color:var(--b-ink-900)}
.b-timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:13px}
.b-timeline li{padding:8px 12px;background:var(--b-ink-50);border-left:3px solid var(--b-navy-700);border-radius:0 6px 6px 0}
.b-timeline li b{color:var(--b-navy-800)}
.b-stats{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.b-stats li{padding:10px 12px;background:var(--b-ink-50);border-radius:6px;display:flex;flex-direction:column;gap:2px}
.b-stats b{font-family:var(--b-mono);font-size:18px;color:var(--b-navy-700)}
.b-stats span{font-size:11.5px;color:var(--b-ink-500)}
.b-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.b-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.b-empty-state{padding:42px 18px;text-align:center;background:#fff;border:1px solid var(--b-ink-100);border-radius:8px}
.b-empty-state .ico{font-size:34px;color:var(--b-ink-300);margin-bottom:8px}
.b-empty-state h3{margin:0 0 4px;color:var(--b-ink-700)}
.b-empty-state p{margin:0;color:var(--b-ink-500);font-size:13px}
.b-card-link{cursor:pointer;transition:transform .12s,box-shadow .12s;text-decoration:none;color:inherit;display:block}
.b-card-link:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(20,30,55,.08)}
.b-form-inline{display:flex;gap:10px;align-items:center}
.b-form-inline input{flex:1;padding:9px 11px;border:1px solid var(--b-ink-200);border-radius:6px;font-size:13px}
.b-stat{padding:14px;background:#fff;border:1px solid var(--b-ink-100);border-radius:8px;display:flex;flex-direction:column;gap:4px}
.b-stat b{font-family:var(--b-mono);font-size:24px;color:var(--b-navy-700)}
.b-stat span{font-size:12px;color:var(--b-ink-500)}
.b-stat.ok b{color:#1f6b34}
.b-stat.err b{color:#9a2a1c}
.b-row-err{background:#fdf3f1}

@media (max-width: 768px){
  .b-form-grid{grid-template-columns:1fr}
  .b-grid-2,.b-grid-3{grid-template-columns:1fr}
  .b-kv{grid-template-columns:1fr;gap:2px 0}
  .b-kv dt{margin-top:8px}
  .b-stats{grid-template-columns:1fr 1fr}
}

/* ===== UI-FIX-3 — Claude Design birebir uyum =====
   Source: B TİPİ TASARIM EKRAN GÖRÜNTÜLERİ CLAUDE DESİGN screenshots */

/* Plant switcher (sağ üst nav köşesi): "Şube: [Kısık HES ▼]" */
.b-nav .ctx{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--b-ink-500);padding:0 16px 0 6px;margin-left:auto;height:42px}
.b-nav .ctx > span{font-weight:500;color:var(--b-ink-600);text-transform:none;white-space:nowrap}
.b-nav .ctx select{
  height:28px;min-width:140px;border:1px solid var(--b-ink-300);background:#fff;border-radius:3px;
  padding:0 26px 0 10px;font-size:12.5px;color:var(--b-ink-800);font-family:inherit;font-weight:500;
  cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%231c3464' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 9px center;
}
.b-nav .ctx select:hover{border-color:var(--b-navy-600);color:var(--b-navy-800)}
.b-nav .ctx select:focus{outline:0;border-color:var(--b-navy-600);box-shadow:0 0 0 2px var(--b-navy-100)}
.b-nav .ctx select:disabled{opacity:.55;cursor:not-allowed;background-color:var(--b-ink-50)}
.b-nav .sep{flex:1}

/* Breadcrumb (eski .NET ergonomisi) */
.b-bread{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--b-ink-500);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}
.b-bread a{color:var(--b-ink-500);text-decoration:none}
.b-bread a:hover{color:var(--b-navy-700)}
.b-bread .sep{color:var(--b-ink-300)}
.b-bread .cur{color:var(--b-navy-800);font-weight:600}

/* Sub-tabs (Kullanıcılar 14 | Gruplar 5 | ...) — count badge inline */
.b-subtabs{display:flex;gap:4px;border-bottom:1px solid var(--b-ink-200);background:#fff;padding:6px 8px 0;border-radius:4px 4px 0 0;border:1px solid var(--b-ink-200);border-bottom:0;flex-wrap:wrap}
.b-subtabs .tab{
  padding:7px 12px;font-size:12.5px;font-weight:500;color:var(--b-ink-700);cursor:pointer;
  border:1px solid var(--b-ink-200);border-bottom:0;border-radius:3px 3px 0 0;background:var(--b-ink-50);
  display:inline-flex;align-items:center;gap:6px;text-decoration:none;margin-bottom:-1px;
}
.b-subtabs .tab:hover{background:#fff;color:var(--b-navy-800)}
.b-subtabs .tab.act{background:#fff;color:var(--b-navy-800);font-weight:600;border-color:var(--b-ink-300);border-bottom-color:#fff}
.b-subtabs .tab .ct{font-size:11px;background:var(--b-ink-100);color:var(--b-ink-700);padding:0 6px;border-radius:8px;font-weight:600;font-family:var(--b-mono);min-width:18px;text-align:center}
.b-subtabs .tab.act .ct{background:var(--b-navy-100);color:var(--b-navy-800)}

/* Status badges (Aktif / Pasif text + dot) — Tanımlar screenshot */
.b-status{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--b-ink-700)}
.b-status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--b-ink-400);display:inline-block}
.b-status.ok::before{background:var(--b-green)}
.b-status.warn::before{background:var(--b-amber)}
.b-status.danger::before{background:var(--b-red)}
.b-status.off::before{background:var(--b-ink-400)}

/* Role pill (Admin / Operatör / Görüntüleyici / vb.) — Tanımlar screenshot */
.b-role{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-size:11.5px;font-weight:600;font-family:var(--b-mono);letter-spacing:.2px;border:1px solid transparent}
.b-role.admin{background:#fdecc8;color:#7a5f1e;border-color:#e6d4a4}
.b-role.mudur{background:#e3e9f3;color:var(--b-navy-700);border-color:#bfd0e8}
.b-role.operator{background:var(--b-ink-100);color:var(--b-ink-700);border-color:var(--b-ink-200)}
.b-role.gorunt{background:#dbeafe;color:#0c4a6e;border-color:#bae6fd}
.b-role.rapor{background:#ede9fe;color:#5b21b6;border-color:#ddd6fe}
.b-role.tumi{background:var(--b-green-50);color:var(--b-green);border-color:#bfdfcd}

/* Onay önizleme panel (sağ alt — Stok Girişi screenshot) */
.b-preview-panel{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;padding:12px 14px;margin-bottom:14px}
.b-preview-panel h4{margin:0 0 8px;font-size:12.5px;font-weight:600;color:var(--b-ink-800);display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.3px}
.b-preview-panel ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px;font-size:12px}
.b-preview-panel li{display:flex;align-items:center;gap:6px;color:var(--b-ink-700)}
.b-preview-panel li.ok{color:var(--b-green)}
.b-preview-panel li.warn{color:var(--b-amber)}
.b-preview-panel li.err{color:var(--b-red)}
.b-preview-panel li::before{content:"";width:14px;height:14px;display:inline-block;flex-shrink:0}
.b-preview-panel li.ok::before{content:"✓";color:var(--b-green);font-weight:700;text-align:center}
.b-preview-panel li.warn::before{content:"⚠";color:var(--b-amber);font-weight:700;text-align:center}
.b-preview-panel li.err::before{content:"✗";color:var(--b-red);font-weight:700;text-align:center}

/* Belgeler (upload kartı — Stok Girişi screenshot sağ panel) */
.b-doc-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.b-doc-card{background:#fff;border:1px solid var(--b-ink-200);border-radius:4px;padding:12px}
.b-doc-card h5{margin:0 0 8px;font-size:11.5px;font-weight:600;color:var(--b-ink-700);text-transform:uppercase;letter-spacing:.3px}
.b-doc-card .b-doc-actions{display:flex;gap:6px;align-items:center;font-size:11.5px;color:var(--b-ink-500)}

/* Mobile drawer (hamburger) — current implementation extension */
.b-nav-toggle{display:none}
@media (max-width: 768px){
  .b-nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:3px;width:32px;height:32px;border:0;background:transparent;cursor:pointer;padding:0;margin-right:8px}
  .b-nav-toggle-bar{display:block;width:18px;height:2px;background:var(--b-ink-700);border-radius:1px;transition:transform .15s}
  .b-nav-items{display:none;position:absolute;top:42px;left:0;right:0;background:#fff;border-bottom:1px solid var(--b-ink-200);flex-direction:column;padding:6px 0;box-shadow:0 4px 12px rgba(20,30,55,.08);z-index:11}
  .b-nav-items.open{display:flex}
  .b-nav-items a{height:auto;padding:10px 16px;border-bottom:1px solid var(--b-ink-100);margin-bottom:0}
  .b-nav-items .b-nav-grp{display:flex;flex-direction:column;align-items:stretch}
  .b-nav-items .b-nav-grp > a{padding:10px 16px}
  .b-nav-items .b-nav-dd{position:static;border:0;border-top:1px solid var(--b-ink-100);box-shadow:none;background:var(--b-ink-50);display:none}
  .b-nav-items .b-nav-grp.open .b-nav-dd{display:flex}
  .b-nav-items .b-nav-dd a{padding-left:32px;font-size:12.5px}
  .b-nav{position:relative}
  /* Plant switcher mobile */
  .b-nav .ctx{padding:8px 16px;border-top:1px solid var(--b-ink-100);background:var(--b-ink-50);width:100%;margin-left:0;height:auto;justify-content:flex-start}
  .b-nav .ctx select{flex:1;min-width:auto}
  .b-doc-cards{grid-template-columns:1fr}
  .b-subtabs{padding:6px 4px 0}
  .b-subtabs .tab{padding:6px 9px;font-size:11.5px}
}

/* ===== PI-ICON-1 — Belge var/yok ikonu (eski ASP.NET ✓/X parity) ===== */
.doc-check{
  display:inline-block;font-family:var(--b-mono),'Consolas',monospace;
  font-weight:700;font-size:14px;line-height:1;
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid transparent;vertical-align:middle;
}
.doc-check--yes{background:var(--b-green-50);color:var(--b-green);border-color:#bfdfcd}
.doc-check--no{background:var(--b-red-50);color:var(--b-red);border-color:#e8b8b6}
