/* HERMES v3.0 — ProjectHub Design */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

:root {
  --bg-primary:#0d0d12;--bg-secondary:#14141c;--bg-tertiary:#1a1a26;--bg-card:#1e1e2a;--bg-hover:#252535;
  --text-primary:#f0f0f5;--text-secondary:#9898a8;--text-muted:#6a6a7a;
  --accent-primary:#6366f1;--accent-secondary:#8b5cf6;--accent-tertiary:#a78bfa;
  --accent-gradient:linear-gradient(135deg,#6366f1,#8b5cf6);
  --success:#22c55e;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;
  --border-color:#2a2a3a;--border-light:#3a3a4a;
  --radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;
  --shadow-sm:0 1px 2px rgba(0,0,0,0.3);--shadow-md:0 4px 12px rgba(0,0,0,0.4);--shadow-lg:0 8px 24px rgba(0,0,0,0.5);
  --font-sans:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'Space Mono','Courier New',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-sans);font-size:.9rem;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;display:flex;min-height:100vh}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}

/* ─── Sidebar ─── */
.sidebar{width:260px;height:100vh;position:fixed;top:0;left:0;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:transform .3s ease}
.sidebar-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}
.sidebar-logo{display:flex;align-items:center;gap:.75rem;font-family:var(--font-mono);font-size:1.15rem;font-weight:700;color:var(--text-primary)}
.sidebar-logo-icon{width:36px;height:36px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;flex-shrink:0}
.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto}
.nav-section{margin-bottom:1rem}
.nav-section-title{text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;font-weight:600;color:var(--text-muted);padding:0 .75rem .4rem;margin-top:.25rem}
.nav-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.87rem;font-weight:500;transition:all .2s;margin-bottom:2px}
.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}
.nav-link.active{background:var(--accent-primary);color:#fff}
.nav-link i{width:18px;text-align:center;font-size:.85rem}
.sidebar-footer{padding:.75rem 1rem;border-top:1px solid var(--border-color)}
.user-menu{display:flex;align-items:center;gap:.65rem;padding:.4rem}
.user-avatar{width:32px;height:32px;background:var(--accent-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.75rem;flex-shrink:0}
.user-name{font-size:.82rem;font-weight:500}.user-role{font-size:.68rem;color:var(--text-muted)}
.sidebar-version{font-size:.6rem;color:var(--text-muted);text-align:center;margin-top:.4rem}
.mobile-toggle{display:none;position:fixed;top:.75rem;left:.75rem;z-index:200;width:40px;height:40px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.1rem;cursor:pointer;align-items:center;justify-content:center}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:90}
.sidebar-overlay.open{display:block}

/* ─── Main ─── */
.main{flex:1;margin-left:260px;padding:1.5rem 2rem;overflow-y:auto;max-height:100vh}
h1{font-size:1.4rem;font-weight:700;margin-bottom:1.25rem}
h1 i{margin-right:.5rem;color:var(--accent-primary)}

/* ─── Cards ─── */
.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1.25rem;overflow:hidden}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}
.card-title{font-size:.88rem;font-weight:600;display:flex;align-items:center;gap:.5rem}
.card-title i{color:var(--text-muted);font-size:.82rem}
.card-body{padding:1.25rem}
.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;transition:all .2s}
.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px)}
.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:.75rem;font-size:1rem}
.stat-icon.income{background:rgba(34,197,94,.15);color:var(--success)}
.stat-icon.expense{background:rgba(239,68,68,.15);color:var(--error)}
.stat-icon.balance{background:rgba(99,102,241,.15);color:var(--accent-primary)}
.stat-value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono);line-height:1.1}
.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--error)}
.stat-label{font-size:.78rem;color:var(--text-muted);margin-top:.2rem}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}
.card-action{cursor:pointer;transition:all .2s;display:block}
.card-action:hover{border-color:var(--accent-primary);transform:translateY(-2px)}
.card-action .card-body{display:flex;align-items:center;gap:1rem}
.card-action-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}

