/* =========================================================
   Görev Box — Reklam Veren Paneli
   Tasarım dili: e-ticaret/SaaS · top-nav + sidebar card + footer
   Referans: bayigram müşteri paneli yapısı
   ========================================================= */

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  /* Surfaces */
  --bg:           #F1F4F8;
  --bg-2:         #E8ECF1;
  --surface:      #FFFFFF;
  --surface-2:    #F7F9FC;
  --surface-3:    #EDF1F6;

  /* Borders */
  --border:       #E5E8ED;
  --border-soft:  #EDF0F4;
  --divider:      #F0F2F6;
  --hairline:     #E8ECF1;

  /* Text */
  --text:         #0F172A;
  --text-2:       #334155;
  --text-3:       #64748B;
  --text-muted:   #94A3B8;
  --text-light:   #B8C0CC;
  --text-on-dark: #E2E8F0;

  /* Brand — Mint/emerald green */
  --accent:        #10B981;
  --accent-dark:   #059669;
  --accent-darker: #047857;
  --accent-soft:   #D1FAE5;
  --accent-tint:   rgba(16,185,129,0.10);

  /* Semantic */
  --success:       #10B981;
  --success-soft:  #D1FAE5;
  --warn:          #F59E0B;
  --warn-soft:     #FEF3C7;
  --danger:        #EF4444;
  --danger-soft:   #FEE2E2;
  --info:          #3B82F6;
  --info-soft:     #DBEAFE;

  /* Footer */
  --footer-bg:     #1B2436;
  --footer-bg-2:   #232D42;
  --footer-text:   #94A3B8;
  --footer-heading:#E2E8F0;

  /* Spacing */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px;  --s-4: 16px;
  --s-5: 20px; --s-6: 24px; --s-7: 32px;  --s-8: 40px;
  --s-9: 48px; --s-10:64px; --s-11:80px;

  /* Radius */
  --r-sm: 6px;  --r-md: 10px; --r-lg: 14px;
  --r-xl: 18px; --r-pill:999px;

  /* Shadow — subtle */
  --sh-1: 0 1px 2px rgba(15,23,42,0.04);
  --sh-2: 0 2px 6px rgba(15,23,42,0.05);
  --sh-3: 0 8px 20px rgba(15,23,42,0.07);
  --sh-glow: 0 0 0 3px rgba(16,185,129,0.18);

  /* Z-index */
  --z-nav:50; --z-drawer:80; --z-modal:100; --z-toast:999;

  /* Layout */
  --nav-h:       64px;
  --sidebar-w:   240px;
  --content-px:  24px;
  --content-py:  24px;
  --max-w:       1280px;

  /* Transition */
  --t-1: 140ms cubic-bezier(.4,0,.2,1);
  --t-2: 220ms cubic-bezier(.4,0,.2,1);
  --t-3: 320ms cubic-bezier(.4,0,.2,1);
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html,body { -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body {
  font-family:'Inter', system-ui, -apple-system, "SF Pro Text", sans-serif;
  background:var(--bg); color:var(--text);
  font-size:13.5px; line-height:1.5;
  letter-spacing:-0.005em;
  min-height:100vh;
  display:flex; flex-direction:column;
}
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
input,select,textarea { font:inherit; color:inherit; }
img { display:block; max-width:100%; }
::selection { background:var(--accent-soft); color:var(--accent-darker); }
.mono { font-family:'JetBrains Mono', ui-monospace, monospace;
        font-feature-settings:'zero','tnum'; }

/* ─── PROMO BAR (üst yeşilimsi bant) ─────────────────────── */
.promo-bar {
  background:linear-gradient(90deg, #FDF2D8 0%, #FCE7E7 50%, #DFF5E2 100%);
  border-bottom:1px solid var(--hairline);
  padding:10px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  font-size:12px;
  flex-wrap:wrap;
}
.promo-bar-inner {
  max-width:var(--max-w); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  width:100%;
}
.promo-left { display:flex; align-items:center; gap:8px; flex:1; min-width:0; }
.promo-left .gift { font-size:18px; flex-shrink:0; }
.promo-left a { color:var(--accent-darker); font-weight:700; }
.promo-pct {
  display:inline-block; padding:1px 8px; border-radius:var(--r-pill);
  background:var(--accent); color:#fff; font-weight:700; font-size:11px;
  margin:0 4px;
}
.promo-right { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.promo-ticker {
  display:flex; align-items:center; gap:8px;
  padding:5px 12px;
  background:var(--surface); border-radius:var(--r-pill);
  font-size:11.5px;
  border:1px solid var(--border);
}
.promo-ticker .live-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent); position:relative;
  animation:livepulse 1.5s ease-in-out infinite;
}
@keyframes livepulse {
  0%,100% { box-shadow:0 0 0 0 rgba(16,185,129,0.5); }
  50%     { box-shadow:0 0 0 6px rgba(16,185,129,0); }
}
.promo-ticker .ticker-num { color:var(--accent-darker); font-weight:700; }
.promo-ticker .ticker-msg { color:var(--text-2); font-weight:500; }
.promo-ticker .ticker-time { color:var(--text-muted); font-size:11px; }
.promo-ticker .ticker-time::before { content:''; display:inline-block; width:2px; height:2px;
                                     border-radius:50%; background:var(--text-light);
                                     vertical-align:middle; margin-right:6px; margin-bottom:1.5px; }

.dark-toggle {
  display:flex; align-items:center; gap:6px;
  font-size:12px; color:var(--text-2);
  padding:5px 10px; border-radius:var(--r-pill);
  transition:background var(--t-1);
}
.dark-toggle:hover { background:rgba(0,0,0,0.06); }
.dark-toggle i { font-size:13px; }

@media (max-width: 760px) {
  .promo-right { display:none; }
}

/* ─── TOP NAV ────────────────────────────────────────────── */
.topnav {
  position:sticky; top:0; z-index:var(--z-nav);
  background:var(--surface);
  border-bottom:1px solid var(--hairline);
  height:var(--nav-h);
  display:flex; align-items:center;
}
.topnav-inner {
  max-width:var(--max-w); margin:0 auto;
  width:100%;
  padding:0 var(--content-px);
  display:flex; align-items:center; gap:24px;
}
.tn-brand {
  display:flex; align-items:center; gap:10px;
  flex-shrink:0;
}
.tn-mark {
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  color:#fff; display:grid; place-items:center;
  font-size:16px;
  box-shadow:0 4px 12px rgba(16,185,129,0.30);
}
.tn-brand-name { font-size:15px; font-weight:700; letter-spacing:-.3px; }
.tn-brand-sub  { font-size:10.5px; color:var(--text-muted); font-weight:500;
                 letter-spacing:.3px; line-height:1; margin-top:1px; }

.tn-search {
  flex:1; max-width:480px; position:relative;
}
.tn-search input {
  width:100%;
  padding:9px 14px 9px 36px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  font-size:13px; color:var(--text);
  outline:0;
  transition:border-color var(--t-1), background var(--t-1);
}
.tn-search input::placeholder { color:var(--text-muted); }
.tn-search input:focus {
  background:var(--surface); border-color:var(--accent);
  box-shadow:var(--sh-glow);
}
.tn-search i {
  position:absolute; top:50%; left:14px; transform:translateY(-50%);
  color:var(--text-muted); font-size:14px; pointer-events:none;
}

/* Arama sonuçları dropdown'ı */
.search-dropdown {
  position:absolute;
  top:calc(100% + 6px); left:0; right:0;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  box-shadow:var(--sh-3);
  max-height:420px; overflow-y:auto;
  display:none;
  z-index:calc(var(--z-nav) + 5);
}
.search-dropdown.is-open { display:block; }
.search-state {
  padding:14px 16px;
  font-size:12.5px; color:var(--text-muted);
  text-align:center;
}
.search-state.loading::before {
  content:''; display:inline-block; width:12px; height:12px;
  border:2px solid var(--border); border-top-color:var(--accent);
  border-radius:50%; animation:sp 0.7s linear infinite;
  vertical-align:middle; margin-right:6px;
}
@keyframes sp { to { transform:rotate(360deg); } }

.search-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px;
  border-top:1px solid var(--hairline);
  color:var(--text);
  transition:background var(--t-1);
}
.search-item:first-child { border-top:0; }
.search-item:hover,
.search-item.is-active { background:var(--accent-soft); }
.search-item-icon {
  width:30px; height:30px; border-radius:8px;
  background:var(--surface-2); display:grid; place-items:center;
  font-size:14px; flex-shrink:0;
}
.search-item-body { flex:1; min-width:0; }
.search-item-title { font-size:13px; font-weight:600; }
.search-item-meta  { font-size:11px; color:var(--text-muted); margin-top:2px; }
.search-item-arrow { color:var(--text-muted); font-size:11px; }
.search-item:hover .search-item-arrow,
.search-item.is-active .search-item-arrow { color:var(--accent); }

