@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ============================================================
   Stok Takip — Premium Light theme (Emerald accent)
   ============================================================ */
:root{
  /* Accent (zümrüt) */
  --accent:#10b981; --accent-d:#059669; --accent-2:#34d399;
  --accent-grad:linear-gradient(135deg,#10b981 0%,#059669 100%);
  --accent-soft:#d1fae5; --accent-softer:#ecfdf5;

  /* Yüzeyler */
  --bg:#f5f7f8; --surface:#ffffff; --surface-2:#f4f6f8;
  --sidebar:#0e1320; --sidebar-2:#171d2e;

  /* Metin */
  --text:#0f1320; --text-2:#586173; --muted:#9aa3b2;

  /* Çizgi & durum */
  --line:#edeff3; --line-2:#e3e7ed;
  --ok:#059669; --warn:#d97706; --danger:#e11d48; --info:#0ea5e9;

  /* Şekil */
  --radius:18px; --radius-sm:12px; --radius-xs:9px;
  --shadow-sm:0 1px 2px rgba(15,19,32,.05), 0 1px 3px rgba(15,19,32,.05);
  --shadow:0 6px 24px rgba(15,19,32,.06);
  --shadow-lg:0 20px 48px rgba(15,19,32,.14);
  --ring:0 0 0 4px rgba(16,185,129,.16);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}
a{text-decoration:none;color:var(--accent-d)}
::selection{background:var(--accent-soft);color:var(--accent-d)}

/* ---------- İskelet ---------- */
.app{display:flex;min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  width:256px;background:var(--sidebar);color:#aeb6c5;
  display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:40;
  border-right:1px solid rgba(255,255,255,.04);
}
.brand{
  display:flex;align-items:center;gap:.7rem;padding:1.35rem 1.25rem 1.15rem;
  font-size:1.18rem;font-weight:800;color:#fff;letter-spacing:-.02em;
}
.brand i{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:11px;background:var(--accent-grad);
  color:#fff;font-size:1.2rem;box-shadow:0 6px 16px rgba(16,185,129,.4);
}
.menu{display:flex;flex-direction:column;padding:.75rem .7rem;gap:.2rem;flex:1}
.menu a{
  display:flex;align-items:center;gap:.8rem;padding:.72rem .85rem;
  border-radius:12px;color:#aeb6c5;font-weight:600;font-size:.93rem;
  transition:all .18s ease;position:relative;
}
.menu a i{font-size:1.18rem;width:1.35rem;text-align:center;transition:.18s}
.menu a:hover{background:rgba(255,255,255,.05);color:#fff}
.menu a:hover i{color:var(--accent-2)}
.menu a.active{background:var(--accent-grad);color:#fff;box-shadow:0 8px 20px rgba(16,185,129,.35)}
.menu a .nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:.7rem;font-weight:800;
  min-width:1.25rem;height:1.25rem;border-radius:1rem;display:inline-flex;align-items:center;justify-content:center;padding:0 .35rem}
.menu a.active .nav-badge{background:rgba(255,255,255,.25)}
.menu a.active i{color:#fff}
.sidebar-foot{padding:.75rem .7rem 1rem;border-top:1px solid rgba(255,255,255,.06)}
.logout{display:flex;align-items:center;gap:.8rem;padding:.72rem .85rem;
  border-radius:12px;color:#f2a3b3;font-weight:600;transition:.18s}
.logout i{font-size:1.15rem;width:1.35rem;text-align:center}
.logout:hover{background:rgba(225,29,72,.14);color:#ffb3c1}

/* ---------- İçerik ---------- */
.content{flex:1;margin-left:256px;min-width:0}
.topbar{
  display:flex;align-items:center;gap:1rem;
  background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(12px);
  padding:1rem 1.75rem;border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:30;
}
.topbar h1{font-size:1.3rem;margin:0;flex:1;font-weight:800;letter-spacing:-.025em}
.menu-toggle{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--text)}
.user-chip{
  display:flex;align-items:center;gap:.55rem;background:var(--surface);
  border:1px solid var(--line-2);padding:.45rem .85rem;border-radius:2rem;
  font-weight:700;font-size:.88rem;color:var(--text);box-shadow:var(--shadow-sm);
}
.user-chip i{font-size:1.3rem;color:var(--accent-d)}
.page{padding:1.75rem}

/* ---------- İstatistik kartları ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1.1rem;margin-bottom:1.75rem}
.stat{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem 1.4rem;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease;
}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.stat .label{color:var(--muted);font-size:.74rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em}
.stat .value{font-size:2rem;font-weight:800;margin-top:.4rem;letter-spacing:-.03em;line-height:1}
.stat .ic{
  position:absolute;right:1.15rem;top:1.15rem;width:44px;height:44px;
  border-radius:13px;display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;opacity:1;background:var(--accent-softer);color:var(--accent-d);
}
.stat.indigo .ic{background:var(--accent-softer);color:var(--accent-d)}
.stat.green  .ic{background:#dcfce7;color:#059669}
.stat.red    .ic{background:#ffe4e6;color:#e11d48}
.stat.amber  .ic{background:#fef3c7;color:#d97706}
.stat::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px}
.stat.indigo::after{background:var(--accent-grad)}
.stat.green::after{background:linear-gradient(180deg,#34d399,#059669)}
.stat.red::after{background:linear-gradient(180deg,#fb7185,#e11d48)}
.stat.amber::after{background:linear-gradient(180deg,#fbbf24,#d97706)}

/* ---------- Kutular ---------- */
.box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.4rem 1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}
.box-head{display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.15rem;gap:.6rem;flex-wrap:wrap}
.box-head h2{font-size:1.08rem;margin:0;font-weight:800;letter-spacing:-.02em;
  display:flex;align-items:center;gap:.5rem}
.box-head h2 i{color:var(--accent-d)}

/* ---------- Tablolar ---------- */
.table{margin:0;color:var(--text)}
.table thead th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);border-bottom:1px solid var(--line-2);font-weight:700;padding-top:.4rem}
.table td{vertical-align:middle;border-color:var(--line)}
.table tbody tr{transition:background .15s}
.table-hover tbody tr:hover,.table tbody tr:hover{background:var(--surface-2)}

/* ---------- Ürün kartları ---------- */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:1.25rem}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s}
.pcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--line-2)}
.pcard .thumb{height:185px;background:var(--surface-2) center/contain no-repeat;
  border-bottom:1px solid var(--line);position:relative;display:block}
