/* ============================================
   VersicherungsVault – assets/css/app.css
   ============================================ */

:root {
  --bg: #0e0f13;
  --surface: #16181f;
  --surface2: #1e2029;
  --border: #2a2d38;
  --accent: #c8a96e;
  --accent2: #e8c989;
  --text: #e8e6e1;
  --muted: #888b99;
  --danger: #e05252;
  --success: #52c07a;
  --warn: #e0a052;
  --info: #527ae0;
}

*,*::before,*::after { margin:0;padding:0;box-sizing:border-box; }

body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
}

body::before {
  content:'';
  position:fixed;inset:0;
  background: radial-gradient(ellipse at 20% 20%,rgba(200,169,110,.05) 0%,transparent 60%),
              radial-gradient(ellipse at 80% 80%,rgba(82,122,224,.04) 0%,transparent 60%);
  pointer-events:none;z-index:0;
}

a { text-decoration:none;color:inherit; }

/* ---- SIDEBAR ---- */
.sidebar {
  position:fixed;left:0;top:0;bottom:0;width:260px;
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;z-index:100;transition:transform .3s ease;
}
.logo { padding:28px 24px 20px;border-bottom:1px solid var(--border); }
.logo-title { font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--accent);letter-spacing:.02em; }
.logo-sub { font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.15em;margin-top:2px; }

.nav { flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto; }
.nav-item {
  display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;
  cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500;color:var(--muted);border:1px solid transparent;
}
.nav-item:hover { background:var(--surface2);color:var(--text); }
.nav-item.active { background:linear-gradient(135deg,rgba(200,169,110,.15),rgba(200,169,110,.05));color:var(--accent);border-color:rgba(200,169,110,.2); }
.nav-icon { font-size:1.1rem;width:22px;text-align:center; }
.nav-section-label { font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:12px 14px 4px;opacity:.6; }

.sidebar-footer { padding:16px;border-top:1px solid var(--border); }
.sidebar-user { display:flex;align-items:center;gap:10px; }
.user-avatar { width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#8b6a2a);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:#1a1200;flex-shrink:0; }
.user-name { font-size:.85rem;font-weight:600; }
.user-logout { font-size:.75rem;color:var(--muted);transition:color .2s; }
.user-logout:hover { color:var(--danger); }

/* ---- MAIN ---- */
.main { margin-left:260px;min-height:100vh;position:relative;z-index:1; }

.topbar {
  position:sticky;top:0;background:rgba(14,15,19,.85);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);padding:16px 32px;
  display:flex;align-items:center;justify-content:space-between;z-index:50;
}
.page-title { font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600; }
.topbar-actions { display:flex;gap:12px;align-items:center; }

.content { padding:32px; }