.tn-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; margin-left:auto; }
.tn-icon {
  width:36px; height:36px; border-radius:50%;
  background:var(--surface-2); color:var(--text-2);
  display:grid; place-items:center; position:relative;
  border:1px solid var(--border);
  transition:background var(--t-1), border-color var(--t-1);
}
.tn-icon:hover { background:var(--surface); border-color:var(--text-muted); color:var(--text); }
.tn-icon i { font-size:15px; }
.tn-icon .pill {
  position:absolute; top:-4px; right:-4px;
  background:var(--danger); color:#fff;
  font-size:10px; font-weight:700;
  min-width:18px; height:18px; padding:0 5px;
  border-radius:9px;
  display:grid; place-items:center;
  border:2px solid var(--surface);
}
.tn-icon.--cart .pill { background:var(--accent); }

.tn-user {
  display:flex; align-items:center; gap:10px;
  padding:6px 14px 6px 6px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  transition:background var(--t-1), border-color var(--t-1);
}
.tn-user:hover { background:var(--surface); border-color:var(--text-muted); }
.tn-user-av {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  color:#fff; display:grid; place-items:center;
  font-size:12px; font-weight:700;
}
.tn-user-name { font-size:12.5px; font-weight:600; line-height:1.2; }
.tn-user-bal  { font-size:10.5px; color:var(--text-muted); margin-top:1px; }