.pcard .thumb .noimg{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;color:#cdd3dd;font-size:2.6rem}
.pcard .body{padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.pcard .pname{font-weight:700;font-size:.96rem;line-height:1.34;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard .pname:hover{color:var(--accent-d)}
.pcard .meta{font-size:.8rem;color:var(--text-2)}
.pcard .price{font-size:1.4rem;font-weight:800;letter-spacing:-.03em}
.pcard .foot{display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1.1rem;border-top:1px solid var(--line);font-size:.78rem;color:var(--muted);
  background:var(--surface-2)}
.pcard .foot a,.pcard .foot .btn-link{color:var(--text-2)}
.pcard .foot a:hover,.pcard .foot .btn-link:hover{color:var(--accent-d)}
.pthumb-sm{width:46px;height:46px;border-radius:10px;object-fit:contain;
  background:var(--surface-2);border:1px solid var(--line)}

/* yapilacaklar listesi */
.todo-list{display:flex;flex-direction:column;gap:.5rem}
.todo-item{display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;border:1px solid var(--line);
  border-radius:var(--radius-sm);background:var(--surface);transition:background .2s,border-color .2s}
.todo-item .todo-check{position:relative;display:inline-flex;align-items:center;margin:0;cursor:pointer}
.todo-item .todo-cb{width:1.3rem;height:1.3rem;cursor:pointer;margin:0}
.todo-item .todo-tick{display:none}
.todo-item .todo-title{flex:1;font-weight:600;color:var(--text)}
.todo-item .todo-date{white-space:nowrap}
.todo-item .todo-del{opacity:.5;transition:.2s}
.todo-item:hover .todo-del{opacity:1}
.todo-item.done{background:var(--accent-softer);border-color:var(--accent-soft)}
.todo-item.done .todo-title{text-decoration:line-through;color:#047857}
.todo-item.done .todo-date{color:#059669 !important}

/* bildirim listesi */
.alert-list{display:flex;flex-direction:column}
.alert-row{display:flex;align-items:flex-start;gap:.85rem;padding:.85rem .25rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.alert-row:last-child{border-bottom:0}
.alert-row.is-new{background:var(--accent-softer);border-radius:10px;padding-left:.7rem;padding-right:.7rem}
.alert-row .alert-type{min-width:92px;justify-content:center;align-self:center}
.alert-meta{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-top:.45rem}
.alert-when{font-weight:800;color:var(--text);font-size:.84rem}
.alert-when i{color:var(--accent-d)}
.alert-exact{font-weight:700;font-size:.78rem;color:var(--text-2);background:var(--surface-2);
  border:1px solid var(--line-2);padding:.15rem .5rem;border-radius:7px}
.alert-sent{font-size:.74rem;font-weight:700;padding:.15rem .45rem;border-radius:7px}
.alert-sent.ok{background:var(--accent-soft);color:#047857}
.alert-sent.err{background:#ffe4e6;color:#9f1239}

/* toplu islem cubugu — yalniz secim varken gorunur, ustte yapisir */
.bulk-bar{align-items:center;gap:.6rem;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--accent);border-radius:var(--radius-sm);padding:.6rem .9rem;margin-bottom:1rem;
  box-shadow:var(--shadow);position:sticky;top:76px;z-index:20}
.bulk-cb{position:absolute;top:.6rem;left:.6rem;z-index:3;width:1.2rem;height:1.2rem;cursor:pointer;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2)}

/* grup karti rozeti */
.group-badge{position:absolute;top:.55rem;right:.55rem;background:rgba(15,19,32,.82);
  color:#fff;font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:2rem;
  display:inline-flex;align-items:center;gap:.25rem}

/* tedarikci karsilastirma satiri (grup detay) */
.cmp-row{display:flex;align-items:center;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.cmp-row:last-child{border-bottom:0}
.cmp-cheapest .cmp-price{color:var(--accent-d)}

/* ---------- Rozetler ---------- */
.pill{display:inline-flex;align-items:center;gap:.3rem;padding:.26rem .66rem;
  border-radius:2rem;font-size:.74rem;font-weight:700;line-height:1}
.pill-ok{background:var(--accent-soft);color:#047857}
.pill-warn{background:#fef3c7;color:#92400e}
.pill-danger{background:#ffe4e6;color:#9f1239}
.pill-muted{background:#eef1f5;color:#64748b}

/* ---------- Beden rozetleri ---------- */
.size-badges{display:flex;flex-wrap:wrap;gap:.4rem}
.size-badges .pill{min-width:2.6rem;justify-content:center;font-size:.82rem;padding:.34rem .5rem}
.size-badges .pill-ok{box-shadow:0 2px 6px rgba(16,185,129,.25)}
.size-badges .pill-muted{text-decoration:line-through;opacity:.55}

/* ---------- Mini grafik ---------- */
.spark{width:100%;height:130px}

/* ---------- Butonlar (Bootstrap override) ---------- */
.btn{border-radius:11px;font-weight:700;font-size:.9rem;padding:.55rem 1.05rem;
  transition:all .18s ease;letter-spacing:-.01em}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent-grad);border:0;box-shadow:0 8px 18px rgba(16,185,129,.32)}
.btn-primary:hover,.btn-primary:focus{background:var(--accent-grad);filter:brightness(1.05);
  box-shadow:0 10px 24px rgba(16,185,129,.42)}
.btn-lg{padding:.8rem 1.3rem;font-size:1rem;border-radius:13px}
.btn-sm{padding:.4rem .7rem;font-size:.82rem;border-radius:9px}
.btn-outline-primary{color:var(--accent-d);border:1.5px solid var(--accent);background:transparent}
.btn-outline-primary:hover{background:var(--accent-grad);border-color:transparent;color:#fff}
.btn-outline-secondary{color:var(--text-2);border:1.5px solid var(--line-2);background:var(--surface)}
.btn-outline-secondary:hover{background:var(--surface-2);color:var(--text);border-color:var(--muted)}
.btn-outline-danger{color:var(--danger);border:1.5px solid #fda4af}
.btn-outline-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-warning{background:#fbbf24;border:0;color:#3a2a06}
.btn-warning:hover{background:#f59e0b;color:#3a2a06}
.btn-light{background:var(--surface);border:1px solid var(--line-2);color:var(--text)}
.btn-link{text-decoration:none;color:var(--accent-d)}

/* ---------- Nav pills (Ürünler sekmeleri) ---------- */
.nav-pills{gap:.35rem;flex-wrap:wrap}
.nav-pills .nav-link{color:var(--text-2);font-weight:700;font-size:.88rem;border-radius:10px;
  padding:.5rem .9rem;background:var(--surface);border:1px solid var(--line)}
.nav-pills .nav-link:hover{background:var(--surface-2);color:var(--text)}
.nav-pills .nav-link.active{background:var(--accent-grad);color:#fff;border-color:transparent;
  box-shadow:0 8px 18px rgba(16,185,129,.3)}
.nav-pills .nav-link .badge{background:rgba(255,255,255,.25) !important;color:inherit !important}
.nav-pills .nav-link:not(.active) .badge{background:var(--surface-2) !important;color:var(--text-2) !important}

/* ---------- Formlar ---------- */
.form-label{font-weight:700;font-size:.86rem;color:var(--text);margin-bottom:.4rem}
.req{color:var(--danger)}
.form-hint{font-size:.79rem;color:var(--muted);margin-top:.3rem;line-height:1.45}
.form-control,.form-select{border-radius:11px;border:1.5px solid var(--line-2);
  padding:.6rem .85rem;font-size:.92rem;color:var(--text);background:var(--surface);transition:.16s}
.form-control::placeholder{color:#b6bdc9}
.form-control:focus,.form-select:focus{border-color:var(--accent);box-shadow:var(--ring);outline:0}
.form-control-lg{padding:.8rem 1rem;border-radius:12px}
/* input-group: ic ogeleri birlestir (genel border-radius override'ini iptal et) */
.input-group{flex-wrap:nowrap}
.input-group > .form-control,.input-group > .form-select,.input-group > .btn{border-radius:0;margin-left:-1px}
.input-group > :first-child{border-top-left-radius:10px;border-bottom-left-radius:10px;margin-left:0}
.input-group > :last-child{border-top-right-radius:10px;border-bottom-right-radius:10px}
.input-group > .form-control:focus,.input-group > .form-select:focus{position:relative;z-index:3}
.form-check-input{border-color:var(--line-2);width:1.05em;height:1.05em}
.form-check-input:checked{background-color:var(--accent);border-color:var(--accent)}
.form-check-input:focus{border-color:var(--accent);box-shadow:var(--ring)}
.form-switch .form-check-input{width:2.3em;height:1.2em}

/* ---------- Uyarılar ---------- */
.alert{border:0;border-radius:14px;padding:.9rem 1.15rem;font-weight:500;box-shadow:var(--shadow-sm)}
.alert-success{background:var(--accent-softer);color:#065f46}
.alert-warning{background:#fffbeb;color:#92400e}
.alert-danger{background:#fff1f3;color:#9f1239}
.alert-info,.alert-light{background:var(--surface-2);color:var(--text-2)}
.reminder-bar{border-left:4px solid var(--accent);border-radius:14px}

/* ---------- Liste grupları ---------- */
.list-group-item{border-color:var(--line);background:transparent;padding-top:.7rem;padding-bottom:.7rem}
.list-group-item-action:hover{background:var(--surface-2)}

/* ---------- Badge ---------- */
.badge{font-weight:700;border-radius:7px}

/* ---------- Pre / kod ---------- */
pre{background:var(--surface-2) !important;border:1px solid var(--line);border-radius:11px;
  color:var(--text-2);font-size:.82rem}
code{color:var(--accent-d);background:var(--accent-softer);padding:.1rem .35rem;border-radius:5px;font-size:.86em}

/* ---------- Giriş / Kurulum ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:1.5rem;position:relative;overflow:hidden;
  background:radial-gradient(1100px 600px at 12% -10%,#10b981 0%,transparent 55%),
             radial-gradient(900px 600px at 110% 120%,#0ea5e9 0%,transparent 50%),
             linear-gradient(135deg,#0e1320 0%,#13243a 100%)}
.login-wrap::before{content:"";position:absolute;inset:0;
  background:radial-gradient(700px 400px at 80% 10%,rgba(52,211,153,.18),transparent 60%)}
.login-box{position:relative;background:rgba(255,255,255,.97);border-radius:24px;padding:2.5rem 2.4rem;
  width:100%;max-width:430px;box-shadow:0 40px 90px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.6)}
.login-box .lhead{text-align:center;margin-bottom:1.75rem}
.login-box .lhead i{display:inline-flex;align-items:center;justify-content:center;
  width:64px;height:64px;border-radius:18px;background:var(--accent-grad);color:#fff;font-size:2rem;
  box-shadow:0 14px 30px rgba(16,185,129,.45);margin-bottom:.4rem}
.login-box h1{font-size:1.55rem;margin:.6rem 0 .3rem;font-weight:800;letter-spacing:-.03em}
.login-box p{color:var(--muted);margin:0;font-size:.92rem}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);transition:transform .26s ease;box-shadow:var(--shadow-lg)}
  body.sidebar-open .sidebar{transform:none}
  .content{margin-left:0}
  .menu-toggle{display:block}
  .page{padding:1.15rem}
  .topbar{padding:.85rem 1.15rem}
}

/* ---------- Mikro etkileşimler ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.stat,.pcard,.box{animation:fadeUp .5s cubic-bezier(.2,.7,.3,1) both}
.stats .stat:nth-child(2){animation-delay:.05s}
.stats .stat:nth-child(3){animation-delay:.1s}
.stats .stat:nth-child(4){animation-delay:.15s}
.product-grid .pcard:nth-child(3n+2){animation-delay:.05s}
.product-grid .pcard:nth-child(3n+3){animation-delay:.1s}

.btn-primary:hover,.btn-outline-primary:hover{transform:translateY(-1px)}

/* İndirim gösterimi */
.price-old{font-size:.85rem;color:var(--muted);text-decoration:line-through;font-weight:600;margin-left:.4rem}
.disc-badge{display:inline-flex;align-items:center;gap:.2rem;background:#ffe4e6;color:#9f1239;
  font-size:.72rem;font-weight:800;padding:.16rem .45rem;border-radius:7px;margin-left:.4rem}

/* Erişilebilir odak */
a:focus-visible,.btn:focus-visible,.menu a:focus-visible,.nav-link:focus-visible,
.form-check-input:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}

/* Hareket azaltma tercihi */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* ---------- İnce kaydırma çubuğu ---------- */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:#d3d9e2;border-radius:8px;border:2px solid var(--bg)}
*::-webkit-scrollbar-thumb:hover{background:#b9c1cd}