/* ---- BUTTONS ---- */
.btn {
  padding:9px 18px;border-radius:8px;border:none;cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:.875rem;font-weight:600;
  transition:all .2s;display:inline-flex;align-items:center;gap:6px;
}
.btn-primary { background:linear-gradient(135deg,var(--accent),#b8953a);color:#1a1200; }
.btn-primary:hover { transform:translateY(-1px);box-shadow:0 4px 16px rgba(200,169,110,.3); }
.btn-ghost { background:transparent;color:var(--muted);border:1px solid var(--border); }
.btn-ghost:hover { color:var(--text);border-color:var(--muted); }
.btn-danger { background:rgba(224,82,82,.15);color:var(--danger);border:1px solid rgba(224,82,82,.3); }
.btn-danger:hover { background:rgba(224,82,82,.25); }
.btn-sm { font-size:.78rem;padding:6px 12px; }

/* ---- STATS GRID ---- */
.stats-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px; }
.stat-card { background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;position:relative;overflow:hidden;transition:border-color .2s; }
.stat-card::before { content:'';position:absolute;top:0;right:0;width:80px;height:80px;border-radius:50%;opacity:.06; }
.stat-card.gold::before { background:var(--accent); }
.stat-card.blue::before { background:var(--info); }
.stat-card.green::before { background:var(--success); }
.stat-card.warn::before { background:var(--warn); }
.stat-icon { font-size:1.4rem;margin-bottom:12px;display:block; }
.stat-value { font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700; }
.stat-label { font-size:.8rem;color:var(--muted);margin-top:4px; }

/* ---- FILTERS ---- */
.contracts-header { display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px; }
.search-bar { display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px;flex:1;max-width:340px; }
.search-bar input { border:none;background:transparent;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.875rem;outline:none;flex:1; }
.search-bar input::placeholder { color:var(--muted); }
.filter-tabs { display:flex;gap:6px;flex-wrap:wrap; }
.filter-tab { padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:500;transition:all .2s; }
.filter-tab:hover,.filter-tab.active { background:rgba(200,169,110,.12);color:var(--accent);border-color:rgba(200,169,110,.3); }

/* ---- CONTRACT CARDS ---- */
.contracts-list { display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px; }
.contract-card { background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;transition:all .2s;position:relative;overflow:hidden; }
.contract-card::after { content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px; }
.contract-card.type-kfz::after         { background:var(--info); }
.contract-card.type-haftpflicht::after { background:var(--success); }
.contract-card.type-gesundheit::after  { background:var(--danger); }
.contract-card.type-leben::after       { background:var(--accent); }
.contract-card.type-hausrat::after     { background:var(--warn); }
.contract-card.type-reise::after       { background:#a052e0; }
.contract-card.type-sonstige::after    { background:var(--muted); }
.contract-card:hover { border-color:rgba(200,169,110,.3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3); }

.card-header { display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px; }
.card-type-badge { display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:3px 10px;border-radius:20px;margin-bottom:8px; }
.badge-kfz         { background:rgba(82,122,224,.15);color:var(--info); }
.badge-haftpflicht { background:rgba(82,192,122,.15);color:var(--success); }
.badge-gesundheit  { background:rgba(224,82,82,.15);color:var(--danger); }
.badge-leben       { background:rgba(200,169,110,.15);color:var(--accent); }
.badge-hausrat     { background:rgba(224,160,82,.15);color:var(--warn); }
.badge-reise       { background:rgba(160,82,224,.15);color:#a052e0; }
.badge-sonstige    { background:rgba(136,139,153,.15);color:var(--muted); }

.status-dot { width:8px;height:8px;border-radius:50%;margin-top:3px;flex-shrink:0; }
.status-dot.active   { background:var(--success);box-shadow:0 0 6px var(--success); }
.status-dot.expiring { background:var(--warn);box-shadow:0 0 6px var(--warn); }
.status-dot.expired  { background:var(--danger); }
.status-dot.inactive { background:var(--muted); }

.card-name    { font-weight:600;font-size:1rem;margin-bottom:2px; }
.card-insurer { font-size:.82rem;color:var(--muted); }

.card-details { display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border); }
.detail-label { font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px; }
.detail-value { font-size:.9rem;font-weight:500; }

.card-actions { display:flex;gap:8px;margin-top:14px; }

/* ---- FORM ---- */
.form-card { background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:32px;max-width:700px; }
.form-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.form-grid .full { grid-column:1/-1; }
.form-group { display:flex;flex-direction:column;gap:6px; }
.form-section-title { font-family:'Playfair Display',serif;font-size:1rem;color:var(--accent);padding:12px 0 4px;border-top:1px solid var(--border);margin-top:8px;grid-column:1/-1; }

label { font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em; }
input,select,textarea {
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:10px 14px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.9rem;outline:none;transition:border-color .2s;
}
input:focus,select:focus,textarea:focus { border-color:var(--accent); }
select option { background:var(--surface); }
textarea { resize:vertical;min-height:80px; }

.form-actions { display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border); }

.error-box { background:rgba(224,82,82,.12);border:1px solid rgba(224,82,82,.3);border-radius:8px;padding:12px 16px;font-size:.875rem;color:var(--danger);margin-bottom:16px; }
.success-box { background:rgba(82,192,122,.12);border:1px solid rgba(82,192,122,.3);border-radius:8px;padding:12px 16px;font-size:.875rem;color:var(--success);margin-bottom:16px; }

/* ---- CALENDAR ---- */
.calendar-list { display:flex;flex-direction:column;gap:10px; }
.calendar-item { display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 18px;transition:border-color .2s; }
.calendar-item:hover { border-color:rgba(200,169,110,.3); }
.calendar-date { text-align:center;min-width:48px;background:var(--surface2);border-radius:8px;padding:8px; }
.calendar-date-day { font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;line-height:1;color:var(--accent); }
.calendar-date-month { font-size:.65rem;text-transform:uppercase;color:var(--muted);letter-spacing:.1em;margin-top:2px; }
.days-remaining { margin-left:auto;font-size:.82rem;font-weight:600; }

/* ---- DETAIL VIEW ---- */
.detail-section { background:var(--surface2);border-radius:12px;padding:20px;margin-bottom:16px; }
.detail-section-title { font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:14px;font-weight:600; }
.detail-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px; }