.tn-burger {
  display:none;
  width:36px; height:36px; border-radius:10px;
  background:var(--surface-2); border:1px solid var(--border);
  color:var(--text);
}

/* ─── SUB NAV (kategori menüsü) ──────────────────────────── */
.subnav {
  background:var(--surface);
  border-bottom:1px solid var(--hairline);
  padding:0 var(--content-px);
}
.subnav-inner {
  max-width:var(--max-w); margin:0 auto;
  width:100%;
  display:flex; align-items:center; gap:6px;
  overflow-x:auto; -ms-overflow-style:none; scrollbar-width:none;
}
.subnav-inner::-webkit-scrollbar { display:none; }
.subnav-item {
  display:flex; align-items:center; gap:7px;
  padding:14px 14px; white-space:nowrap;
  font-size:12.5px; font-weight:600; color:var(--text-2);
  border-bottom:2px solid transparent;
  transition:color var(--t-1), border-color var(--t-1);
  position:relative;
}
.subnav-item i { color:var(--text-muted); font-size:13px; }
.subnav-item:hover { color:var(--accent-dark); }
.subnav-item:hover i { color:var(--accent); }
.subnav-item .yeni {
  position:absolute; top:6px; right:0;
  background:var(--accent); color:#fff;
  font-size:9px; font-weight:700;
  padding:1px 6px; border-radius:6px;
}
.subnav-item .chev { font-size:9px; opacity:.6; }

/* ─── LAYOUT ─────────────────────────────────────────────── */
.app-wrap {
  flex:1;
  max-width:var(--max-w); margin:0 auto;
  width:100%;
  padding:24px var(--content-px);
  display:grid;
  grid-template-columns:var(--sidebar-w) 1fr;
  gap:20px;
  align-items:start;
}

/* ─── SIDEBAR CARD ───────────────────────────────────────── */
.sidebar {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:20px;
  position:sticky; top:calc(var(--nav-h) + 24px);
  box-shadow:var(--sh-1);
}

.sb-user {
  text-align:center; padding-bottom:18px;
  border-bottom:1px solid var(--hairline);
  margin-bottom:18px;
  position:relative;
}
.sb-user-badge {
  display:inline-block; padding:3px 10px;
  background:var(--accent-soft); color:var(--accent-darker);
  font-size:9.5px; font-weight:700; letter-spacing:.5px;
  border-radius:var(--r-pill); text-transform:uppercase;
  margin-bottom:10px;
}
.sb-user-av {
  width:54px; height:54px; border-radius:14px;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  color:#fff; display:grid; place-items:center;
  font-size:20px; font-weight:700;
  margin:0 auto 10px;
  box-shadow:0 4px 12px rgba(16,185,129,0.25);
}
.sb-user-name { font-size:13.5px; font-weight:700; }
.sb-user-bal  { font-size:12px; color:var(--text-3); margin-top:2px;
                font-family:'JetBrains Mono', monospace; font-weight:500; }

