:root{--bg:#f4f7fb;--card:#fff;--text:#172033;--muted:#6b7280;--primary:#2563eb;--primary2:#1d4ed8;--danger:#dc2626;--success:#16a34a;--warning:#f59e0b;--border:#e5e7eb;--dark:#0f172a;--soft:#f8fafc}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}h1,h2{margin:0}h1{font-size:30px}h2{font-size:18px;margin-bottom:14px}.muted{color:var(--muted)}.hint{font-size:13px;color:var(--muted);text-align:center;margin:16px 0 0}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top,#dbeafe,transparent 35%),var(--bg)}.login-card,.card{background:rgba(255,255,255,.95);border:1px solid var(--border);border-radius:20px;box-shadow:0 16px 45px rgba(15,23,42,.08)}.login-card{width:100%;max-width:410px;padding:30px}.login-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#eff6ff;color:#1d4ed8;font-weight:900;font-size:24px;margin-bottom:12px}.brand{font-size:25px;font-weight:900;margin-bottom:6px}.sub{color:var(--muted);font-size:14px;margin-bottom:22px}.layout{display:flex;min-height:100vh}.sidebar{width:270px;background:linear-gradient(180deg,#0f172a,#111827);color:#fff;padding:18px;position:fixed;inset:0 auto 0 0;overflow:auto}.brandbox{display:flex;gap:12px;align-items:center;padding:10px 8px 24px}.brandbox strong{display:block;font-size:18px}.brandbox small{display:block;color:#94a3b8;font-size:12px;margin-top:3px}.logo-dot{width:42px;height:42px;border-radius:14px;background:#2563eb;display:grid;place-items:center;font-weight:900}.nav a{display:flex;align-items:center;padding:12px 14px;border-radius:14px;margin-bottom:7px;color:#cbd5e1;font-weight:700}.nav a:hover,.nav a.active{background:rgba(255,255,255,.1);color:#fff}.main{margin-left:270px;width:calc(100% - 270px);padding:28px}.top{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:22px}.top p{margin:6px 0 0}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.card{padding:20px;margin-bottom:18px}.stat{min-height:118px}.stat span{color:var(--muted);font-weight:800;font-size:13px}.stat b{font-size:27px;display:block;margin-top:12px;letter-spacing:-.5px}.stat.income{border-left:5px solid var(--success)}.stat.expense{border-left:5px solid var(--danger)}.stat.net{border-left:5px solid var(--primary)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.link{color:var(--primary);font-weight:800}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.form-grid .full{grid-column:1/-1}.form-end{display:flex;align-items:end}.form-inline,.filters,.month-picker,.quick-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.quick-form>*{flex:1;min-width:120px}.quick-form button{flex:0 0 auto}label{font-size:13px;color:#374151;font-weight:800;margin-bottom:7px;display:block}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:13px;padding:11px 12px;background:#fff;color:var(--text);outline:none;font-size:14px}input:focus,select:focus,textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 4px #dbeafe}textarea{min-height:88px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:13px;padding:11px 15px;background:var(--primary);color:#fff;font-weight:900;cursor:pointer;white-space:nowrap}.btn:hover{background:var(--primary2)}.btn.secondary{background:#475569}.btn.danger{background:var(--danger)}.btn.success{background:var(--success)}.btn.small{padding:8px 10px;font-size:12px}.btn.wide{width:100%;margin-top:16px}.actions{display:flex;gap:8px;flex-wrap:wrap}.table-wrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:16px}table{width:100%;border-collapse:collapse;background:#fff;min-width:760px}th,td{text-align:left;padding:13px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}th{color:#475569;background:#f8fafc;font-weight:900}tr:last-child td{border-bottom:0}.alert{padding:13px 15px;border-radius:14px;margin-bottom:14px;font-weight:800}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}.badge,.pill{display:inline-flex;align-items:center;padding:6px 9px;border-radius:999px;font-size:12px;font-weight:900}.badge{background:#eef2ff;color:#3730a3}.pill.income{background:#dcfce7;color:#166534}.pill.expense{background:#fee2e2;color:#991b1b}.progress{height:14px;background:#e5e7eb;border-radius:99px;overflow:hidden}.progress i{display:block;height:100%;background:linear-gradient(90deg,#16a34a,#f59e0b,#dc2626);border-radius:99px}.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mini-stats div,.account-list div{background:var(--soft);border:1px solid var(--border);border-radius:15px;padding:14px}.mini-stats span,.account-list span{display:block;color:var(--muted);font-size:13px;font-weight:800}.mini-stats b,.account-list b{display:block;margin-top:7px;font-size:20px}.account-list{display:grid;gap:10px}@media(max-width:1050px){.grid,.grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:780px){.layout{display:block}.sidebar{position:relative;width:100%;inset:auto;border-radius:0 0 24px 24px}.brandbox{padding-bottom:14px}.nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.nav a{margin:0;justify-content:center;text-align:center}.main{margin-left:0;width:100%;padding:16px}.top{align-items:flex-start;flex-direction:column}h1{font-size:25px}.grid,.grid.two,.grid.three,.stats-grid,.form-grid{grid-template-columns:1fr}.form-inline,.filters,.month-picker,.quick-form{align-items:stretch}.form-inline>*,.filters>*,.month-picker>*,.quick-form>*{width:100%;flex:auto}.card{padding:16px;border-radius:18px}.stat{min-height:auto}.stat b{font-size:23px}.mini-stats{grid-template-columns:1fr}table{min-width:720px}.login-card{padding:24px}}.detail-stats .stat{appearance:none;border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);text-align:left;cursor:pointer;transition:.18s ease;position:relative}
.detail-stats .stat:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(15,23,42,.12)}
.detail-stats .stat.active{outline:3px solid #bfdbfe;background:#f8fbff}
.stat em{display:inline-flex;margin-top:10px;color:var(--primary);font-style:normal;font-weight:900;font-size:12px}
.stat-detail{display:none;margin-top:-2px;animation:detailIn .18s ease}
.stat-detail.is-open{display:block}
.detail-summary{margin:0 0 14px}.detail-summary b{color:var(--text)}
.detail-mini{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:14px}
.compact-table table{min-width:690px}.compact-table th,.compact-table td{padding:11px 12px}
@keyframes detailIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media(max-width:780px){.detail-stats .stat:hover{transform:none}.detail-mini{grid-template-columns:1fr}.stat-detail{margin-top:0}.compact-table table{min-width:680px}}


.amount{font-weight:900;white-space:nowrap}.amount-income{color:var(--success)!important}.amount-expense{color:var(--danger)!important}.amount-neutral{color:var(--text)!important}.amount-warning{color:var(--warning)!important}.amount-primary{color:var(--primary)!important}
.stat.income b,.stat.income .amount{color:var(--success)!important}.stat.expense b,.stat.expense .amount{color:var(--danger)!important}.stat.net b.positive,.stat.net .amount-income{color:var(--success)!important}.stat.net b.negative,.stat.net .amount-expense{color:var(--danger)!important}
.detail-mini .income-amount b,.detail-mini .income-amount .amount{color:var(--success)!important}.detail-mini .expense-amount b,.detail-mini .expense-amount .amount{color:var(--danger)!important}.detail-mini .debt-amount b,.detail-mini .debt-amount .amount{color:var(--warning)!important}.detail-mini .receivable-amount b,.detail-mini .receivable-amount .amount{color:var(--primary)!important}
td.amount-cell b{font-weight:900}.row-income .amount-cell b,.row-income .amount{color:var(--success)!important}.row-expense .amount-cell b,.row-expense .amount{color:var(--danger)!important}.row-debt .amount-cell b,.row-debt .amount{color:var(--warning)!important}.row-receivable .amount-cell b,.row-receivable .amount{color:var(--primary)!important}

/* Mobile bottom navigation */
.nav-icon{display:none}.nav-text{display:inline}
@media(max-width:780px){
  body{padding-bottom:86px}
  .layout{display:block;min-height:100vh}
  .sidebar.bottom-nav-shell{position:fixed;left:10px;right:10px;bottom:10px;top:auto;width:auto;z-index:999;padding:8px;background:rgba(15,23,42,.94);border:1px solid rgba(255,255,255,.10);border-radius:24px;box-shadow:0 18px 45px rgba(15,23,42,.30);backdrop-filter:blur(14px);overflow:visible}
  .sidebar.bottom-nav-shell .brandbox{display:none}
  .bottom-nav{display:flex;align-items:center;gap:6px;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding:2px;grid-template-columns:none}
  .bottom-nav::-webkit-scrollbar{display:none}
  .bottom-nav a{flex:0 0 74px;min-height:58px;margin:0;padding:8px 6px;border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-align:center;color:#cbd5e1;scroll-snap-align:center;font-size:11px;line-height:1.05;font-weight:900}
  .bottom-nav a:hover,.bottom-nav a.active{background:#fff;color:#0f172a;box-shadow:0 10px 24px rgba(0,0,0,.18)}
  .nav-icon{display:grid;place-items:center;width:24px;height:24px;font-size:18px;line-height:1}
  .nav-text{display:block;max-width:68px;white-space:normal}
  .main{margin-left:0;width:100%;padding:16px 14px 22px}
}
@media(max-width:420px){
  .sidebar.bottom-nav-shell{left:8px;right:8px;bottom:8px;border-radius:22px}
  .bottom-nav a{flex-basis:68px;font-size:10.5px;min-height:56px}
  .nav-text{max-width:62px}
}

/* Dashboard kategori pizza/pie grafikleri */
.stat-chart-card{padding:18px;min-height:184px}
.stat-chart-layout{display:flex;align-items:center;justify-content:space-between;gap:16px}
.stat-main{min-width:0}.stat-main b{font-size:25px}.stat-main em{margin-top:8px}
.mini-donut{width:118px;height:118px;flex:0 0 118px;border-radius:50%;background:var(--donut);position:relative;display:block;box-shadow:0 14px 32px rgba(15,23,42,.14), inset 0 0 0 1px rgba(15,23,42,.08);border:4px solid #fff;overflow:hidden}
.mini-donut:after{content:none}
.mini-donut strong,.mini-donut small{display:none}
.donut-legend{display:grid;grid-template-columns:1fr;gap:7px;margin-top:14px}
.donut-legend small{display:flex;align-items:center;gap:8px;color:#475569;font-weight:850;font-size:12px;line-height:1.2;min-width:0}
.donut-legend i{width:12px;height:12px;border-radius:3px;flex:0 0 12px;box-shadow:0 0 0 1px rgba(15,23,42,.08)}
.donut-legend b{margin:0 0 0 auto;font-size:12px;letter-spacing:0;color:var(--text);font-weight:1000}
.stat-chart-card.income .mini-donut{box-shadow:0 14px 32px rgba(22,163,74,.15), inset 0 0 0 1px rgba(15,23,42,.08)}
.stat-chart-card.expense .mini-donut{box-shadow:0 14px 32px rgba(220,38,38,.15), inset 0 0 0 1px rgba(15,23,42,.08)}
@media(max-width:1050px){.stat-chart-card{min-height:168px}.mini-donut{width:108px;height:108px;flex-basis:108px}}
@media(max-width:780px){.stat-chart-card{min-height:auto}.stat-chart-layout{gap:12px}.mini-donut{width:104px;height:104px;flex-basis:104px}.donut-legend{grid-template-columns:repeat(2,minmax(0,1fr))}.donut-legend small{font-size:11px}.stat-main b{font-size:22px}}
@media(max-width:380px){.donut-legend{grid-template-columns:1fr}.mini-donut{width:92px;height:92px;flex-basis:92px}}