/* ---- DOCUMENTS ---- */
.doc-list { display:flex;flex-direction:column;gap:8px;margin-top:12px; }
.doc-item { display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px; }
.doc-icon { font-size:1.2rem; }
.doc-name { flex:1;font-size:.875rem;font-weight:500; }
.doc-size { font-size:.75rem;color:var(--muted); }

/* ---- TOAST ---- */
.toast { position:fixed;bottom:24px;right:24px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 18px;font-size:.875rem;z-index:300;transform:translateY(80px);transition:transform .3s ease;display:flex;align-items:center;gap:8px; }
.toast.show { transform:translateY(0); }
.toast.success { border-color:rgba(82,192,122,.4); }
.toast.error { border-color:rgba(224,82,82,.4); }

/* ---- SECTION TITLE ---- */
.section-title { font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:10px; }
.section-title::after { content:'';flex:1;height:1px;background:var(--border); }

/* ---- EMPTY STATE ---- */
.empty-state { text-align:center;padding:60px 20px;color:var(--muted); }
.empty-state .emoji { font-size:3rem;margin-bottom:16px;display:block; }
.empty-state p { font-size:1rem;margin-bottom:20px; }

/* ---- AUTH PAGES ---- */
.auth-page { min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px; }
.auth-card { background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px;width:100%;max-width:420px; }
.auth-logo { font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--accent);margin-bottom:6px; }
.auth-subtitle { font-size:.85rem;color:var(--muted);margin-bottom:28px; }

/* ---- BADGE ---- */
.badge { display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:.72rem;font-weight:600; }

/* ---- TABLE ---- */
.table-wrap { overflow-x:auto; }
table { width:100%;border-collapse:collapse;font-size:.875rem; }
th { text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--border); }
td { padding:12px;border-bottom:1px solid rgba(42,45,56,.5);vertical-align:middle; }
tr:hover td { background:var(--surface2); }

/* ---- RESPONSIVE ---- */
.mobile-menu-btn { display:none;background:transparent;border:none;color:var(--text);font-size:1.3rem;cursor:pointer;padding:4px; }
.overlay-bg { display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99; }
.overlay-bg.active { display:block; }

@media(max-width:768px) {
  .sidebar { transform:translateX(-260px); }
  .sidebar.open { transform:translateX(0); }
  .main { margin-left:0; }
  .content { padding:20px; }
  .contracts-list { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .form-grid .full { grid-column:1; }
  .topbar { padding:14px 20px; }
  .mobile-menu-btn { display:flex; }
  .form-card { padding:20px; }
}

@keyframes fadeIn { from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)} }
.fade-in { animation:fadeIn .3s ease; }