/* Seviye / progress */
.sb-level {
  display:flex; align-items:center; gap:10px;
  padding:10px 0;
  border-bottom:1px solid var(--hairline);
  margin-bottom:14px;
}
.sb-level-num {
  width:26px; height:26px; border-radius:50%;
  background:linear-gradient(135deg, var(--warn), #F97316);
  color:#fff; display:grid; place-items:center;
  font-size:12px; font-weight:700; flex-shrink:0;
}
.sb-level-info { flex:1; min-width:0; }
.sb-level-name { font-size:11.5px; font-weight:700; color:var(--warn); }
.sb-level-bar { height:3px; background:var(--surface-3); border-radius:2px;
                margin-top:4px; overflow:hidden; }
.sb-level-bar div { height:100%;
                    background:linear-gradient(90deg, var(--warn), #F97316);
                    border-radius:2px; transition:width var(--t-2); }
.sb-level-bonus {
  background:var(--accent-soft); color:var(--accent-darker);
  font-size:9.5px; font-weight:700; letter-spacing:.4px;
  padding:3px 8px; border-radius:var(--r-pill);
  flex-shrink:0;
}

/* Bakiye Yükle CTA — yeşil prominent */
.sb-cta {
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 14px;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  color:#fff;
  border-radius:10px;
  font-size:13px; font-weight:600;
  margin-bottom:14px;
  box-shadow:0 4px 12px rgba(16,185,129,0.30);
  transition:transform var(--t-1), box-shadow var(--t-1);
}
.sb-cta:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(16,185,129,0.40); }
.sb-cta i { font-size:14px; }
.sb-cta .chev { margin-left:auto; opacity:.85; }

/* Sidebar Nav */
.sb-nav { display:flex; flex-direction:column; gap:1px; }
.sb-link {
  display:flex; align-items:center; gap:11px;
  padding:10px 12px; border-radius:8px;
  color:var(--text-3); font-size:13px; font-weight:500;
  transition:background var(--t-1), color var(--t-1);
  position:relative;
}
.sb-link i {
  font-size:14px; width:16px; text-align:center;
  color:var(--text-muted); transition:color var(--t-1);
}
.sb-link:hover { background:var(--surface-2); color:var(--text); }
.sb-link:hover i { color:var(--text-2); }
.sb-link.is-active {
  background:var(--accent-soft); color:var(--accent-darker);
  font-weight:600;
}
.sb-link.is-active i { color:var(--accent-dark); }
.sb-link.is-active::before {
  content:''; position:absolute; left:-20px; top:8px; bottom:8px;
  width:3px; background:var(--accent); border-radius:0 2px 2px 0;
}
.sb-pill {
  margin-left:auto;
  background:var(--danger); color:#fff;
  font-size:9.5px; font-weight:700;
  padding:1px 6px; border-radius:var(--r-pill);
}

.sb-divider { height:1px; background:var(--hairline); margin:14px 0; }

.sb-logout {
  display:flex; align-items:center; gap:11px;
  padding:10px 12px; border-radius:8px;
  color:var(--danger); font-size:13px; font-weight:500;
  transition:background var(--t-1);
}
.sb-logout i { font-size:14px; width:16px; text-align:center; }
.sb-logout:hover { background:var(--danger-soft); }

/* Panel geçişi */
.sb-switch {
  display:flex; align-items:center; gap:11px;
  padding:10px 12px; border-radius:8px;
  background:var(--surface-2);
  color:var(--text-2); font-size:12.5px; font-weight:600;
  margin-bottom:6px;
  transition:background var(--t-1), color var(--t-1);
  border:1px dashed var(--border);
}
.sb-switch i { font-size:13px; width:16px; text-align:center; color:var(--accent); }
.sb-switch:hover { background:var(--accent-soft); color:var(--accent-darker); border-color:var(--accent); }

/* ─── MAIN CONTENT ───────────────────────────────────────── */
.main { min-width:0; display:flex; flex-direction:column; gap:18px; }

/* Page header — sade, bayigram tarzı */
.page-head {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:18px; flex-wrap:wrap;
  margin-bottom:18px;
}
.page-head > div:first-child { flex:1; min-width:0; }
.page-eyebrow {
  font-size:11px; font-weight:600; letter-spacing:.6px;
  color:var(--accent-darker); text-transform:uppercase;
  margin-bottom:6px;
}
.page-title {
  font-size:22px; font-weight:700; letter-spacing:-.4px;
  color:var(--text); line-height:1.2;
}
.page-sub {
  font-size:13px; color:var(--text-3); margin-top:4px;
  max-width:560px; line-height:1.55;
}
.page-actions { display:flex; gap:8px; flex-wrap:wrap; }


/* ─── COMPONENTS ─────────────────────────────────────────── */

/* Card — beyaz, ince border, başlık + "Tümünü Gör" pill */
.card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-1);
}
.card-head {
  display:flex; align-items:center; gap:10px;
  padding:14px 20px;
  border-bottom:1px solid var(--hairline);
}
.card-head-icon {
  width:32px; height:32px; border-radius:8px;
  background:var(--accent-soft); color:var(--accent-darker);
  display:grid; place-items:center; font-size:14px;
  flex-shrink:0;
}
.card-head-title {
  font-size:13.5px; font-weight:600; color:var(--text);
}
.card-head .right { margin-left:auto; }
.card-body { padding:20px; }
.card-foot {
  padding:14px 20px;
  border-top:1px solid var(--hairline);
  background:var(--surface-2);
  border-radius:0 0 var(--r-lg) var(--r-lg);
}

