/* ==========================================================
   İMP TAKİP  —  v6  (referans: dark SaaS admin panel)
   ========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── Renk Değişkenleri ─────────────────────────────────── */
:root{
  --c-brand:    #00b09b;
  --c-brand2:   #00d4b5;
  --c-brand-gl: rgba(0,176,155,.22);
  --c-brand-bg: rgba(0,176,155,.1);

  --c-ok:      #22c55e;  --c-ok-bg:   rgba(34,197,94,.12);   --c-ok-txt:  #4ade80;
  --c-err:     #f43f5e;  --c-err-bg:  rgba(244,63,94,.12);   --c-err-txt: #fb7185;
  --c-warn:    #f59e0b;  --c-warn-bg: rgba(245,158,11,.12);  --c-warn-txt:#fbbf24;
  --c-info:    #3b82f6;  --c-info-bg: rgba(59,130,246,.12);  --c-info-txt:#60a5fa;

  /* Arka planlar */
  --bg:        #0f1923;
  --bg2:       #141e2d;
  --bg3:       #1a2538;
  --bg4:       #1f2d42;

  /* Sınırlar */
  --border:    rgba(255,255,255,.07);
  --border2:   rgba(255,255,255,.12);

  /* Yazı */
  --tx1:  #f1f5f9;
  --tx2:  #cbd5e1;
  --tx3:  #94a3b8;
  --tx4:  #64748b;

  /* Sidebar */
  --sb-w:  240px;

  /* Layout */
  --topbar: 56px;
  --r:  10px;
  --r2:  7px;
  --r3:  5px;

  /* Gölgeler */
  --sh1: 0 2px 8px rgba(0,0,0,.3);
  --sh2: 0 8px 24px rgba(0,0,0,.4);
  --sh3: 0 20px 48px rgba(0,0,0,.5);

  --t: .15s ease;
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-size:13.5px;line-height:1.55;
  background:var(--bg);color:var(--tx2);
  -webkit-font-smoothing:antialiased;
}
a{color:var(--c-brand);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--c-brand2)}
::selection{background:var(--c-brand-bg)}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:99px}

