/*
Theme Name: Finanzportal SFA
Theme URI: https://securefinaccess.com
Author: SecureFinAccess
Description: SecureFinAccess Kundenportal (Dashboard, Dokumente, Profil, Auszahlung) mit einheitlichem Header/Footer, Modals, Admin-Portal und dynamischen Anlagen.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: finanzportal
*/

:root{
  --brand-700:#0b346e; --brand-600:#0d3d80;
  --bg:#f8fafc; --card:#ffffff; --text:#0f172a; --muted:#64748b; --border:#e5e7eb;
}

html, body { height:100%; }
body { margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif; background:var(--bg); color:var(--text); display:flex; min-height:100vh; flex-direction:column; }

.wrap, .wrap-page { max-width:1200px; margin:0 auto; padding:0 20px; }
.wrap-page { margin:18px auto; flex:1 0 auto; }

.card { background:var(--card); border:1px solid var(--border); border-radius:14px; padding:18px; margin-bottom:16px; box-shadow:0 8px 28px rgba(2,6,23,.08); }

button, .button, .btn, .wp-element-button, input[type=submit]{
  display:inline-block; padding:10px 14px; border-radius:12px; text-decoration:none;
  background:var(--brand-600); color:#fff; border:0; font-weight:600; cursor:pointer;
  box-shadow:0 4px 12px rgba(33,67,166,.25);
}
button:hover, .button:hover, .btn:hover, .wp-element-button:hover, input[type=submit]:hover{ filter:brightness(1.05); }

/* Header */
.site-header { background:linear-gradient(180deg,var(--brand-700),var(--brand-600)); color:#fff; position:sticky; top:0; z-index:100; }
.site-header .wrap { display:flex; align-items:center; gap:18px; padding:12px 20px; }
.custom-logo{ height:72px; width:auto; }
.site-title{ color:#fff; text-decoration:none; font-weight:700; display:flex; align-items:center; }
.sfa-burger{ display:none; background:transparent; border:0; font-size:22px; color:#fff; cursor:pointer; }
.primary-nav{ margin-left:auto; }
.menu--inline{ list-style:none; display:flex; gap:22px; margin:0; padding:0; }
.menu--inline a{ color:#fff; text-decoration:none; padding:6px 8px; border-radius:10px; }
.menu--inline a:hover, .menu--inline .current-menu-item>a{ background:rgba(255,255,255,.14); }

@media (max-width: 900px){
  .sfa-burger{ display:block; }
  #primary-nav{ display:none; position:absolute; right:12px; top:60px; background:var(--brand-700); border-radius:12px; padding:10px 12px; }
  #primary-nav.open{ display:block; }
  .menu--inline{ flex-direction:column; gap:8px; }
}

/* Footer */
.site-footer{ background:linear-gradient(180deg,var(--brand-700),var(--brand-600)); color:#e5e7eb; margin-top:auto; flex-shrink:0; }
.footer-bar{ display:flex; gap:12px; justify-content:space-between; flex-wrap:wrap; padding:14px 20px; }
.footer-bar .links a{ color:#ffffff; text-decoration:none; margin:0 6px; }
.footer-bar .links a:hover{ text-decoration:underline; }

/* Modals */
.sfa-modal{ position:fixed; inset:0; background:rgba(0,0,0,.6); display:none; z-index:9999; }
.sfa-modal-content{ background:#fff; color:var(--text); max-width:980px; margin:5% auto; padding:22px; border-radius:14px; max-height:85vh; overflow:auto; box-shadow:0 10px 30px rgba(0,0,0,.25); }
.sfa-modal h1{ margin-top:0; }
.sfa-close{ background:#eef2ff; border:0; border-radius:10px; padding:6px 10px; float:right; font-size:18px; cursor:pointer; }

/* Tables */
.table{ width:100%; border-collapse:separate; border-spacing:0; }
.table th{ font-weight:700; color:var(--muted); text-align:left; border-bottom:1px solid var(--border); padding:10px; }
.table td{ border-bottom:1px solid var(--border); padding:10px; }
h1.page-title{ font-size:1.6rem; margin:8px 0 16px; letter-spacing:.2px; }

/* Dokumente */
.doc-empty{display:flex;align-items:center;gap:14px;background:#f8fafc;border:1px dashed var(--border); border-radius:12px;padding:16px}
.doc-empty__icon{font-size:26px}
.doc-empty__title{font-weight:700}

/* Forms */
.sfa-form .sfa-section-title{margin:6px 0 10px;font-size:1.1rem;font-weight:700;color:var(--brand-700)}
.sfa-subcard{background:#f9fafb;border:1px solid var(--border);margin-top:8px}
.form-grid{display:grid;gap:20px}
.form-grid-2{grid-template-columns:1fr 1fr}
.form-field{display:flex;flex-direction:column}
.form-field--full{grid-column:1 / -1}
.sfa-form label{font-weight:600;margin-bottom:6px;color:var(--muted)}
.sfa-form input[type=text], .sfa-form input[type=date], .sfa-form input[type=number]{
  border:1px solid var(--border);border-radius:10px;padding:12px 14px;background:#fff;outline:none;font-size:16px
}
.sfa-form input:focus{border-color:#93c5fd;box-shadow:0 0 0 3px rgba(59,130,246,.25)}
.form-actions{margin-top:20px;display:flex;gap:10px;justify-content:flex-start}

/* Payout note */
.sfa-payout .sfa-hint{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;border-radius:10px;padding:10px 12px;margin-bottom:12px}