/* "Tümünü Gör" pill butonu */
.card-link {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 12px;
  background:var(--accent); color:#fff;
  border-radius:var(--r-pill);
  font-size:11.5px; font-weight:600;
  transition:background var(--t-1), transform var(--t-1);
}
.card-link:hover { background:var(--accent-dark); transform:translateY(-1px); }
.card-link i { font-size:11px; }

/* Button — generic */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:9px 16px;
  border-radius:8px;
  font-size:13px; font-weight:600;
  background:var(--surface); color:var(--text);
  border:1px solid var(--border);
  transition:all var(--t-1);
  white-space:nowrap;
}
.btn:hover { border-color:var(--text-muted); transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none; }
.btn i { font-size:13px; }

.btn--primary {
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  color:#fff; border-color:transparent;
  box-shadow:0 4px 12px rgba(16,185,129,0.25);
}
.btn--primary:hover { box-shadow:0 6px 18px rgba(16,185,129,0.35); }

.btn--dark {
  background:#0F172A; color:#fff; border-color:#0F172A;
}
.btn--dark:hover { background:#1E293B; }

/* Dark variant card — dark mode'dan etkilenmesin, sabit koyu */
.card--dark {
  background:#0F172A !important; color:#FAFAFA !important; border:0 !important;
}
.card--dark .t-muted,
.card--dark .t-3,
.card--dark .t-xs { color:rgba(255,255,255,0.55) !important; }

.btn--danger {
  background:var(--danger); color:#fff; border-color:var(--danger);
}
.btn--danger:hover { background:#DC2626; }

.btn--ghost {
  background:transparent; color:var(--text-2); border-color:var(--border);
}
.btn--ghost:hover { background:var(--surface); }

.btn--sm  { padding:6px 12px; font-size:12px; border-radius:7px; }
.btn--lg  { padding:12px 22px; font-size:14px; }
.btn--block { width:100%; }

/* Form */
.form-group { margin-bottom:16px; }
.form-label {
  display:block; font-size:12px; font-weight:600;
  color:var(--text-2); margin-bottom:6px;
}
.form-label .req { color:var(--danger); margin-left:2px; }
.form-label .hint { color:var(--text-muted); font-size:11.5px; margin-left:6px; font-weight:400; }

.form-control {
  width:100%;
  padding:10px 13px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--surface);
  font-size:13px; color:var(--text);
  outline:0;
  transition:border-color var(--t-1), box-shadow var(--t-1);
}
.form-control:focus { border-color:var(--accent); box-shadow:var(--sh-glow); }
.form-control:disabled { background:var(--surface-2); color:var(--text-muted); }
.form-control::placeholder { color:var(--text-light); }
textarea.form-control { resize:vertical; min-height:84px; line-height:1.55; }

.form-hint {
  display:flex; align-items:center; gap:5px;
  margin-top:6px;
  font-size:11px; color:var(--text-muted);
}
.form-row { display:grid; gap:14px; }
.form-row--2 { grid-template-columns:1fr 1fr; }
.form-row--3 { grid-template-columns:1fr 1fr 1fr; }

select.form-control {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2.5 4.5L6 8L9.5 4.5' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center;
  padding-right:32px;
}

/* Badge */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:2px 9px; border-radius:var(--r-pill);
  font-size:10.5px; font-weight:600;
  background:var(--surface-2); color:var(--text-3);
  border:1px solid var(--hairline);
}
.badge--success { background:var(--success-soft); color:var(--accent-darker); border-color:rgba(16,185,129,0.20); }
.badge--warn    { background:var(--warn-soft);    color:#A16207;             border-color:rgba(245,158,11,0.20); }
.badge--danger  { background:var(--danger-soft);  color:#B91C1C;             border-color:rgba(239,68,68,0.20); }
.badge--info    { background:var(--info-soft);    color:#1D4ED8;             border-color:rgba(59,130,246,0.20); }

/* Status badge */
.status         { display:inline-flex; align-items:center; gap:4px;
                  font-size:11px; font-weight:600; padding:2px 9px;
                  border-radius:var(--r-pill); border:1px solid; }
.status::before { content:''; width:5px; height:5px; border-radius:50%;
                  background:currentColor; opacity:.7; }
.status--active    { background:var(--success-soft); color:var(--accent-darker); border-color:rgba(16,185,129,0.22); }
.status--approved  { background:var(--success-soft); color:var(--accent-darker); border-color:rgba(16,185,129,0.22); }
.status--paused    { background:var(--warn-soft);    color:#A16207;             border-color:rgba(245,158,11,0.22); }
.status--pending   { background:var(--warn-soft);    color:#A16207;             border-color:rgba(245,158,11,0.22); }
.status--rejected  { background:var(--danger-soft);  color:#B91C1C;             border-color:rgba(239,68,68,0.22); }
.status--completed { background:var(--info-soft);    color:#1D4ED8;             border-color:rgba(59,130,246,0.22); }

/* Alert */
.alert {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; border-radius:var(--r-md);
  font-size:13px; font-weight:500; border:1px solid;
  margin-bottom:16px;
}
.alert i { font-size:15px; flex-shrink:0; }
.alert--success { background:var(--success-soft); color:var(--accent-darker); border-color:rgba(16,185,129,0.25); }
.alert--danger  { background:var(--danger-soft);  color:#B91C1C;             border-color:rgba(239,68,68,0.25); }
.alert--warn    { background:var(--warn-soft);    color:#A16207;             border-color:rgba(245,158,11,0.25); }
.alert--info    { background:var(--info-soft);    color:#1D4ED8;             border-color:rgba(59,130,246,0.25); }

/* Empty state — card içinde */
.empty {
  text-align:center;
  padding:48px 24px;
}
.empty-icon {
  width:64px; height:64px; border-radius:18px;
  background:var(--surface-2); color:var(--text-muted);
  display:grid; place-items:center;
  font-size:24px; margin:0 auto 12px;
}
.empty-title { font-size:13.5px; font-weight:600; color:var(--text-2); }
.empty-sub   { font-size:12.5px; color:var(--text-muted); margin-top:5px; }
.empty-action { margin-top:18px; }

/* Skeleton */
@keyframes shimmer { 0%{background-position:-400px 0;} 100%{background-position:400px 0;} }
.skeleton {
  background:linear-gradient(90deg, var(--surface-2) 0%, var(--surface-3) 50%, var(--surface-2) 100%);
  background-size:800px 100%; animation:shimmer 1.4s linear infinite;
  border-radius:var(--r-sm);
}

/* Divider */
.hr  { border:0; border-top:1px solid var(--hairline); margin:14px 0; }

/* Toast */
#toasts {
  position:fixed; bottom:24px; right:24px;
  z-index:var(--z-toast);
  display:flex; flex-direction:column; gap:8px;
  pointer-events:none;
}
.toast {
  pointer-events:auto;
  background:var(--text); color:#fff;
  padding:11px 16px; border-radius:10px;
  font-size:12.5px; font-weight:500;
  display:flex; align-items:center; gap:8px;
  box-shadow:var(--sh-3);
  transform:translateY(20px); opacity:0;
  transition:transform var(--t-2), opacity var(--t-2);
  max-width:340px;
}
.toast.is-show { transform:translateY(0); opacity:1; }
.toast--success i { color:var(--accent); }
.toast--danger  i { color:#FCA5A5; }

/* Drawer */
.drawer {
  position:fixed; top:0; right:0; bottom:0;
  width:min(560px, 95vw);
  background:var(--surface);
  border-left:1px solid var(--border);
  box-shadow:var(--sh-3);
  z-index:var(--z-drawer);
  transform:translateX(100%);
  transition:transform var(--t-3);
  display:flex; flex-direction:column;
}
.drawer.is-open { transform:translateX(0); }
.drawer-head { padding:18px 22px; border-bottom:1px solid var(--hairline);
               display:flex; align-items:center; gap:10px; }
.drawer-head h3 { font-size:14px; font-weight:600; }
.drawer-close { margin-left:auto; width:32px; height:32px; border-radius:8px;
                background:var(--surface-2); display:grid; place-items:center; }
.drawer-body { flex:1; overflow-y:auto; padding:20px 22px; }
.drawer-overlay {
  position:fixed; inset:0; background:rgba(15,23,42,0.45);
  z-index:calc(var(--z-drawer) - 1);
  opacity:0; pointer-events:none;
  transition:opacity var(--t-2);
}
.drawer-overlay.is-open { opacity:1; pointer-events:auto; }

/* Lightbox */
.lightbox {
  position:fixed; inset:0;
  background:rgba(15,23,42,0.94);
  z-index:var(--z-modal); display:none; place-items:center; padding:24px;
}
.lightbox.is-open { display:grid; }
.lightbox img { max-width:96vw; max-height:92vh; border-radius:var(--r-md); }
.lightbox-close {
  position:fixed; top:18px; right:20px;
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,0.10);
  color:#fff; display:grid; place-items:center; font-size:18px;
}

/* Mobile sidebar overlay */
.sb-overlay {
  position:fixed; inset:0; background:rgba(15,23,42,0.45);
  z-index:calc(var(--z-nav) - 1);
  opacity:0; pointer-events:none;
  transition:opacity var(--t-2);
}
.sb-overlay.is-open { opacity:1; pointer-events:auto; }

/* Grid utilities */
.grid { display:grid; gap:14px; }
.grid--2 { grid-template-columns:repeat(2,1fr); }
.grid--3 { grid-template-columns:repeat(3,1fr); }
.grid--4 { grid-template-columns:repeat(4,1fr); }

.row { display:flex; gap:10px; align-items:center; }
.row--between { justify-content:space-between; }

/* Text utils */
.t-muted { color:var(--text-muted); }
.t-2     { color:var(--text-2); }
.t-3     { color:var(--text-3); }
.t-bold  { font-weight:600; }
.t-xl    { font-size:18px; font-weight:700; letter-spacing:-.3px; }
.t-lg    { font-size:15px; font-weight:600; letter-spacing:-.2px; }
.t-md    { font-size:13.5px; }
.t-sm    { font-size:12px; }
.t-xs    { font-size:11px; }
.t-right { text-align:right; }
.t-center{ text-align:center; }
.truncate { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ─── FAB (floating sohbet) ──────────────────────────────── */
.fab {
  position:fixed; bottom:20px; right:20px;
  display:flex; align-items:center; gap:8px;
  padding:11px 18px;
  background:var(--danger);
  color:#fff;
  border-radius:var(--r-pill);
  font-size:13px; font-weight:600;
  box-shadow:0 8px 20px rgba(239,68,68,0.35);
  z-index:90;
  transition:transform var(--t-1), box-shadow var(--t-1);
}
.fab:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(239,68,68,0.50); }
.fab i { font-size:15px; }
.fab .pulse {
  width:8px; height:8px; border-radius:50%; background:#fff;
  animation:livepulse 1.5s ease-in-out infinite;
}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer {
  background:var(--footer-bg);
  color:var(--footer-text);
  margin-top:48px;
  padding:40px 0 0;
}
.footer-inner {
  max-width:var(--max-w); margin:0 auto;
  padding:0 var(--content-px);
}

.f-top {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:24px; flex-wrap:wrap;
  padding-bottom:28px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.f-brand { display:flex; align-items:center; gap:12px; }
.f-brand-mark {
  width:42px; height:42px; border-radius:11px;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  display:grid; place-items:center; font-size:18px; color:#fff;
}
.f-brand-name { font-size:17px; font-weight:700; color:#fff; letter-spacing:-.3px; }
.f-brand-sub  { font-size:11px; color:var(--text-muted); margin-top:2px; }

.f-social { display:flex; gap:8px; }
.f-social a {
  width:36px; height:36px; border-radius:50%;
  background:var(--footer-bg-2);
  color:var(--footer-text);
  display:grid; place-items:center;
  transition:background var(--t-1), color var(--t-1), transform var(--t-1);
}
.f-social a:hover { background:var(--accent); color:#fff; transform:translateY(-2px); }

.f-tabs {
  display:flex; align-items:center;
  padding:22px 0 0;
  gap:6px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow-x:auto; -ms-overflow-style:none; scrollbar-width:none;
}
.f-tabs::-webkit-scrollbar { display:none; }
.f-tab {
  display:flex; align-items:center; gap:6px;
  padding:14px 16px; border-radius:8px 8px 0 0;
  font-size:12.5px; font-weight:600;
  color:var(--text-muted);
  white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color var(--t-1), border-color var(--t-1);
}
.f-tab i { font-size:13px; }
.f-tab:hover { color:#fff; }
.f-tab.is-active { color:#fff; border-bottom-color:var(--accent); }

.f-cards {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:14px; padding:22px 0;
}
.f-card {
  background:var(--footer-bg-2);
  border-radius:var(--r-md);
  padding:18px 16px;
  text-align:center;
  transition:transform var(--t-1);
}
.f-card:hover { transform:translateY(-2px); }
.f-card-icon {
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,0.06);
  display:grid; place-items:center; margin:0 auto 10px;
  color:var(--accent); font-size:16px;
}
.f-card-title { font-size:13px; font-weight:600; color:#fff; }
.f-card-sub   { font-size:11px; color:var(--text-muted); margin-top:3px; }

.f-policies {
  display:flex; flex-wrap:wrap; gap:6px 18px;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,0.08);
  font-size:11.5px;
}
.f-policies a { color:var(--text-muted); transition:color var(--t-1); }
.f-policies a:hover { color:#fff; }

.f-contacts {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:14px;
  padding:22px 0 32px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.f-contact {
  display:flex; align-items:center; gap:12px;
  padding:14px 16px;
  background:var(--footer-bg-2);
  border-radius:var(--r-md);
}
.f-contact-icon {
  width:38px; height:38px; border-radius:50%;
  background:var(--accent); color:#fff;
  display:grid; place-items:center;
  flex-shrink:0; font-size:15px;
}
.f-contact-l { font-size:13px; font-weight:700; color:#fff; line-height:1.2;
               font-family:'JetBrains Mono', monospace; letter-spacing:.5px; }
.f-contact-s { font-size:11px; color:var(--text-muted); margin-top:2px; }

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  :root { --sidebar-w: 220px; }
}
@media (max-width: 880px) {
  .app-wrap {
    grid-template-columns: 1fr;
    padding: 16px;
  }
  .sidebar {
    position:fixed; top:0; left:0; bottom:0; width:280px;
    border-radius:0; padding:24px 20px;
    transform:translateX(-100%);
    transition:transform var(--t-3);
    box-shadow:none; z-index:var(--z-nav);
    overflow-y:auto;
  }
  .sidebar.is-open { transform:translateX(0); box-shadow:var(--sh-3); }
  .tn-burger { display:grid; }
  .tn-search { display:none; }
  .tn-brand-sub { display:none; }
  .tn-user-name, .tn-user-bal { display:none; }
  .tn-user { padding:4px; }

  .f-cards, .f-contacts { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .tn-user { display:none; }
  .f-cards, .f-contacts { grid-template-columns:1fr; }
  .page-hero { padding:16px 18px; }
  .page-hero h1 { font-size:16px; }
}

@media print {
  .topnav, .sidebar, .footer { display:none; }
  .app-wrap { padding:0; grid-template-columns:1fr; }
}

/* ─── DARK MODE ──────────────────────────────────────────── */
html[data-theme="dark"] {
  --bg:           #0F1623;
  --bg-2:         #141E2F;
  --surface:      #1A2436;
  --surface-2:    #1E2A3F;
  --surface-3:    #243348;
  --border:       #2A3850;
  --border-soft:  #243348;
  --divider:      #243348;
  --hairline:     #243348;

  --text:         #E2E8F0;
  --text-2:       #CBD5E1;
  --text-3:       #94A3B8;
  --text-muted:   #64748B;
  --text-light:   #475569;
}
html[data-theme="dark"] body { background:var(--bg); }
html[data-theme="dark"] .topnav,
html[data-theme="dark"] .subnav { background:var(--surface); }
html[data-theme="dark"] .tn-search input,
html[data-theme="dark"] .tn-icon,
html[data-theme="dark"] .tn-user { background:var(--surface-2); border-color:var(--border); }
html[data-theme="dark"] .sidebar,
html[data-theme="dark"] .card { background:var(--surface); border-color:var(--border); }
html[data-theme="dark"] .empty-icon,
html[data-theme="dark"] .li-icon,
html[data-theme="dark"] .card-head-icon { background:var(--surface-2); }
html[data-theme="dark"] .promo-bar {
  background:linear-gradient(90deg, #2A2418 0%, #2B1F24 50%, #1A2D26 100%);
  border-bottom-color:var(--border);
}
html[data-theme="dark"] .promo-ticker { background:var(--surface-2); border-color:var(--border); }
html[data-theme="dark"] .form-control { background:var(--surface-2); border-color:var(--border); color:var(--text); }
html[data-theme="dark"] .badge,
html[data-theme="dark"] .status { background:var(--surface-2); border-color:var(--border); }