/* ── Light Mode ────────────────────────────────────────── */
body.light-mode,
html.light-mode body{
  --bg:   #f0f2f6;
  --bg2:  #ffffff;
  --bg3:  #f4f6f9;
  --bg4:  #eaecf2;
  --border:  rgba(0,0,0,.09);
  --border2: rgba(0,0,0,.16);
  --tx1: #0f172a;
  --tx2: #1e293b;
  --tx3: #475569;
  --tx4: #94a3b8;
}
html.light-mode body{background:var(--bg);color:var(--tx2);color-scheme:light}
html.light-mode body .top{background:rgba(240,242,246,.94) !important;border-bottom:1px solid rgba(0,0,0,.09)}
html.light-mode body .bottom-nav{background:rgba(248,249,252,.97);border-top-color:rgba(0,0,0,.09)}
html.light-mode body .bottom-nav a{color:#94a3b8}
html.light-mode body .bottom-nav a.active,
html.light-mode body .bottom-nav a:hover{color:var(--c-brand)}
html.light-mode body .bottom-nav a.fab{box-shadow:0 6px 18px var(--c-brand-gl),0 0 0 3px #f0f2f6}
body.light-mode .top{
  background:rgba(240,242,246,.94) !important;
  border-bottom:1px solid rgba(0,0,0,.09);
}
body.light-mode .card{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode table{background:#fff}
body.light-mode th{background:#f8f9fb;color:#64748b;border-bottom-color:rgba(0,0,0,.08)}
body.light-mode td{color:#1e293b;border-bottom-color:rgba(0,0,0,.07)}
body.light-mode tbody tr:hover td{background:rgba(0,176,155,.04)}
body.light-mode tbody tr.stock-low{background:rgba(245,158,11,.06)}
body.light-mode .table-wrap{border-color:rgba(0,0,0,.09);background:#fff}
body.light-mode .stat,.body.light-mode .db-stat{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode .modal{background:#fff}
body.light-mode .modal-head,.body.light-mode .modal-foot{background:#f8f9fb;border-color:rgba(0,0,0,.08)}
body.light-mode .chip{background:#fff;border-color:#e2e5ec;color:#1e293b}
body.light-mode .chip.active{background:var(--c-brand);color:#fff !important;border-color:var(--c-brand)}
body.light-mode .report-tabs{background:#f0f2f6;border-color:rgba(0,0,0,.1);box-shadow:none}
body.light-mode .report-tab{color:#334155}
body.light-mode .report-tab:hover{background:#fff;border-color:rgba(0,0,0,.12);color:#0f172a}
body.light-mode .report-tabs-label{color:#64748b}
body.light-mode .side-filter{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode .b-gray{background:#e8eaef;color:#475569}
body.light-mode input[type=text]:not(.fb-search-input),
body.light-mode input[type=email],
body.light-mode input[type=password],
body.light-mode input[type=number],
body.light-mode input[type=date],
body.light-mode input[type=tel],
body.light-mode select,
body.light-mode textarea{background:#fff;border-color:#d1d5db;color:#0f172a}
/* Filtre barı light */
body.light-mode .ufilter-bar,
body.light-mode .fail-filter-wrap{background:#e8eaf0;border-color:rgba(0,0,0,.1)}
body.light-mode .ufb-item{border-right-color:rgba(0,0,0,.08)}
body.light-mode .ufb-input,
body.light-mode .ufb-select,
body.light-mode .ufb-date{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.12);color:#0f172a}
body.light-mode .ufb-lbl,
body.light-mode .fdr-lbl{color:#64748b}
body.light-mode .fdr-toggle{color:#334155;background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1)}
body.light-mode .fdr-toggle:hover{color:var(--c-brand)}
body.light-mode .fdr-wrap.open .fdr-toggle{color:var(--c-brand);background:var(--c-brand-bg)}
body.light-mode .fdr-sel-item{border-right-color:rgba(0,0,0,.08)}
body.light-mode .fdr-select{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.1);color:#0f172a}
body.light-mode .fdr-panel,
body.light-mode .range-picker.collapsible .range-body{background:#fff;border-color:rgba(0,0,0,.12)}
body.light-mode .fdr-chip,
body.light-mode .range-chip{background:#f0f2f6;color:#334155 !important;border-color:rgba(0,0,0,.1)}
body.light-mode .fdr-chip:hover,
body.light-mode .range-chip:hover{border-color:var(--c-brand);color:var(--c-brand) !important;background:var(--c-brand-bg)}
body.light-mode .fdr-chip.active,
body.light-mode .range-chip.active{background:var(--c-brand);color:#fff !important;border-color:var(--c-brand)}
body.light-mode .range-custom,.body.light-mode .fdr-custom{background:#f8f9fb;border-color:rgba(0,0,0,.1)}
body.light-mode .range-custom input[type=date],
body.light-mode .fdr-custom input[type=date]{background:#fff;border-color:rgba(0,0,0,.12);color:#0f172a}
body.light-mode .range-toggle{color:#334155;background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1)}
body.light-mode .range-toggle:hover{color:var(--c-brand)}
/* Bottom nav light */
body.light-mode .bottom-nav{background:rgba(248,249,252,.97);border-top-color:rgba(0,0,0,.09)}
body.light-mode .bottom-nav a{color:#94a3b8}
body.light-mode .bottom-nav a.active,.body.light-mode .bottom-nav a:hover{color:var(--c-brand)}
body.light-mode .bottom-nav a.fab{box-shadow:0 6px 18px var(--c-brand-gl),0 0 0 3px #f0f2f6}

/* Sidebar — seçili öğe açık modda koyu yazı (beyaz üzeri gri okunmuyordu) */
body.light-mode .sidebar nav a.active{
  color:#0f172a;
  background:rgba(0,176,155,.12);
  border-left-color:var(--c-brand);
}
body.light-mode .sidebar nav a.active .nav-icon{color:var(--c-brand)}
body.light-mode .sidebar nav a:hover{color:var(--tx1);background:var(--bg4)}
body.light-mode .nav-group-toggle{color:#64748b}
body.light-mode .nav-group-toggle:hover,
body.light-mode .nav-group-toggle.active{color:#0f172a;background:rgba(0,176,155,.08)}
body.light-mode .nav-group:not(.open) .nav-group-toggle{background:transparent}

/* Theme toggle button */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:var(--r2);
  border:1px solid var(--border2);background:var(--bg3);
  cursor:pointer;color:var(--tx3);transition:all var(--t);flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--c-brand);color:var(--c-brand);background:var(--c-brand-bg)}
.theme-toggle svg{width:16px;height:16px;display:block}
.theme-toggle .ico-dark{display:block}
.theme-toggle .ico-light{display:none}
body.light-mode .theme-toggle .ico-dark{display:none}
body.light-mode .theme-toggle .ico-light{display:block}

/* ── Login ─────────────────────────────────────────────── */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(ellipse 60% 50% at 0% 0%, rgba(0,176,155,.18),transparent 55%),
             radial-gradient(ellipse 50% 60% at 100% 100%, rgba(59,130,246,.15),transparent 55%),
             var(--bg);
}
.login-card{
  width:100%;max-width:380px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;box-shadow:var(--sh3);padding:36px 30px;
}
.login-card h2{font-size:20px;font-weight:800;color:var(--c-brand)}
.login-card p{font-size:13px;color:var(--tx4);margin:4px 0 22px}

/* ── Layout ────────────────────────────────────────────── */
.layout{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:var(--sb-w);min-width:var(--sb-w);flex-shrink:0;
  background:var(--bg2);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;z-index:50;
  border-right:1px solid var(--border);
}
.brand{
  display:flex;align-items:center;gap:10px;
  padding:16px 14px 14px;border-bottom:1px solid var(--border);
}
.logo{
  width:34px;height:34px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--c-brand),var(--c-brand2));
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#fff;
  box-shadow:0 4px 10px var(--c-brand-gl);
}
.brand-name{font-size:13.5px;font-weight:700;color:var(--tx1)}
.brand-sub{font-size:9.5px;color:var(--tx4);text-transform:uppercase;letter-spacing:.1em;margin-top:1px}

.sidebar nav{flex:1;overflow-y:auto;padding:8px 8px;display:flex;flex-direction:column;gap:1px}
.sidebar nav::-webkit-scrollbar{width:0}
.nav-title{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--tx4);padding:13px 8px 4px}
.nav-group{margin-top:4px}
.nav-group-toggle{
  width:100%;height:31px;border:0;background:transparent;border-radius:var(--r2);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:0 8px;color:var(--tx4);cursor:pointer;font:inherit;
  transition:background var(--t),color var(--t);
}
.nav-group-toggle:hover,.nav-group-toggle.active{color:var(--tx2);background:rgba(255,255,255,.035)}
.nav-group-title{
  font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.nav-group-chev{
  width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  color:currentColor;opacity:.75;transition:transform var(--t),background var(--t),opacity var(--t);
}
.nav-group-chev svg{width:14px;height:14px;display:block}
.nav-group-toggle:hover .nav-group-chev{opacity:1;background:rgba(255,255,255,.04)}
.nav-group.open .nav-group-chev{transform:rotate(180deg)}
.nav-group-items{
  display:flex;flex-direction:column;gap:1px;
  margin-top:2px;padding-left:6px;border-left:1px solid rgba(255,255,255,.05);
}
.nav-group:not(.open) .nav-group-items{display:none}
.sidebar nav a{
  display:flex;align-items:center;gap:9px;
  padding:8px 10px;border-radius:var(--r2);
  color:var(--tx3);font-size:13px;font-weight:500;
  transition:all var(--t);
}
.sidebar nav a:hover{color:var(--tx1);background:var(--bg3);text-decoration:none}
.sidebar nav a.active{
  color:#fff;background:var(--bg3);
  border-left:2px solid var(--c-brand);font-weight:600;
}
.sidebar nav a.active .nav-icon{color:var(--c-brand)}
.nav-icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity var(--t)}
.nav-icon svg{width:16px;height:16px;display:block}
.sidebar nav a:hover .nav-icon,.sidebar nav a.active .nav-icon{opacity:1}

.sidebar-foot{border-top:1px solid var(--border);padding:11px 12px;display:flex;align-items:center;gap:9px}
.user-profile-link{display:flex;align-items:center;gap:9px;min-width:0;flex:1;border-radius:var(--r2);padding:4px 5px;margin:-4px -5px;color:inherit;text-decoration:none !important;transition:all var(--t)}
.user-profile-link:hover,.user-profile-link.active{background:var(--bg3)}
.user-profile-link:hover .user{color:var(--c-brand)}
.user-profile-link.active .user{color:var(--c-brand)}
.user-profile-link:hover .user-role{color:var(--tx2)}
.user-profile-link.active .user-role{color:var(--tx2)}
.user-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--c-brand),var(--c-brand2));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff}
.user-info{flex:1;min-width:0}
.user{font-size:12px;font-weight:600;color:var(--tx1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:9.5px;color:var(--tx4);text-transform:uppercase;letter-spacing:.07em;margin-top:1px}
.logout{color:var(--tx4);padding:4px;border-radius:5px;display:flex;align-items:center;transition:all var(--t);flex-shrink:0}
.logout svg{width:14px;height:14px}
.logout:hover{color:var(--c-err-txt);background:var(--c-err-bg);text-decoration:none}

.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);z-index:40;opacity:0;transition:opacity var(--t)}
.sidebar-overlay.open{display:block;opacity:1}

/* Role permissions */
.role-perm-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.role-perm-card{
  border:1px solid var(--border);border-radius:var(--r);
  padding:12px;background:rgba(255,255,255,.018);
}
.role-perm-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;color:var(--tx4);font-size:12px;font-weight:700}
.role-perm-note{font-size:12px;color:var(--tx4);background:var(--bg3);border-radius:var(--r2);padding:8px 9px;margin-bottom:10px}
.role-perm-sections{display:flex;flex-direction:column;gap:10px}
.role-perm-section{display:flex;flex-direction:column;gap:6px}
.role-perm-section-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--tx4)}
.role-perm-matrix{
  border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;
  background:rgba(0,0,0,.08);
}
.role-perm-row{
  display:grid;grid-template-columns:minmax(180px,1.8fr) repeat(5,58px);
  align-items:center;gap:0;border-top:1px solid var(--border);min-height:44px;
}
.role-perm-row:first-child{border-top:0}
.role-perm-row > div,.role-perm-row > label{padding:0 10px;height:100%;display:flex;align-items:center;justify-content:center}
.role-perm-row--head{
  min-height:36px;background:rgba(255,255,255,.03);color:var(--tx4);
  font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;
}
.role-perm-row--head > div:first-child{justify-content:flex-start}
.role-perm-page{
  justify-content:flex-start !important;gap:8px;color:var(--tx2);font-size:12.5px;font-weight:600;
}
.role-perm-page .nav-icon{width:15px;height:15px}
.role-perm-switch{
  cursor:pointer;position:relative;
}
.role-perm-switch input{
  position:absolute;opacity:0;pointer-events:none;
}
.role-perm-switch span{
  width:36px;height:22px;border-radius:999px;border:1px solid var(--border2);
  background:var(--bg3);display:inline-flex;align-items:center;padding:2px;transition:all var(--t);
}
.role-perm-switch span::after{
  content:'';width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.28);
  transform:translateX(0);transition:transform var(--t),background var(--t);
}
.role-perm-switch input:checked + span{background:var(--c-brand);border-color:var(--c-brand)}
.role-perm-switch input:checked + span::after{transform:translateX(14px)}
.role-perm-switch input:disabled + span{opacity:.38}
.role-perm-switch.is-disabled{cursor:default}
.role-perm-switch.is-disabled span{background:transparent}
body.light-mode .role-perm-card{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode .role-perm-note{background:#f4f6f9}
body.light-mode .role-perm-matrix{background:#fff;border-color:#e2e5ec}
body.light-mode .role-perm-row{border-top-color:#edf0f4}
body.light-mode .role-perm-row--head{background:#f8f9fb;color:#64748b}
body.light-mode .role-perm-page{color:#1e293b}
body.light-mode .role-perm-switch span{background:#e9edf3;border-color:#d6dbe3}
@media(max-width:1100px){.role-perm-grid{grid-template-columns:1fr}}
@media(max-width:760px){
  .role-perm-row{grid-template-columns:repeat(5,minmax(44px,1fr));grid-auto-rows:minmax(42px,auto)}
  .role-perm-row--head{display:none}
  .role-perm-page{grid-column:1 / -1;padding-top:10px;padding-bottom:4px}
  .role-perm-row > label{position:relative;padding:18px 0 10px}
  .role-perm-row > label::before{
    content:attr(data-short);position:absolute;top:6px;left:50%;transform:translateX(-50%);
    font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--tx4);
  }
  .role-perm-switch span{width:32px;height:20px}
  .role-perm-switch span::after{width:14px;height:14px}
  .role-perm-switch input:checked + span::after{transform:translateX(12px)}
}

/* Topbar */
.content{flex:1;display:flex;flex-direction:column;min-width:0}
.top{
  position:sticky;top:0;z-index:30;
  background:rgba(15,25,35,.96);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 22px;height:var(--topbar);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.top h1{font-size:16px;font-weight:700;color:var(--tx1);white-space:nowrap}
.top .actions{display:flex;gap:8px}
.menu-toggle{display:none;background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;color:var(--tx2)}
.menu-toggle:hover{background:var(--bg3)}
.menu-toggle svg{width:20px;height:20px;display:block}
.main-body{padding:18px 22px;flex:1}

/* ── Cards ─────────────────────────────────────────────── */
.card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:18px 20px;margin-bottom:14px;
  overflow:visible;
}
.card h2{font-size:13.5px;font-weight:700;color:var(--tx1);margin-bottom:14px;display:flex;align-items:center;gap:7px}

/* ── Grid ──────────────────────────────────────────────── */
.grid{display:grid;gap:12px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid.cols-2,.grid.cols-3,.grid.cols-4{grid-template-columns:1fr}}

/* ── Stat kartları ─────────────────────────────────────── */
.stat{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  padding:15px 16px;display:flex;align-items:center;gap:12px;transition:all var(--t);
}
.stat:hover{border-color:var(--border2);transform:translateY(-1px)}
.stat .ico{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;background:var(--c-brand-bg);color:var(--c-brand);flex-shrink:0}
.stat .lbl{font-size:10.5px;font-weight:700;color:var(--tx4);text-transform:uppercase;letter-spacing:.06em}
.stat .val{font-size:22px;font-weight:800;color:var(--tx1);line-height:1;margin-top:2px}
.stat.ok   .ico{background:var(--c-ok-bg);  color:var(--c-ok-txt)}
.stat.warn .ico{background:var(--c-warn-bg);color:var(--c-warn-txt)}
.stat.danger .ico{background:var(--c-err-bg); color:var(--c-err-txt)}

/* ── Tablo ─────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r2);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:13px;background:var(--bg2)}
th{
  background:var(--bg);
  padding:9px 12px;border-bottom:1px solid var(--border);
  font-size:10.5px;font-weight:700;color:var(--tx4);
  text-align:left;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;
}
td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--tx2);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr{transition:background var(--t)}
tbody tr:hover td{background:rgba(255,255,255,.02)}
tbody tr.stock-low{background:rgba(245,158,11,.04)}

/* ── Formlar ───────────────────────────────────────────── */
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:13px}
label{display:block;font-size:11.5px;font-weight:600;color:var(--tx3);margin-bottom:4px}
input[type=text]:not(.fb-search-input),input[type=email],input[type=password],input[type=number],
input[type=date],input[type=tel],input[type=search],select,textarea{
  width:100%;padding:8px 11px;font-size:13.5px;
  border:1px solid var(--border2);border-radius:var(--r2);
  background:var(--bg3);color:var(--tx1);font-family:inherit;
  outline:none;transition:all var(--t);
}
.product-search-wrap{position:relative;width:100%;min-width:0}
.product-select-native{
  position:absolute !important;left:0;top:0;width:1px !important;height:1px !important;
  opacity:0 !important;pointer-events:none !important;margin:0 !important;padding:0 !important;
}
.product-select-search{
  width:100%;min-height:42px;padding:9px 12px;font-size:14px;font-weight:600;
  border:1px solid var(--border2);border-radius:var(--r2);
  background:var(--bg3);color:var(--tx1);font-family:inherit;outline:none;
  transition:all var(--t);
}
.product-select-search:focus{border-color:var(--c-brand);box-shadow:0 0 0 2px var(--c-brand-gl)}
.product-search-results{
  display:none;
  position:absolute;
  left:0;
  top:calc(100% + 6px);
  margin-top:0;
  padding:7px;max-height:300px;overflow-y:auto;overflow-x:hidden;
  background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);
  box-shadow:var(--sh2);z-index:70;
  width:100%;max-width:100%;
}
.product-search-results.open{display:flex;flex-direction:column;gap:6px}
.product-search-option{
  width:100%;border:0;border-radius:var(--r2);padding:11px 13px;
  background:var(--bg2);color:var(--tx1);font:inherit;font-size:13px;font-weight:700;
  text-align:left;cursor:pointer;line-height:1.35;transition:all var(--t);
  white-space:normal;word-break:break-word;overflow-wrap:anywhere;
}
.product-search-option:hover,.product-search-option:focus{
  background:var(--c-brand-bg);color:var(--c-brand);outline:none;
}
.product-search-empty{padding:12px;color:var(--tx4);font-size:13px;text-align:center}
body.light-mode .product-select-search{background:#fff;border-color:#d1d5db;color:#0f172a}
body.light-mode .product-search-results{background:#fff;border-color:rgba(0,0,0,.1);box-shadow:0 14px 34px rgba(15,23,42,.12)}
body.light-mode .product-search-option{background:#f4f6f9;color:#0f172a}
body.light-mode .product-search-option:hover,body.light-mode .product-search-option:focus{background:var(--c-brand-bg);color:var(--c-brand)}
input:focus,select:focus,textarea:focus{border-color:var(--c-brand);box-shadow:0 0 0 2px var(--c-brand-gl)}
input::placeholder,textarea::placeholder{color:var(--tx4)}
textarea{min-height:80px;resize:vertical}
select{cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:28px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 11 11'%3E%3Cpath d='M5.5 7L2 3h7z' fill='%2364748b'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 9px center}
select option{background:#1a2538;color:#e2e8f0}

/* ── Butonlar ──────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 15px;border:none;border-radius:var(--r2);
  font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;
  color:#fff !important;text-decoration:none !important;white-space:nowrap;
  background:var(--c-brand);box-shadow:0 2px 6px var(--c-brand-gl);
  transition:all var(--t);
}
.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn:active{transform:none;filter:brightness(.95)}
.btn.secondary{background:#334155;box-shadow:none}
.btn.secondary:hover{background:#475569}
.btn.success{background:var(--c-ok);box-shadow:0 2px 6px var(--c-ok-bg)}
.btn.danger{background:var(--c-err);box-shadow:0 2px 6px var(--c-err-bg)}
.btn.outline{background:transparent !important;color:var(--tx2) !important;border:1px solid var(--border2);box-shadow:none}
.btn.outline:hover{border-color:var(--c-brand);color:var(--c-brand) !important;background:var(--c-brand-bg) !important}
.btn.sm{padding:4px 10px;font-size:12px;border-radius:var(--r3)}
.btn.sm.outline{padding:4px 9px}

/* ── Icon Butonlar ─────────────────────────────────────── */
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:var(--r3);
  border:1px solid var(--border2);background:var(--bg3);
  cursor:pointer;color:var(--tx3);transition:all var(--t);
  text-decoration:none !important;padding:0;flex-shrink:0;
}
.icon-btn svg{width:13px;height:13px;display:block}
.icon-btn:hover{border-color:var(--c-brand);color:var(--c-brand);background:var(--c-brand-bg)}
.icon-btn-danger:hover{border-color:var(--c-err);color:var(--c-err-txt);background:var(--c-err-bg)}
.prod-table{border-collapse:collapse;border-spacing:0}
.prod-table th{
  position:sticky;top:0;z-index:2;height:36px;padding:6px 10px;
  font-size:10px;text-align:center;letter-spacing:.06em;vertical-align:middle;
  background:var(--bg);border-bottom:1px solid var(--border2);
}
.prod-table td{
  height:36px;padding:6px 10px;font-size:12px;line-height:1.15;vertical-align:middle;
  background:transparent !important;border-bottom-color:rgba(255,255,255,.055);
}
.prod-table th:nth-child(1),.prod-table th:nth-child(2){text-align:left}
.prod-table tbody tr:nth-child(8n+1){--prod-row-bg:rgba(20,184,166,.075)}
.prod-table tbody tr:nth-child(8n+2){--prod-row-bg:rgba(59,130,246,.075)}
.prod-table tbody tr:nth-child(8n+3){--prod-row-bg:rgba(139,92,246,.075)}
.prod-table tbody tr:nth-child(8n+4){--prod-row-bg:rgba(245,158,11,.08)}
.prod-table tbody tr:nth-child(8n+5){--prod-row-bg:rgba(34,197,94,.075)}
.prod-table tbody tr:nth-child(8n+6){--prod-row-bg:rgba(236,72,153,.07)}
.prod-table tbody tr:nth-child(8n+7){--prod-row-bg:rgba(14,165,233,.075)}
.prod-table tbody tr:nth-child(8n){--prod-row-bg:rgba(100,116,139,.09)}
body.light-mode .prod-table tbody tr:nth-child(8n+1){--prod-row-bg:#fff7ed}
body.light-mode .prod-table tbody tr:nth-child(8n+2){--prod-row-bg:#eef6ff}
body.light-mode .prod-table tbody tr:nth-child(8n+3){--prod-row-bg:#f3f0ff}
body.light-mode .prod-table tbody tr:nth-child(8n+4){--prod-row-bg:#ecfdf5}
body.light-mode .prod-table tbody tr:nth-child(8n+5){--prod-row-bg:#fff1f2}
body.light-mode .prod-table tbody tr:nth-child(8n+6){--prod-row-bg:#f0fdfa}
body.light-mode .prod-table tbody tr:nth-child(8n+7){--prod-row-bg:#f8fafc}
body.light-mode .prod-table tbody tr:nth-child(8n){--prod-row-bg:#fefce8}
.prod-table tbody tr{background:var(--prod-row-bg);transition:filter var(--t),background var(--t)}
.prod-table tbody tr.stock-low{
  background:var(--prod-row-bg) !important;
}
.prod-table tbody tr.stock-low td{
  box-shadow:none;
}
.prod-table tbody tr.stock-low td:first-child{
  box-shadow:inset 3px 0 0 var(--c-warn);
}
.prod-table tbody tr:hover{filter:brightness(1.12)}
.prod-table tbody tr:hover td{background:transparent !important}
.prod-table .badge{padding:1px 6px;line-height:1.2}
.prod-table td[data-label="Öner. Min."] > div{
  flex-direction:row !important;gap:4px !important;align-items:center !important;
}
.prod-table .row-actions{display:inline-flex;gap:4px;justify-content:center;flex-wrap:nowrap;white-space:nowrap}
.prod-table .icon-btn{width:26px;height:26px}
.prod-table .icon-btn svg{width:12px;height:12px}
.prod-ui-icon{
  width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;opacity:.92
}
.prod-ui-icon svg{width:14px;height:14px;display:block}
.prod-ui-icon--warning{color:inherit}
.prod-head-label{
  display:inline-flex;align-items:center;gap:6px;
  color:inherit;white-space:nowrap;
}
.prod-head-label .prod-ui-icon{color:var(--c-brand)}
.prod-mini-badge{gap:4px}
.prod-mini-badge .prod-ui-icon{width:11px;height:11px;opacity:1}
.prod-mini-badge .prod-ui-icon svg{width:11px;height:11px}
@media(min-width:901px){
  .prod-table tr td.row-actions{width:64px;min-width:64px;padding:4px 6px}
}

/* ── Badge ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}
.b-green{background:var(--c-ok-bg);color:var(--c-ok-txt)}
.b-blue{background:var(--c-info-bg);color:var(--c-info-txt)}
.b-red{background:var(--c-err-bg);color:var(--c-err-txt)}
.b-amber{background:var(--c-warn-bg);color:var(--c-warn-txt)}
.b-gray{background:var(--bg4);color:var(--tx3)}
.b-purple{background:rgba(139,92,246,.15);color:#a78bfa}
.b-teal{background:var(--c-brand-bg);color:var(--c-brand)}

/* ── Flash ─────────────────────────────────────────────── */
.flash{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:var(--r2);margin-bottom:12px;font-size:13px;border:1px solid;animation:slideDown .2s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:translateY(0)}}
@keyframes floatIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.flash-success{background:var(--c-ok-bg);color:var(--c-ok-txt);border-color:rgba(34,197,94,.25)}
.flash-error{background:var(--c-err-bg);color:var(--c-err-txt);border-color:rgba(244,63,94,.25)}
.flash-info{background:var(--c-info-bg);color:var(--c-info-txt);border-color:rgba(59,130,246,.25)}

/* ── Misc ──────────────────────────────────────────────── */
.actions{display:flex;gap:7px;flex-wrap:wrap}
.row-actions{display:flex;gap:4px;flex-wrap:wrap}
.filter-bar{display:flex;flex-wrap:wrap;gap:9px;align-items:flex-end;margin-bottom:14px}
.filter-bar > div{min-width:140px}
hr{border:none;border-top:1px solid var(--border);margin:13px 0}
.empty{padding:44px 20px;text-align:center;color:var(--tx4)}
.empty h3{font-size:14px;font-weight:600;color:var(--tx2);margin-bottom:5px}
.items-table input[type=number]{padding:6px 9px}
.items-table td{padding:7px 10px}
.items-table select{padding:6px 26px 6px 9px}
.modal-inline{border:1px dashed var(--border2);background:var(--bg3);padding:13px;border-radius:var(--r2);margin-top:11px}

/* ── Side Filter (ürünler yan paneli) ─────────────────── */
.side-layout{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:flex-start}
.side-filter{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;position:sticky;top:calc(var(--topbar) + 14px)}
.side-filter h3{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:var(--tx4);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.side-filter h3 small{font-size:9px;opacity:.7;text-transform:none;letter-spacing:0}
.side-filter .search-box{margin-bottom:14px}
.side-filter .search-box input{width:100%}
.chip-list{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.chip{display:flex;justify-content:space-between;align-items:center;padding:8px 11px;border:1px solid var(--border);border-radius:var(--r2);background:var(--bg3);color:var(--tx2);font-size:12.5px;font-weight:500;text-decoration:none !important;transition:all var(--t);cursor:pointer}
.chip:hover{border-color:var(--c-brand);color:var(--c-brand);background:var(--c-brand-bg)}
.chip.active{background:var(--c-brand);color:#fff !important;border-color:var(--c-brand);box-shadow:0 2px 8px var(--c-brand-gl)}
.chip .count{background:var(--bg4);color:var(--tx3);border-radius:999px;padding:1px 8px;font-size:10.5px;font-weight:700;min-width:22px;text-align:center}
.chip.active .count{background:rgba(255,255,255,.2);color:#fff}
.chip.muted{opacity:.4;pointer-events:none}

/* Ürünler / Stok — mobil: kompakt form + ürün kartları (küçük ekranda tablo satır-satır çöküyor) */
.product-filters-mobile{display:none}
.product-mob-cards{display:none;flex-direction:column;gap:8px}
.product-filters-mobile-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border);
}
.product-filters-mobile-title{
  font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--tx4);
}
.product-filters-mobile-clear{font-size:12.5px;font-weight:600;color:var(--c-brand);text-decoration:none}
.product-filters-mobile-clear:hover{text-decoration:underline}
.product-filters-mobile .product-filters-mobile-row{grid-template-columns:1fr 1fr;gap:10px}
.product-filters-mobile input[type=search],.product-filters-mobile input[type=text],
.product-filters-mobile select{min-height:44px;font-size:16px}
.product-filters-mobile .product-filters-mobile-submit{width:100%;min-height:44px;margin-top:4px}
.product-mob-name{font-size:13.5px;font-weight:800;color:var(--tx1);line-height:1.3;margin-top:6px;word-break:break-word}
.product-mob-card-badges{display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.product-mob-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:6px 8px;margin-top:10px;
  padding-top:10px;border-top:1px solid var(--border);
}
.product-mob-cell{display:flex;flex-direction:column;gap:1px;min-width:0}
.product-mob-lbl{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tx4);
  display:inline-flex;align-items:center;gap:4px
}
.product-mob-lbl .prod-ui-icon{width:11px;height:11px;color:var(--c-brand)}
.product-mob-lbl .prod-ui-icon svg{width:11px;height:11px}
.product-mob-val{font-size:12.5px;font-weight:600;color:var(--tx1);text-align:right}
.product-mob-val--badges{
  display:flex;align-items:center;justify-content:flex-end;min-height:20px;
}
.product-mob-cell--wide{
  grid-column:1/-1;flex-direction:row;align-items:center;justify-content:space-between;
  padding:6px 0 2px;border-top:1px dashed var(--border);margin-top:2px;gap:8px
}
.product-mob-cell--wide .product-mob-lbl{align-self:center}
.product-mob-val--big{font-size:16px !important}
.product-mob-oneri{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;
  margin-top:6px;padding:6px 9px;border-radius:var(--r2);font-size:12px;font-weight:500;
  background:var(--bg3);color:var(--tx2);
}
.product-mob-oneri--bad{background:var(--c-err-bg);color:var(--c-err-txt)}
.product-mob-oneri--ok{background:var(--c-ok-bg);color:var(--c-ok-txt)}
.product-mob-oneri-sub{font-size:11px;opacity:.85}
.product-mob-actions{flex-wrap:wrap;justify-content:stretch;gap:8px}
.product-mob-actions .btn{flex:1;min-width:0;min-height:40px;justify-content:center}
.product-mob-card--warn{border-color:rgba(244,63,94,.3)}
.product-mob-empty{text-align:center;padding:28px 16px;color:var(--tx4)}
.product-mob-empty-ico{
  width:54px;height:54px;margin:0 auto 8px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:var(--c-brand-bg);color:var(--c-brand)
}
.product-mob-empty-ico .prod-ui-icon{width:28px;height:28px;opacity:1}
.product-mob-empty-ico .prod-ui-icon svg{width:28px;height:28px}
.product-mob-empty-txt{font-size:14px;font-weight:600;color:var(--tx2)}

body.light-mode .product-mob-oneri{background:rgba(0,0,0,.04);color:var(--tx1)}

@media(max-width:900px){
  .product-stock-page .product-filters-mobile{display:block}
  .product-stock-page .product-filters-desktop{display:none !important}
  .product-stock-page #mainProductTableWrap{display:none !important}
  .product-stock-page .product-mob-cards{display:flex !important}
}

/* Raporlar — sekme çubuğu (segmented nav) */
.report-tabs-wrap{margin-bottom:18px}
.report-tabs-label{
  display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--tx4);margin:0 0 10px 2px;
}
.report-tabs{
  display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  padding:7px;max-width:100%;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
@media (max-width:720px){
  .report-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:8px;padding:8px;
    scroll-snap-type:x mandatory;overscroll-behavior-x:contain;
  }
  .report-tab{scroll-snap-align:start}
}
.report-tab{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 14px;border-radius:999px;
  font-size:12.5px;font-weight:600;font-family:inherit;
  text-decoration:none !important;white-space:nowrap;flex-shrink:0;
  color:var(--tx2);border:1px solid transparent;background:transparent;
  transition:background .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease;
  cursor:pointer;line-height:1.2;
}
.report-tab:hover{
  color:var(--tx1);background:var(--bg2);border-color:var(--border2);
}
.report-tab.active{
  color:#fff !important;background:var(--c-brand);border-color:var(--c-brand);
  box-shadow:0 2px 12px var(--c-brand-gl);
}
.report-tab.active:hover{color:#fff !important;filter:brightness(1.04)}
.report-tab:focus-visible{
  outline:2px solid var(--c-brand2);outline-offset:2px
}

/* ── Modal ─────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);z-index:999;display:none;align-items:flex-start;justify-content:center;padding:38px 16px;overflow-y:auto}
.modal-backdrop.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);max-width:700px;width:100%;box-shadow:var(--sh3);overflow:hidden;animation:modalIn .2s ease}
@keyframes modalIn{from{transform:translateY(-16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.modal-head{padding:15px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg)}
.modal-head h3{margin:0;font-size:15px;font-weight:700;color:var(--tx1)}
.modal-close{background:none;border:none;cursor:pointer;color:var(--tx4);padding:4px 8px;border-radius:var(--r3);font-size:20px;line-height:1;transition:all var(--t)}
.modal-close:hover{background:var(--bg3);color:var(--tx1)}
.modal-body{padding:20px;max-height:calc(100vh - 220px);overflow-y:auto}
.modal-foot{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg);display:flex;gap:7px;justify-content:flex-end}
body.modal-open{overflow:hidden}

/* ================================================================
   FİLTRE ÇUBUĞU (.fb-*)  —  Dropdown tabanlı
   ================================================================ */
.fb-wrap{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:10px 14px;
  margin-bottom:14px;
  position:relative;
  z-index:4;
  overflow:visible;
}
/* Açık panel varken tablo / kart içeriğinin üstüne çıksın */
.fb-wrap:has(.fb-panel.open){
  z-index:80;
}

/* Üst satır: Arama + Pilleri + Temizle — mümkünse tek satır; sığmazsa satır kırılır */
.fb-head{
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:8px 10px;
  flex-wrap:wrap;
}

/* Arama kutusu — grid ile ikon / metin / temizle aynı hücrede; padding her zaman uygulanır */
.fb-search{
  display:grid !important;
  grid-template-columns:minmax(0,1fr);
  grid-template-areas:"main";
  align-items:stretch;
  flex:1 1 260px;
  min-width:min(100%,200px);
  max-width:420px;
}
.fb-search-ico{
  grid-area:main;
  justify-self:start;
  align-self:center;
  margin-left:12px;
  color:var(--tx4);pointer-events:none;
  display:flex;z-index:2;
}
.fb-search-ico svg{width:15px;height:15px;display:block}
.fb-search > input.fb-search-input,
.fb-search > input[type=text].fb-search-input{
  grid-area:main;
  width:100%;min-width:0;height:36px;
  box-sizing:border-box;
  padding:0 40px 0 40px !important;
  margin:0;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:var(--r2);
  color:var(--tx1);
  font-family:inherit;font-size:13.5px;
  line-height:36px;
  outline:none;transition:all var(--t);
  -webkit-appearance:none;
  appearance:none;
}
.fb-search > input.fb-search-input:focus,
.fb-search > input[type=text].fb-search-input:focus{
  border-color:var(--c-brand);
  background:var(--bg2);
  box-shadow:0 0 0 2px var(--c-brand-gl);
}
.fb-search > input.fb-search-input::placeholder,
.fb-search > input[type=text].fb-search-input::placeholder{color:var(--tx4)}
.fb-search-clear{
  grid-area:main;
  justify-self:end;
  align-self:center;
  margin-right:8px;
  width:20px;height:20px;border-radius:50%;
  display:flex !important;align-items:center;justify-content:center;
  background:var(--bg4);color:var(--tx3) !important;
  font-size:14px;line-height:1;font-weight:400;
  text-decoration:none !important;transition:all var(--t);
  z-index:2;
}
.fb-search-clear:hover{background:var(--c-err);color:#fff !important}

/* ── Pill Butonu (Dropdown trigger) ── */
.fb-pill{
  display:inline-flex !important;
  align-items:center;gap:7px;
  height:36px;padding:0 13px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:var(--r2);
  color:var(--tx1);font-family:inherit;
  font-size:13px;font-weight:500;
  cursor:pointer;white-space:nowrap;
  transition:all var(--t);
}
.fb-pill:hover{border-color:var(--c-brand);color:var(--c-brand)}
.fb-pill.open{
  border-color:var(--c-brand);
  background:var(--c-brand-bg);
  color:var(--c-brand);
  box-shadow:0 0 0 2px var(--c-brand-gl);
}
.fb-pill.has-value{border-color:rgba(0,176,155,.35)}
.fb-pill-lbl{
  font-size:11px;color:var(--tx4);font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
}
.fb-pill.has-value .fb-pill-lbl{color:var(--c-brand);opacity:.75}
.fb-pill.open .fb-pill-lbl{color:var(--c-brand)}
.fb-pill-val{font-weight:600;max-width:140px;overflow:hidden;text-overflow:ellipsis}
.fb-pill-caret{width:11px;height:11px;color:var(--tx4);transition:transform var(--t);flex-shrink:0}
.fb-pill:hover .fb-pill-caret,.fb-pill.open .fb-pill-caret{color:var(--c-brand)}
.fb-pill.open .fb-pill-caret{transform:rotate(180deg)}

/* Her pil + kendi paneli — panel pil hizasında, tam satır genişliği değil */
.fb-dd{
  position:relative;
  display:inline-flex;
  flex-direction:column;
  align-items:stretch;
  max-width:100%;
  flex:0 0 auto;
}
.fb-dd .fb-pill{align-self:stretch}

/* Tarih pili + özel tarih: kompakt tek satır (pil | küçük tarih | tarih | Uygula) */
.fb-date-group{
  display:flex;
  flex-direction:row;
  align-items:center;
  flex-wrap:nowrap;
  gap:8px;
  flex:0 1 auto;
  min-width:0;
}
.fb-custom-inline{
  display:flex;
  flex-direction:row;
  align-items:center;
  flex:0 0 auto;
  min-width:0;
}
.fb-custom-inline-form{
  margin:0;
  display:flex;
  align-items:center;
}
.fb-custom-inline-form .fb-custom-row{
  padding:0;
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:center;
  gap:6px;
}

/* ── Temizle ── */
.fb-reset{
  display:inline-flex !important;align-items:center;gap:6px;
  height:36px;padding:0 12px;
  border-radius:var(--r2);
  font-size:12.5px;font-weight:600;
  color:var(--c-err-txt) !important;
  border:1px solid rgba(244,63,94,.3);
  background:var(--c-err-bg);
  text-decoration:none !important;
  transition:all var(--t);
  margin-left:auto;white-space:nowrap;
  flex-shrink:0;
}
.fb-reset svg{width:12px;height:12px}
.fb-reset:hover{background:var(--c-err);color:#fff !important;border-color:var(--c-err)}

/* ── Panel (pil altında, en az pil kadar geniş) ── */
.fb-panel{
  display:none;
  position:absolute;
  left:0;
  top:calc(100% + 6px);
  z-index:100;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:8px;
  box-shadow:var(--sh2);
  animation:slideDown .15s ease;
  min-width:100%;
  width:max-content;
  max-width:min(320px,calc(100vw - 28px));
}
.fb-panel.open{display:block}
.fb-panel-title{
  font-size:10px;font-weight:700;
  color:var(--tx4);text-transform:uppercase;letter-spacing:.08em;
  padding:0 4px 5px;margin-bottom:4px;
  border-bottom:1px solid var(--border);
}
.fb-panel-list{
  display:flex;flex-direction:column;gap:1px;
  /* Tarih ön ayarları (~12 satır) kaydırmasız görünsün; çok uzun listelerde (hekim) sınırla */
  max-height:min(85vh,720px);
  overflow-y:auto;
  overflow-x:hidden;
  padding-right:2px;
}
.fb-panel-list::-webkit-scrollbar{width:4px}
.fb-panel-list::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:99px}

/* Seçenek satırı — daha sıkı; liste kısalsa bile daha çok satır sığar */
.fb-opt{
  display:flex !important;align-items:center;gap:8px;
  padding:5px 9px;border-radius:var(--r3);
  color:var(--tx2) !important;
  font-size:12px;font-weight:500;
  line-height:1.25;
  text-decoration:none !important;
  transition:all var(--t);cursor:pointer;
}
.fb-opt:hover{background:var(--bg2);color:var(--tx1) !important}
.fb-opt.active{
  background:var(--c-brand-bg);
  color:var(--c-brand) !important;font-weight:600;
}
.fb-check{
  width:14px;font-size:11px;color:var(--c-brand);
  flex-shrink:0;text-align:center;
}
.fb-opt-lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}
.fb-opt-count{
  background:var(--bg4);color:var(--tx4);
  padding:0 6px;border-radius:999px;
  font-size:10px;font-weight:700;min-width:20px;text-align:center;
  flex-shrink:0;
}
.fb-opt.active .fb-opt-count{background:var(--c-brand);color:#fff}

.fb-custom-row{
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  align-items:center;
  gap:8px;
  padding:0 4px;
}
/* Özel tarih satırı — dar inputlar, tek çizgide */
.fb-custom-inline .fb-date{
  flex:0 0 auto;
  width:7.4rem;
  min-width:7rem;
  max-width:30vw;
  height:30px;
  padding:0 4px;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:var(--r3);
  color:var(--tx1);
  font-family:inherit;
  font-size:12px;
  outline:none;
  color-scheme:dark;
}
.fb-date{
  flex:0 0 auto;
  height:32px;padding:0 8px;
  min-width:0;
  background:var(--bg2);
  border:1px solid var(--border2);
  border-radius:var(--r3);
  color:var(--tx1);font-family:inherit;
  font-size:13px;outline:none;color-scheme:dark;
}
.fb-custom-inline .fb-date:focus{border-color:var(--c-brand)}
.fb-date:focus{border-color:var(--c-brand)}
.fb-arrow{color:var(--tx4);font-size:14px;flex-shrink:0}
.fb-custom-apply{
  flex-shrink:0;
  white-space:nowrap;
  height:30px !important;
  min-height:30px;
  padding:0 10px !important;
  font-size:12px !important;
  line-height:1;
}

/* ── Light mode ── */
body.light-mode .fb-wrap{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode .fb-search input.fb-search-input,
body.light-mode .fb-search input[type=text].fb-search-input{background:#f4f6fa;border-color:rgba(0,0,0,.1);color:#0f172a}
body.light-mode .fb-search input.fb-search-input:focus,
body.light-mode .fb-search input[type=text].fb-search-input:focus{background:#fff}
body.light-mode .fb-pill{background:#f4f6fa;border-color:rgba(0,0,0,.1);color:#0f172a}
body.light-mode .fb-pill:hover{border-color:var(--c-brand);color:var(--c-brand)}
body.light-mode .fb-pill.open{background:var(--c-brand-bg)}
body.light-mode .fb-panel{background:#f8f9fb;border-color:rgba(0,0,0,.08)}
body.light-mode .fb-opt:hover{background:#fff}
body.light-mode .fb-opt-count{background:#e5e8ed;color:#64748b}
body.light-mode .fb-date{background:#fff;border-color:rgba(0,0,0,.12);color:#0f172a;color-scheme:light}
body.light-mode .fb-custom-inline .fb-date{background:#fff;border-color:rgba(0,0,0,.12);color:#0f172a;color-scheme:light}
body.light-mode .fb-search-clear{background:#e5e8ed;color:#64748b !important}

/* ── Mobil ── */
@media(max-width:640px){
  .fb-wrap{padding:10px;border-radius:var(--r2)}
  .fb-head{gap:8px;align-items:stretch !important}
  .fb-search{flex:1 1 100%;min-width:0;max-width:100%;order:1}
  .fb-date-group{
    flex:1 1 100%;
    flex-direction:column;
    align-items:stretch;
    flex-wrap:nowrap;
    order:2;
  }
  .fb-date-group .fb-dd{flex:0 0 auto;min-width:0;width:100%}
  .fb-date-group .fb-dd .fb-pill{justify-content:space-between}
  .fb-custom-inline{width:100%;flex:0 0 auto}
  .fb-head > .fb-dd{order:2}
  .fb-dd{flex:1 1 auto;min-width:0}
  .fb-dd .fb-pill{justify-content:space-between}
  .fb-pill-val{max-width:none}
  .fb-panel{
    max-width:calc(100vw - 24px);
    left:0;
    right:auto;
  }
  .fb-custom-row{
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:4px;
  }
  .fb-reset{order:3;margin-left:0;align-self:flex-start}
}

/* Eski filtre CSS'leri kaldırıldı — sadece .fb-* sınıfları kullanılıyor */

/* ── Dashboard ─────────────────────────────────────────── */
.db-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:14px}
@media(max-width:1200px){.db-stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.db-stats{grid-template-columns:repeat(2,1fr)}}
.db-stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;gap:9px;transition:all var(--t)}
.db-stat::before{display:none}
.db-stat.ok{border-top:2px solid var(--c-ok)}
.db-stat.danger{border-top:2px solid var(--c-err)}
.db-stat:hover{border-color:var(--border2);transform:translateY(-1px)}
.db-stat-ico{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--c-brand-bg);color:var(--c-brand);flex-shrink:0}
.db-stat.ok .db-stat-ico{background:var(--c-ok-bg);color:var(--c-ok-txt)}
.db-stat.danger .db-stat-ico{background:var(--c-err-bg);color:var(--c-err-txt)}
.db-stat-ico svg{width:17px;height:17px;stroke-width:1.75}
.db-stat-body{flex:1}
.db-stat-val{font-size:22px;font-weight:800;color:var(--tx1);line-height:1}
.db-stat-lbl{font-size:10px;font-weight:700;color:var(--tx4);text-transform:uppercase;letter-spacing:.06em;margin-top:3px}
.db-stat-sub{font-size:10.5px;color:var(--tx4);margin-top:2px}
.db-stat-link{font-size:11px;font-weight:600;color:var(--c-brand);align-self:flex-end;opacity:.8;transition:opacity var(--t)}
.db-stat-link:hover{opacity:1;text-decoration:none}
.db-grid-7-3{display:grid;grid-template-columns:7fr 3fr;gap:12px}
.db-grid-6-4{display:grid;grid-template-columns:6fr 4fr;gap:12px}
@media(max-width:1000px){.db-grid-7-3,.db-grid-6-4{grid-template-columns:1fr}}
.top-urun-list{display:flex;flex-direction:column;gap:9px}
.top-urun-item{display:flex;align-items:center;gap:11px}
.top-urun-rank{width:20px;height:20px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--tx4);flex-shrink:0}
.top-urun-item:nth-child(1) .top-urun-rank{background:var(--c-brand);color:#fff;border:none}
.top-urun-item:nth-child(2) .top-urun-rank{background:var(--c-info);color:#fff;border:none}
.top-urun-item:nth-child(3) .top-urun-rank{background:var(--c-ok);color:#fff;border:none}
.top-urun-body{flex:1;min-width:0}
.top-urun-name{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:4px;font-size:12.5px}
.top-urun-bar{height:3px;background:var(--border);border-radius:99px;overflow:hidden}
.top-urun-fill{height:100%;border-radius:99px;background:var(--c-brand);transition:width .6s}
.top-urun-stats{text-align:right;flex-shrink:0;min-width:48px}
.top-urun-val{font-size:16px;font-weight:800;color:var(--tx1);line-height:1;margin-bottom:3px}
.hekim-item{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--border)}
.hekim-item:last-of-type{border-bottom:none}
.hekim-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--c-brand),var(--c-brand2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:11px}
.hekim-info{flex:1;min-width:0}
.hekim-name{font-size:13px;font-weight:600;color:var(--tx1)}
.hekim-meta{font-size:11.5px;color:var(--tx4);display:flex;gap:5px;align-items:center;margin-top:2px;flex-wrap:wrap}
.krit-item{display:flex;align-items:center;gap:9px;padding:7px 9px;background:var(--c-err-bg);border:1px solid rgba(244,63,94,.2);border-radius:var(--r2);margin-bottom:5px}
.krit-item:last-child{margin-bottom:0}
.krit-ico{font-size:15px;flex-shrink:0}
.islem-list{display:flex;flex-direction:column}
.islem-item{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--border)}
.islem-item:last-child{border-bottom:none}
.islem-date{font-size:10.5px;font-weight:700;color:var(--c-brand);background:var(--c-brand-bg);border-radius:4px;padding:3px 6px;flex-shrink:0;text-align:center;min-width:32px}
.islem-body{flex:1;min-width:0}
.islem-patient{font-size:13px;font-weight:600;color:var(--tx1)}
.islem-doctor{font-size:11.5px;color:var(--tx4);margin-top:2px}
.hareket-item{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--border)}
.hareket-item:last-child{border-bottom:none}

/* ── Procedure detail ───────────────────────────────────── */
.proc-view-shell{display:flex;flex-direction:column;gap:14px}
.proc-view-hero{
  position:relative;padding:22px;overflow:hidden;
  background:
    linear-gradient(180deg, rgba(0,176,155,.09) 0%, rgba(0,176,155,0) 44%),
    linear-gradient(135deg, rgba(255,255,255,.025), rgba(255,255,255,0)),
    var(--bg2);
  box-shadow:var(--sh1);
}
.proc-view-hero::before{
  content:'';position:absolute;left:0;right:0;top:0;height:4px;
  background:linear-gradient(90deg,var(--c-brand),#38bdf8 52%,#8b5cf6);
}
.proc-view-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.proc-view-patient{display:flex;align-items:center;gap:14px;min-width:0}
.proc-view-avatar{
  width:58px;height:58px;border-radius:16px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--c-brand),var(--c-brand2));
  color:#fff;font-size:20px;font-weight:800;letter-spacing:.03em;
  box-shadow:0 10px 24px var(--c-brand-gl);
}
.proc-view-title-wrap{min-width:0}
.proc-view-kicker{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--tx4)}
.proc-view-title{font-size:26px;font-weight:800;color:var(--tx1);line-height:1.04;margin-top:6px;letter-spacing:-.02em}
.proc-view-sub{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12.5px;color:var(--tx4);margin-top:8px}
.proc-view-sub a{color:var(--tx3);text-decoration:none}
.proc-view-sub a:hover{color:var(--c-brand)}
.proc-view-flags{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.proc-view-flags .badge{
  min-height:30px;padding:0 12px;font-size:11.5px;font-weight:700;
  border:1px solid rgba(255,255,255,.05);backdrop-filter:blur(8px);
}
.proc-view-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:16px}
.proc-view-stat{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);
  padding:12px;display:flex;align-items:flex-start;gap:10px;min-width:0;
  transition:transform var(--t),border-color var(--t),background var(--t),box-shadow var(--t);
}
.proc-view-stat:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 10px 22px rgba(0,0,0,.14)}
.proc-view-stat-icon{
  width:36px;height:36px;border-radius:11px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--c-brand-bg);color:var(--c-brand);font-size:18px;
}
.proc-view-stat.is-doctor .proc-view-stat-icon{background:rgba(139,92,246,.14);color:#a78bfa}
.proc-view-stat.is-date .proc-view-stat-icon{background:rgba(59,130,246,.14);color:#60a5fa}
.proc-view-stat.is-stock .proc-view-stat-icon{background:rgba(245,158,11,.14);color:#fbbf24}
.proc-view-stat.is-fail .proc-view-stat-icon{background:rgba(244,63,94,.14);color:#fb7185}
.proc-view-stat.is-ok .proc-view-stat-icon{background:rgba(34,197,94,.14);color:#4ade80}
.proc-view-stat-body{min-width:0}
.proc-view-stat-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--tx4)}
.proc-view-stat-value{font-size:14px;font-weight:700;color:var(--tx1);margin-top:4px;line-height:1.35}
.proc-view-note-box{
  margin-top:14px;padding:12px 14px;border:1px solid var(--border);
  border-radius:var(--r2);background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)), var(--bg3);
}
.proc-view-note-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--tx4);margin-bottom:6px}
.proc-view-note-text{font-size:13px;line-height:1.6;color:var(--tx2)}

.proc-add-to-proc{box-shadow:var(--sh1)}
.proc-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.proc-section-head h2{margin:0}
.proc-section-head p{margin:5px 0 0;font-size:12.5px;line-height:1.55;color:var(--tx4);max-width:760px}
.proc-section-mini{
  display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;
  background:var(--bg3);border:1px solid var(--border);font-size:12px;font-weight:700;color:var(--tx3)
}
.proc-add-grid{display:grid;grid-template-columns:minmax(0,2.1fr) 120px 160px minmax(0,1.6fr) auto;gap:10px;align-items:end}
.proc-add-field{min-width:0}
.proc-add-field label{display:block;margin-bottom:6px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--tx4)}
.proc-add-field--action{display:flex;justify-content:flex-end}
.proc-add-submit{min-width:112px;min-height:44px;justify-content:center}

.proc-used-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:2px}
.proc-used-toolbar h2{margin:0}
.proc-used-toolbar p{margin:4px 0 0;font-size:12.5px;color:var(--tx4)}
.proc-used-pills{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.proc-items-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.proc-item-card{
  position:relative;background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)), var(--bg2);
  border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all var(--t);box-shadow:var(--sh1)
}
.proc-item-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg, rgba(0,176,155,.95), rgba(56,189,248,.7));
}
.proc-item-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.proc-item-card.is-fail::before{background:linear-gradient(180deg,#f43f5e,#fb7185)}
.proc-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 14px}
.proc-item-index{
  width:38px;height:38px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);border:1px solid var(--border);color:var(--tx3);
  font-size:12px;font-weight:800;letter-spacing:.08em;
}
.proc-item-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:8px}
.proc-item-badges{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.proc-item-title{font-size:15px;font-weight:700;color:var(--tx1);line-height:1.4}
.proc-item-inline-note{
  display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;
  background:var(--bg3);border:1px solid var(--border);font-size:11.5px;color:var(--tx3)
}
.proc-item-meta-pills{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.proc-item-meta-pill{
  display:inline-flex;align-items:center;min-height:26px;padding:0 10px;border-radius:999px;
  background:rgba(255,255,255,.035);border:1px solid var(--border);
  font-size:11.5px;font-weight:600;color:var(--tx3)
}
.proc-item-side{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;flex-shrink:0}
.proc-item-qty{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:56px;min-height:40px;padding:0 12px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--border);
  font-size:22px;font-weight:800;color:var(--tx1);line-height:1;text-align:center
}

.fail-info-box{display:flex;align-items:flex-start;gap:11px;background:linear-gradient(180deg, rgba(244,63,94,.16), rgba(244,63,94,.1));border-top:1px solid rgba(244,63,94,.24);padding:12px 16px}
.fail-info-icon{font-size:18px;flex-shrink:0;line-height:1;margin-top:2px}
.fail-info-content{flex:1;min-width:0}
.fail-info-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.fail-info-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--c-err-txt)}
.fail-info-date{font-size:11.5px;color:var(--tx4)}
.fail-info-reason{font-size:14px;font-weight:700;color:var(--tx1);line-height:1.45}

.fail-define-row{border-top:1px solid var(--border);padding:12px 16px;background:rgba(255,255,255,.015)}
.fail-define-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.proc-item-action-copy{font-size:12.5px;color:var(--tx4);line-height:1.5}
.fail-trigger-btn{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--border2);border-radius:var(--r3);padding:6px 11px;font-size:12px;font-weight:700;color:var(--tx3);cursor:pointer;font-family:inherit;transition:all var(--t)}
.fail-trigger-btn svg{width:12px;height:12px}
.fail-trigger-btn:hover{border-color:var(--c-err);color:var(--c-err-txt);background:var(--c-err-bg)}
.fail-form-inline{margin-top:12px;animation:slideDown .15s ease}
.fail-form-inline form{display:grid;grid-template-columns:160px minmax(220px,1fr) auto auto;gap:10px;align-items:end}
.fail-form-inline label{display:block;font-size:12px;font-weight:700;color:var(--tx3);margin-bottom:4px}
.proc-view-empty{text-align:center;padding:24px}
.proc-view-empty h3{font-size:18px;font-weight:800;color:var(--tx1);margin-bottom:6px}
.proc-view-empty p{font-size:13px;color:var(--tx4)}

body.light-mode .proc-view-hero{
  background:
    linear-gradient(180deg, rgba(0,176,155,.08) 0%, rgba(0,176,155,0) 44%),
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(255,255,255,.78)),
    #fff;
}
body.light-mode .proc-view-flags .badge{border-color:rgba(0,0,0,.06)}
body.light-mode .proc-view-stat{background:#fff;border-color:rgba(0,0,0,.08)}
body.light-mode .proc-view-note-box{background:#f8fafc;border-color:rgba(0,0,0,.08)}
body.light-mode .proc-item-card{background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.96));border-color:rgba(0,0,0,.08)}
body.light-mode .proc-item-index,
body.light-mode .proc-item-inline-note,
body.light-mode .proc-item-meta-pill,
body.light-mode .proc-item-qty,
body.light-mode .fail-define-row,
body.light-mode .proc-section-mini{background:#f8fafc;border-color:rgba(0,0,0,.08)}
body.light-mode .fail-info-box{background:rgba(244,63,94,.09)}

@media(max-width:1200px){
  .proc-add-grid{grid-template-columns:minmax(0,1fr) 110px 150px minmax(0,1fr)}
  .proc-add-field--action{grid-column:1 / -1}
}
@media(max-width:900px){
  .proc-view-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proc-items-list{gap:8px}
  .proc-item-card{border-radius:12px}
  .proc-item-top{display:grid;grid-template-columns:38px minmax(0,1fr);align-items:flex-start}
  .proc-item-main{gap:6px}
  .proc-item-title{font-size:14px;line-height:1.32}
  .proc-item-inline-note{padding:2px 8px;font-size:10.5px}
  .proc-item-meta-pills{gap:5px}
  .proc-item-meta-pill{min-height:23px;padding:0 8px;font-size:10.5px}
  .proc-item-side{grid-column:2;justify-content:flex-start}
  .proc-item-side .badge{min-height:28px;padding:0 9px;font-size:10.5px}
  .proc-item-qty{min-width:46px;min-height:32px;padding:0 10px;font-size:16px;border-radius:10px}
  .proc-item-index{grid-row:1 / span 2}
  .proc-item-side{justify-content:flex-start}
  .fail-define-row{padding:10px 14px}
  .proc-item-action-copy{font-size:11.5px}
  .fail-trigger-btn{min-height:32px;padding:0 11px}
  .fail-form-inline{margin-top:10px}
  .fail-form-inline form{grid-template-columns:1fr 1fr auto auto}
  .fail-form-inline label{font-size:11.5px}
  .fail-info-box{padding:10px 14px}
  .fail-info-reason{font-size:13px}
}
@media(max-width:640px){
  .proc-view-hero{padding:16px}
  .proc-view-patient{align-items:flex-start}
  .proc-view-avatar{width:50px;height:50px;border-radius:14px;font-size:17px}
  .proc-view-title{font-size:20px}
  .proc-view-stat-grid{grid-template-columns:1fr}
  .proc-view-sub{gap:7px}
  .proc-add-grid{grid-template-columns:1fr 1fr}
  .proc-add-field--product,.proc-add-field--note,.proc-add-field--action{grid-column:1 / -1}
  .proc-add-field--action{justify-content:stretch}
  .proc-add-submit{width:100%}
  .proc-used-toolbar{gap:8px}
  .proc-used-toolbar h2{font-size:18px}
  .proc-used-toolbar p{font-size:11.5px}
  .proc-used-pills{gap:6px}
  .proc-used-pills .badge{min-height:26px;padding:0 9px;font-size:10.5px}
  .proc-item-top{display:grid;grid-template-columns:1fr;gap:8px;padding:10px 12px}
  .proc-item-index{display:none}
  .proc-item-main{gap:4px}
  .proc-item-badges .badge.b-blue{display:none}
  .proc-item-title{font-size:13.5px;line-height:1.28}
  .proc-item-meta-pills{display:none}
  .proc-item-side{
    grid-column:auto;
    display:grid;
    grid-template-columns:auto auto auto;
    justify-content:flex-start;
    gap:6px;
  }
  .proc-item-side .badge{min-height:26px;padding:0 8px;font-size:10px}
  .proc-item-qty{font-size:15px;min-height:28px;min-width:42px;padding:0 9px;border-radius:9px}
  .proc-item-side{grid-column:auto}
  .fail-info-box{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
    gap:8px;
    padding:9px 12px;
  }
  .fail-info-icon{display:none}
  .fail-info-top{margin-bottom:2px}
  .fail-info-label{font-size:9.5px}
  .fail-info-date{font-size:10px}
  .fail-info-reason{font-size:12.5px;line-height:1.35}
  .fail-info-box .btn.sm{width:auto;justify-content:center;align-self:center;min-height:30px;padding:0 10px}
  .fail-define-row{padding:8px 12px}
  .fail-define-top{flex-direction:row;align-items:center;justify-content:flex-end}
  .proc-item-action-copy{display:none}
  .fail-trigger-btn{
    min-height:30px;
    padding:0 11px;
    font-size:11px;
    background:var(--bg3);
  }
  .fail-form-inline{margin-top:8px}
  .fail-form-inline form{grid-template-columns:1fr}
  .fail-form-inline .btn{width:100%;justify-content:center}
}

/* ── Gender Picker ─────────────────────────────────────── */
.gender-picker{display:flex;gap:7px}
.gender-opt{flex:1;cursor:pointer}
.gender-opt input[type=radio]{display:none}
.gender-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:9px 5px;border:1.5px solid var(--border2);border-radius:var(--r2);background:var(--bg3);font-size:12.5px;font-weight:600;color:var(--tx3);transition:all var(--t);text-align:center;user-select:none}
.gender-btn:hover{border-color:var(--c-brand);color:var(--c-brand)}
.g-ico{font-size:17px;line-height:1}
.gender-opt.active-E .gender-btn{border-color:#3b82f6;background:rgba(59,130,246,.12);color:#60a5fa}
.gender-opt.active-K .gender-btn{border-color:#a855f7;background:rgba(168,85,247,.12);color:#c084fc}
.gender-opt.active-O .gender-btn{border-color:var(--tx4);background:var(--bg4);color:var(--tx3)}

/* ── Mobile patient cards ──────────────────────────────── */
.mobile-page-header{padding:12px 0 13px;border-bottom:1px solid var(--border);margin-bottom:13px}
.mobile-page-header h2{font-size:20px;font-weight:800;color:var(--tx1);letter-spacing:-.02em}
.mobile-page-header p{font-size:12.5px;color:var(--tx4);margin-top:3px}
.mobile-page-header .mob-actions{display:flex;gap:7px;margin-top:11px}
.mobile-page-header .mob-actions .btn{flex:1;height:40px;font-size:13.5px}
.mobile-page-header .mob-actions .btn-outline-dark{flex:1;height:40px;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--border2);border-radius:var(--r2);background:var(--bg3);color:var(--tx2);font-family:inherit;font-weight:600;cursor:pointer;text-decoration:none;transition:all var(--t)}
.mobile-page-header .mob-actions .btn-outline-dark:hover{border-color:var(--c-brand);color:var(--c-brand)}
.mob-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.mob-stat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:12px;display:flex;align-items:center;gap:10px}
.mob-stat-ico{width:34px;height:34px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px}
.mob-stat-val{font-size:19px;font-weight:800;color:var(--tx1);line-height:1}
.mob-stat-lbl{font-size:10px;font-weight:700;color:var(--tx4);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.mob-filter-strip{display:flex;gap:6px;align-items:center;margin-bottom:11px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.mob-filter-strip::-webkit-scrollbar{display:none}
.mob-filter-pill{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 11px;flex-shrink:0;background:var(--bg2);border:1px solid var(--border2);border-radius:999px;color:var(--tx2);font-size:12.5px;font-weight:500;white-space:nowrap;cursor:pointer}
.mob-filter-pill select,.mob-filter-pill input{background:transparent;border:none;outline:none;color:var(--tx1);font-size:12.5px;font-family:inherit;cursor:pointer;padding:0;appearance:none;-webkit-appearance:none}
.mob-filter-pill input{width:80px}
.mob-filter-pill input::placeholder{color:var(--tx4)}
.mob-card-list{display:flex;flex-direction:column;gap:7px}
.mob-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px;transition:border-color var(--t)}
.mob-card:hover{border-color:var(--border2)}
.mob-card-head{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.mob-avatar{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}
.mob-card-name{font-size:13.5px;font-weight:800;color:var(--tx1);text-transform:uppercase;letter-spacing:.01em}
.mob-card-sub{font-size:11.5px;color:var(--tx4);margin-top:2px}
.mob-card-rows{border-top:1px solid var(--border);padding-top:8px;display:flex;flex-direction:column;gap:5px}
.mob-card-row{display:flex;justify-content:space-between;align-items:center}
.mob-card-row-lbl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--tx4)}
.mob-card-row-val{font-size:12.5px;font-weight:600;color:var(--tx1)}
.mob-card-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}
.mob-icon-btn{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all var(--t);flex-shrink:0;text-decoration:none}
.mob-icon-btn svg{width:15px;height:15px;display:block}
.mob-icon-btn.view{background:var(--c-brand-bg);color:var(--c-brand)}
.mob-icon-btn.edit{background:rgba(139,92,246,.14);color:#a78bfa}
.mob-icon-btn.del{background:var(--c-err-bg);color:var(--c-err-txt)}
.mob-icon-btn.view:hover{background:rgba(0,176,155,.25)}
.mob-icon-btn.edit:hover{background:rgba(139,92,246,.25)}
.mob-icon-btn.del:hover{background:rgba(244,63,94,.25)}
.mob-fab{
  position:fixed;right:18px;bottom:92px;z-index:44;
  width:52px;height:52px;padding:0;border-radius:18px;
  background:linear-gradient(135deg,var(--c-brand),var(--c-brand2));
  color:#fff !important;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.24);
  box-shadow:0 14px 30px rgba(0,176,155,.28),0 4px 12px rgba(15,23,42,.18),inset 0 1px 0 rgba(255,255,255,.22);
  transition:transform var(--t),box-shadow var(--t),filter var(--t);
  line-height:1;-webkit-tap-highlight-color:transparent;
}
.mob-fab:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 36px rgba(0,176,155,.34),0 6px 16px rgba(15,23,42,.2);text-decoration:none}
.mob-fab:active{transform:translateY(-1px) scale(.96);filter:brightness(.98)}
.mob-fab-ico{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mob-fab-ico svg{width:22px;height:22px;display:block;stroke-width:2.4}
.mob-fab-label{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
body.light-mode .mob-fab{box-shadow:0 14px 30px rgba(0,176,155,.22),0 4px 14px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.32)}

/* Hastalar — mobil özel (daha az dikey boşluk, tam genişlik arama) */
.patients-mob-filter-card{display:none;padding:12px 14px;margin-bottom:0}
.patients-mob-header{padding:8px 0 10px;margin-bottom:8px}
.patients-mob-h2{font-size:19px}
.patients-mob-filtre-notu{color:var(--c-err-txt);font-weight:600}
.patients-page .patients-mob-stats{
  display:flex;flex-direction:row;flex-wrap:nowrap;align-items:stretch;gap:5px;
  overflow:visible;
  margin-bottom:10px;padding:0;max-width:100%;
}
.patients-page .patients-mob-stats .mob-stat{
  flex:1 1 0;min-width:0;max-width:100%;
  padding:6px 3px;flex-direction:column;align-items:center;justify-content:flex-start;gap:3px;
  text-align:center
}
.patients-page .patients-mob-stats .mob-stat-txt{min-width:0;width:100%}
.patients-page .patients-mob-stats .mob-stat-ico{
  width:26px;height:26px;border-radius:7px;font-size:12px;flex-shrink:0
}
.patients-page .patients-mob-stats .mob-stat-val{
  font-size:15px;font-weight:800;line-height:1.05;letter-spacing:-.02em
}
.patients-page .patients-mob-stats .mob-stat-lbl{
  font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.03em;
  line-height:1.2;margin-top:0;word-break:break-word
}
@media (min-width:400px){
  .patients-page .patients-mob-stats{gap:7px}
  .patients-page .patients-mob-stats .mob-stat-val{font-size:16px}
  .patients-page .patients-mob-stats .mob-stat-lbl{font-size:8.5px}
}
.patients-mob-filter-form{display:flex;flex-direction:column;gap:10px}
.patients-mob-ffield label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tx4);margin:0 0 4px;display:block}
.patients-mob-input{width:100%;min-height:44px;font-size:16px;box-sizing:border-box;border-radius:var(--r2)}
.patients-mob-clear{width:100%;min-height:42px;justify-content:center}
.patients-mob-card-name{text-transform:none;letter-spacing:0 !important;font-size:14px}
.patients-mob-card .mob-card-sub{display:flex;flex-wrap:wrap;align-items:center;gap:5px;row-gap:4px}
.patients-mob-tel{display:inline-block;margin-top:5px;font-size:12.5px;font-weight:600;color:var(--c-brand) !important;text-decoration:none;word-break:break-all}
.patients-mob-tel:hover{text-decoration:underline}
.patients-mob-card-actions{justify-content:stretch;gap:6px;flex-wrap:wrap}
.patients-mob-act{flex:1;min-width:0;min-height:40px;justify-content:center}
.patients-mob-empty{text-align:center;padding:28px 16px 20px;color:var(--tx4)}
.patients-mob-empty-ico{font-size:38px;opacity:.45;margin-bottom:6px}
.patients-mob-empty-title{font-size:16px;font-weight:700;color:var(--tx2)}
.patients-mob-empty-hint{font-size:13px;margin:8px 0 14px;line-height:1.45}
.patients-mob-empty-btn{width:100%;min-height:44px;justify-content:center}
@media (max-width: 480px) {
  .patients-mob-card-actions{flex-direction:column}
  .patients-mob-act{flex:1 1 100% !important;max-width:100%;width:100%}
}
#patientForm.patients-modal-form input[type=text],#patientForm.patients-modal-form input[type=number]{min-height:44px;font-size:16px}
#patientForm.patients-modal-form .gender-btn{min-height:48px}
body.light-mode .patients-mob-filter-card{background:var(--bg2)}

/* Hasta ekle / düzenle modal — mobil bottom sheet + büyük dokunma alanı */
.patient-modal-backdrop.open{
  align-items:flex-end;justify-content:center;padding:0;
  padding-bottom:env(safe-area-inset-bottom,0);
}
@media (min-width:601px){
  .patient-modal-backdrop.open{
    align-items:flex-start;padding:38px 16px;
  }
}
.patient-modal.patient-modal{
  display:flex;flex-direction:column;width:100%;margin:0;overflow:hidden
}
@media (max-width:600px){
  .patient-modal.patient-modal{
    max-height:min(92dvh,calc(100vh - 8px));
    width:100%;max-width:100%;
    border-radius:var(--r) var(--r) 0 0
  }
}
.patient-modal-form{
  display:flex;flex-direction:column;flex:1;min-height:0;max-height:100%
}
.patient-modal-head{flex-shrink:0}
.patient-modal-close{
  min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--r2)
}
.patient-modal-body{
  flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;
  max-height:none !important;padding:16px 18px 8px
}
.patient-modal-field{margin-bottom:18px}
.patient-modal-field:last-of-type{margin-bottom:6px}
.patient-modal-field label,
.patient-modal-label{
  display:block;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--tx4);margin:0 0 7px 2px
}
.patient-modal-field input[type=text],
.patient-modal-field input[type=number]{
  width:100%;box-sizing:border-box;min-height:48px;font-size:16px;padding:0 14px;border-radius:var(--r2)
}
.patient-modal-hint{font-size:12px;color:var(--tx4);margin:7px 0 0;line-height:1.45}
.patient-gender-picker{display:flex;gap:8px;margin-top:2px}
.patient-gender-picker .gender-opt{flex:1;min-width:0}
.patient-gender-picker .gender-btn{
  min-height:54px;padding:10px 4px;border-width:2px;border-radius:var(--r2)
}
.patient-gender-picker .g-ico{font-size:20px;line-height:1}
.patient-modal-foot{
  flex-shrink:0;padding:12px 16px calc(14px + env(safe-area-inset-bottom));
  gap:10px;border-top:1px solid var(--border);background:var(--bg)
}
@media (max-width:640px){
  .patient-modal-backdrop .patient-modal-foot{
    flex-direction:column !important;width:100%
  }
  .patient-modal-backdrop .patient-modal-foot .btn{
    width:100% !important;min-height:48px;justify-content:center
  }
}
@media (min-width:601px){
  .patient-modal{max-width:440px;max-height:none}
  .patient-modal-form{max-height:none}
  .patient-modal-body{max-height:calc(100vh - 200px) !important;overflow-y:auto}
  .patient-modal-foot{flex-direction:row;justify-content:flex-end;align-items:center}
}
.patient-gender-picker .gender-opt.active-E .gender-btn{
  border-color:#3b82f6;background:rgba(59,130,246,.14);color:#60a5fa
}
.patient-gender-picker .gender-opt.active-K .gender-btn{
  border-color:#a855f7;background:rgba(168,85,247,.14);color:#c084fc
}
.patient-gender-picker .gender-opt.active-O .gender-btn{
  border-color:var(--tx4);background:var(--bg4);color:var(--tx2)
}
body.light-mode .patient-gender-picker .gender-btn{background:var(--bg3)}

/* ── Bottom Nav ────────────────────────────────────────── */
.bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;background:rgba(20,30,45,.97);backdrop-filter:blur(12px);border-top:1px solid var(--border);z-index:45;padding:7px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around;align-items:flex-end}
.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 4px;color:var(--tx4);font-size:9.5px;font-weight:600;text-decoration:none !important;transition:color var(--t);min-width:0}
.bottom-nav a svg{width:21px;height:21px;display:block;stroke-width:1.75}
.bottom-nav a .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.bottom-nav a.active,.bottom-nav a:hover{color:var(--c-brand)}
.bottom-nav a.fab{flex:0 0 50px;width:50px;height:50px;border-radius:50%;background:var(--c-brand);color:#fff !important;box-shadow:0 6px 18px var(--c-brand-gl),0 0 0 3px var(--bg);margin-top:-18px;padding:0;justify-content:center;gap:0}
.bottom-nav a.fab svg{width:22px;height:22px}
.bottom-nav a.fab:hover{transform:scale(1.05)}

/* ── Responsive ────────────────────────────────────────── */
@media(max-width:1000px){
  .side-layout{grid-template-columns:1fr}
  /* Ürünler: mobilde filtre paneli sticky + uzun listeler = liste görünmez; scroll ile birlikte yukarı kayar, chip'ler yatay */
  .side-layout .side-filter{
    position:static;
    top:auto;
    z-index:auto;
    max-height:none;
    padding:12px;
    margin-bottom:10px;
  }
  .side-layout .side-filter .chip-list{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:stretch;
    gap:6px;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    padding:2px 0 8px;
    margin-bottom:8px;
    scrollbar-width:thin;
  }
  .side-layout .side-filter .chip-list::-webkit-scrollbar{height:3px}
  .side-layout .side-filter .chip-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
  .side-layout .side-filter .chip{
    flex:0 0 auto;
    min-width:90px;
    max-width:min(210px,46vw);
    scroll-snap-align:start;
  }
  .side-layout .side-filter .chip > span:first-of-type{
    display:block;
    min-width:0;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .side-layout .side-filter .chip br{display:none !important}
  .side-layout .side-filter .chip small{display:none !important}
  .side-filter .search-box input{min-height:44px;font-size:16px}
  .side-filter h3{margin-bottom:5px}
  .side-filter .search-box .btn,
  .side-filter > .btn[href]{min-height:44px}
}

@media(max-width:900px){
  html,body{max-width:100%;overflow-x:hidden}
  :root{--sb-w:250px}
  .sidebar{position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);transition:transform var(--t);box-shadow:var(--sh3)}
  .sidebar.open{transform:translateX(0)}
  .menu-toggle{display:inline-flex}
  .bottom-nav{display:flex}
  .main-body{padding:13px 12px 96px}
  .top{padding:0 12px}
  .top h1{font-size:15px}
  .card{padding:14px}
  .mob-card-list{display:flex}
  .mobile-page-header,.mob-stats,.mob-filter-strip,.mob-fab{display:block}
  .mob-stats{display:grid}
  .mob-filter-strip{display:flex}
  #mainPatientCard{display:none !important}

  /* iOS focus zoom ve yatay taşmayı engelle */
  .product-search-wrap{max-width:100%;overflow:visible}
  .product-select-search{font-size:16px}
  .product-search-option{font-size:14px}
}
@media(min-width:901px){.mob-card-list,.mobile-page-header,.mob-stats,.mob-filter-strip,.mob-fab{display:none !important}}

@media(max-width:640px){
  .filter-bar{flex-direction:column;align-items:stretch}
  .form-row{grid-template-columns:1fr}
  .modal-foot{flex-direction:column-reverse}
  .modal-foot .btn{width:100%}
  .modal-body{padding:14px;max-height:calc(100vh - 200px)}
  .db-stats{grid-template-columns:1fr 1fr}
  .table-wrap{overflow:visible;border:none;border-radius:0;background:transparent}
  table thead{display:none}
  table,tbody,tr,td{display:block;width:100%}
  tbody tr{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);margin-bottom:8px;padding:9px 12px}
  tbody tr:hover td{background:transparent}
  td{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding:7px 0;font-size:13px;text-align:right;gap:9px}
  td:last-child{border-bottom:none}
  td::before{content:attr(data-label);font-weight:700;color:var(--tx4);text-transform:uppercase;font-size:10px;letter-spacing:.05em;text-align:left;flex-shrink:0}
  td.row-actions{justify-content:flex-end;flex-wrap:wrap}
  td.row-actions::before{display:none}
}

/* ── Print ─────────────────────────────────────────────── */
@media print{
  .sidebar,.top,.btn,.menu-toggle,.sidebar-overlay,.modal-backdrop,.bottom-nav{display:none !important}
  .content{width:100% !important}
  body,.main-body,.content,.card,.table-wrap{background:#fff !important;color:#000 !important}
  .card{box-shadow:none;border:1px solid #ddd}
  th{color:#333 !important}
  td{color:#000 !important}
}