/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.55rem 1.1rem;font-size:.82rem;font-weight:500;font-family:var(--font-sans);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s;text-decoration:none;white-space:nowrap;line-height:1}
.btn-primary{background:var(--accent-gradient);color:#fff}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}
.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-light)}
.btn-ghost{background:transparent;color:var(--text-secondary);padding:.4rem .6rem;font-size:.78rem}
.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--error);border:1px solid rgba(239,68,68,.25)}
.btn-danger:hover{background:var(--error);color:#fff}
.btn-sm{padding:.35rem .65rem;font-size:.78rem}

/* ─── Forms ─── */
.form-group{margin-bottom:1.1rem}
.form-label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.35rem}
.form-label i{margin-right:.3rem;font-size:.75rem}
.form-control{width:100%;padding:.65rem .85rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.85rem;font-family:var(--font-sans);transition:all .2s}
.form-control:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(99,102,241,.2)}
.form-control::placeholder{color:var(--text-muted)}
textarea.form-control{min-height:70px;resize:vertical}
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 24 24' fill='none' stroke='%239898a8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.form-hint{font-size:.72rem;color:var(--text-muted);margin-top:.25rem}
.type-toggle{display:flex;gap:.5rem;margin-bottom:1.25rem}
.type-toggle button{flex:1;padding:.6rem;border-radius:var(--radius-md);border:2px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;font-weight:600;font-size:.85rem;font-family:var(--font-sans);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.45rem}
.type-toggle button.selected.ausgabe{border-color:var(--error);background:rgba(239,68,68,.1);color:var(--error)}
.type-toggle button.selected.einnahme{border-color:var(--success);background:rgba(34,197,94,.1);color:var(--success)}
.form-check{display:flex;align-items:center;gap:.6rem;cursor:pointer;font-size:.85rem}
.form-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}

/* ─── Tables ─── */
.table-container{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.82rem}
th{text-align:left;padding:.7rem;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}
td{padding:.7rem;border-bottom:1px solid var(--border-color);color:var(--text-secondary);vertical-align:middle}
tr:hover td{background:var(--bg-hover)}
.action-cell{white-space:nowrap}
.action-cell form{display:inline}

/* ─── Badges ─── */
.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.18rem .5rem;font-size:.7rem;font-weight:500;border-radius:999px;line-height:1}
.badge-success{background:rgba(34,197,94,.15);color:var(--success)}
.badge-error{background:rgba(239,68,68,.15);color:var(--error)}
.badge-warning{background:rgba(245,158,11,.15);color:var(--warning)}
.badge-info{background:rgba(59,130,246,.15);color:var(--info)}
.badge-primary{background:rgba(99,102,241,.15);color:var(--accent-tertiary)}
.badge-neutral{background:var(--bg-hover);color:var(--text-secondary)}
.amount-income{color:var(--success);font-weight:600;font-family:var(--font-mono);font-size:.82rem}
.amount-expense{color:var(--error);font-weight:600;font-family:var(--font-mono);font-size:.82rem}
.tag-pill{display:inline-flex;align-items:center;gap:.2rem;padding:.12rem .45rem;font-size:.65rem;font-weight:500;border-radius:999px;background:rgba(99,102,241,.12);color:var(--accent-tertiary);margin-right:.15rem}

/* ─── Charts ─── */
.chart-bar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}
.chart-bar-label{width:130px;font-size:.75rem;color:var(--text-secondary);text-align:right;flex-shrink:0}
.chart-bar-fill-wrap{flex:1;height:20px;background:var(--bg-secondary);border-radius:6px;overflow:hidden}
.chart-bar-fill{height:100%;border-radius:6px;transition:width .5s ease;min-width:3px}
.chart-bar-value{width:100px;font-size:.75rem;font-weight:600;font-family:var(--font-mono);flex-shrink:0;text-align:right}
.trend-chart{padding:.5rem 0}.trend-bars{display:flex;gap:.35rem;align-items:flex-end;min-height:130px;padding-bottom:.5rem}
.trend-month{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}
.trend-bar-group{display:flex;gap:2px;align-items:flex-end;height:110px}
.trend-bar{width:11px;border-radius:3px 3px 0 0;min-height:2px;transition:height .5s ease}
.trend-bar.income{background:var(--success)}.trend-bar.expense{background:var(--error)}
.trend-label{font-size:.58rem;color:var(--text-muted);margin-top:.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.trend-legend{display:flex;gap:1.5rem;justify-content:center;margin-top:.75rem;font-size:.72rem;color:var(--text-secondary)}
.legend-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:.25rem;vertical-align:middle}
.legend-dot.income{background:var(--success)}.legend-dot.expense{background:var(--error)}

/* ─── Upcoming ─── */
.upcoming-item{display:flex;justify-content:space-between;align-items:center;padding:.55rem 0;border-bottom:1px solid var(--border-color);font-size:.82rem}
.upcoming-item:last-child{border-bottom:none}
.upcoming-item.urgent{background:rgba(239,68,68,.06);margin:0 -1.25rem;padding:.55rem 1.25rem;border-radius:var(--radius-md)}
.upcoming-left{display:flex;align-items:center;gap:.65rem}
.upcoming-days{width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;font-family:var(--font-mono);flex-shrink:0}
.upcoming-days.soon{background:rgba(239,68,68,.15);color:var(--error)}
.upcoming-days.normal{background:rgba(99,102,241,.12);color:var(--accent-tertiary)}
.upcoming-desc{font-weight:500}.upcoming-date{font-size:.72rem;color:var(--text-muted)}

/* ─── Invoices ─── */
.invoice-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}
.invoice-item{display:flex;align-items:center;justify-content:space-between;padding:.45rem .7rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8rem}
.invoice-info{display:flex;align-items:center;gap:.45rem}
.invoice-info i{color:var(--text-muted)}
.file-upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:all .2s}
.file-upload-area:hover{border-color:var(--accent-primary);color:var(--text-secondary)}
.file-upload-area i{font-size:1.3rem;margin-bottom:.4rem;display:block}

/* ─── Flash ─── */
.flash-container{margin-bottom:1rem}
.flash{padding:.65rem 1rem;border-radius:var(--radius-md);margin-bottom:.4rem;font-size:.82rem;display:flex;justify-content:space-between;align-items:center;animation:fadeIn .3s ease}
.flash-success{background:rgba(34,197,94,.12);color:var(--success);border:1px solid rgba(34,197,94,.25)}
.flash-error{background:rgba(239,68,68,.12);color:var(--error);border:1px solid rgba(239,68,68,.25)}
.flash-close{background:none;border:none;color:inherit;cursor:pointer;font-size:.85rem;padding:0 .3rem}

/* ─── Custom Confirm Modal ─── */
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s}
.confirm-overlay.show{opacity:1;pointer-events:auto}
.confirm-box{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem;width:90%;max-width:400px;text-align:center;box-shadow:var(--shadow-lg);transform:scale(.95);transition:transform .2s}
.confirm-overlay.show .confirm-box{transform:scale(1)}
.confirm-icon{font-size:2.5rem;margin-bottom:1rem}
.confirm-title{font-size:1.05rem;font-weight:600;margin-bottom:.5rem}
.confirm-msg{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.5rem}
.confirm-btns{display:flex;gap:.75rem;justify-content:center}

/* ─── Pagination ─── */
.pagination{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}

/* ─── Settings ─── */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.setting-item{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid var(--border-color);font-size:.82rem}
.setting-item:last-child{border-bottom:none}
.add-inline{display:flex;gap:.5rem;margin-top:.65rem}
.add-inline input{flex:1;padding:.35rem .65rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-family:var(--font-sans)}
.add-inline input:focus{outline:none;border-color:var(--accent-primary)}
.inline-form{display:inline-flex;gap:.25rem;align-items:center}
.cat-edit-input{background:transparent;border:1px solid transparent;color:var(--text-primary);padding:.2rem .4rem;border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--font-sans);width:100%}
.cat-edit-input:focus{border-color:var(--accent-primary);background:var(--bg-secondary);outline:none}
.license-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:1rem}
.license-meter{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}
.license-fill{height:100%;border-radius:3px;transition:width .3s}

/* ─── Auth ─── */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);width:100%}
.auth-container{width:100%;max-width:420px;padding:1rem}
.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem 2rem;box-shadow:var(--shadow-lg)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:var(--font-mono);font-size:1.3rem;font-weight:700;margin-bottom:2rem}
.auth-logo-icon{width:42px;height:42px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem}
.auth-card h2{text-align:center;margin-bottom:1.5rem;font-size:1.05rem}
.totp-secret{font-family:var(--font-mono);font-size:.82rem;padding:.7rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);word-break:break-all;margin:1rem 0;user-select:all}
.error-page{display:flex;align-items:center;justify-content:center;min-height:100vh;text-align:center;background:var(--bg-primary);width:100%}
.error-code{font-size:5rem;font-weight:800;font-family:var(--font-mono);color:var(--accent-primary)}
.error-msg{font-size:1.05rem;color:var(--text-secondary);margin:.5rem 0 2rem}

/* ─── Utilities ─── */
.flex-between{display:flex;justify-content:space-between;align-items:center}
.text-small{font-size:.75rem;color:var(--text-muted)}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem;gap:.65rem}
.empty-state-icon{width:52px;height:52px;background:var(--bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1.2rem}
.section-title{font-size:.85rem;font-weight:600;margin-bottom:.65rem;display:flex;align-items:center;gap:.45rem}
.section-title i{color:var(--text-muted)}
.filter-bar{display:flex;gap:.65rem;flex-wrap:wrap;align-items:flex-end}
.filter-bar .form-group{margin-bottom:0;flex:1;min-width:120px}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── Responsive ─── */
@media(max-width:1024px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.mobile-toggle{display:flex}
  .main{margin-left:0;padding:1rem;padding-top:3.5rem}
  .card-grid{grid-template-columns:1fr}.form-row,.form-row-3{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}
  .filter-bar .form-group{min-width:100%}.trend-bar{width:8px}.trend-bar-group{height:80px}
  table{font-size:.78rem}th,td{padding:.55rem .4rem}.stat-value{font-size:1.2rem}h1{font-size:1.2rem}
}
@media(max-width:480px){
  .main{padding:.75rem;padding-top:3rem}.card-body{padding:.9rem}.card-header{padding:.7rem .9rem}
  .type-toggle{flex-direction:column}.upcoming-item{flex-direction:column;align-items:flex-start;gap:.3rem}
}
