/*
Theme Name: Factuportal
Theme URI: https://example.com/factuportal
Author: Factuportal
Description: Zakelijk factuurportaal (login-only) met factuuroverzicht, factuurdetail, Mollie iDEAL, uitstel en betalingsregeling.
Version: 42.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: factuportal
*/

:root{
  --fp-bg:#f4f6fb;
  --fp-card:#ffffff;
  --fp-text:#111827;
  --fp-muted:#6b7280;
  --fp-border:#e5e7eb;
  --fp-accent:#1d4ed8;
  --fp-accent2:#7c3aed;
  --fp-ok:#16a34a;
  --fp-bad:#dc2626;
  --fp-warn:#f59e0b;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:var(--fp-bg);
  color:var(--fp-text);
}
a{color:var(--fp-accent);text-decoration:none}
a:hover{text-decoration:underline}

.fp-topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--fp-border);
}
.fp-topbar-inner{
  max-width:1600px;margin:0 auto;padding:14px 18px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.fp-brand{display:flex;align-items:center;gap:10px}
.fp-logo{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--fp-accent),var(--fp-accent2));
}
.fp-title{font-weight:900;letter-spacing:.2px}
.fp-user{display:flex;align-items:center;gap:10px;color:var(--fp-muted);font-size:14px}

.fp-wrap{max-width:1600px;margin:0 auto;padding:22px 18px 60px}
.fp-card{
  background:var(--fp-card);
  border:1px solid var(--fp-border);
  border-radius:16px;
  box-shadow:0 12px 28px rgba(0,0,0,.07);
  padding:18px;
}
.fp-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:16px}
@media (max-width: 1000px){.fp-grid{grid-template-columns:1fr}}

.fp-h1{margin:0 0 12px 0;font-size:22px}
.fp-h2{margin:0 0 10px 0;font-size:18px}
.fp-muted{color:var(--fp-muted)}
.fp-hr{border:0;border-top:1px solid var(--fp-border);margin:14px 0}

.fp-button{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;border-radius:12px;
  border:1px solid var(--fp-border);
  background:#fff;color:var(--fp-text);
  cursor:pointer;
}
.fp-button:hover{background:#f9fafb;text-decoration:none}
.fp-button--primary{
  background:var(--fp-accent);
  border-color:rgba(29,78,216,.25);
  color:#fff;
}
.fp-button--primary:hover{filter:brightness(1.03)}
.fp-button--danger{background:#fff;border-color:rgba(220,38,38,.25);color:var(--fp-bad)}

.fp-table{width:100%;border-collapse:collapse}
.fp-table th,.fp-table td{padding:12px 10px;border-bottom:1px solid var(--fp-border);text-align:left;font-size:14px}
.fp-table th{color:var(--fp-muted);font-weight:800}
.fp-table tr:hover td{background:#fafafa}

.fp-badge{
  display:inline-flex;align-items:center;
  padding:4px 10px;border-radius:999px;font-size:12px;font-weight:800;
  border:1px solid var(--fp-border);color:var(--fp-muted);background:#fff;
}
.fp-badge--open{color:var(--fp-accent);border-color:rgba(29,78,216,.25);background:rgba(29,78,216,.06)}
.fp-badge--paid{color:var(--fp-ok);border-color:rgba(22,163,74,.25);background:rgba(22,163,74,.06)}
.fp-badge--overdue{color:var(--fp-bad);border-color:rgba(220,38,38,.25);background:rgba(220,38,38,.06)}
.fp-badge--regeling{color:var(--fp-accent2);border-color:rgba(124,58,237,.25);background:rgba(124,58,237,.06)}
.fp-badge--uitstel{color:var(--fp-warn);border-color:rgba(245,158,11,.28);background:rgba(245,158,11,.10)}

.fp-alert{padding:10px 12px;border-radius:14px;border:1px solid var(--fp-border);background:#fff;margin:0 0 12px 0}
.fp-alert--ok{border-color:rgba(22,163,74,.25);background:rgba(22,163,74,.06)}
.fp-alert--bad{border-color:rgba(220,38,38,.25);background:rgba(220,38,38,.06)}

.fp-form label{display:block;font-size:13px;color:var(--fp-muted);margin:10px 0 6px}
.fp-form input[type="text"], .fp-form input[type="number"], .fp-form input[type="date"], .fp-form select, .fp-form textarea, .fp-form input[type="password"]{
  width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--fp-border);
  background:#fff;color:var(--fp-text);outline:none;
}
.fp-form textarea{min-height:110px;resize:vertical}
.fp-form .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width: 640px){.fp-form .row{grid-template-columns:1fr}}
.fp-note{font-size:12px;color:var(--fp-muted);margin-top:6px}


/* Login page (Enterprise) */
.fp-login-wrap{
  min-height: calc(100vh - 120px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:46px 18px;
}
.fp-login-shell{
  width:min(980px, 100%);
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items:stretch;
}
@media (max-width: 980px){
  .fp-login-shell{grid-template-columns:1fr; width:min(520px, 100%);}
}
.fp-login-hero{
  border-radius:18px;
  border:1px solid var(--fp-border);
  background:
    radial-gradient(900px 380px at 20% 0%, rgba(29,78,216,.22), transparent 60%),
    radial-gradient(700px 420px at 80% 30%, rgba(124,58,237,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.86));
  box-shadow:0 18px 45px rgba(0,0,0,.10);
  padding:26px;
  position:relative;
  overflow:hidden;
}
.fp-login-hero:before{
  content:"";
  position:absolute; inset:-80px -120px auto auto;
  width:260px; height:260px;
  background:linear-gradient(135deg, rgba(29,78,216,.25), rgba(124,58,237,.25));
  filter:blur(18px);
  border-radius:999px;
}
.fp-login-hero h1{
  margin:0;
  font-size:26px;
  font-weight:950;
  letter-spacing:.2px;
}
.fp-login-hero p{margin:10px 0 0;color:var(--fp-muted);max-width:48ch;line-height:1.5}
.fp-login-meta{
  margin-top:18px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.fp-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.72);
  color:var(--fp-text);
  font-size:12px;
  font-weight:800;
}
.fp-dot{width:8px;height:8px;border-radius:999px;background:var(--fp-ok)}
.fp-lock{
  width:10px;height:10px;border-radius:3px;
  background:var(--fp-accent);
  box-shadow:0 6px 14px rgba(29,78,216,.25);
}
.fp-login-card{
  width:100%;
  background:var(--fp-card);
  border:1px solid var(--fp-border);
  border-radius:18px;
  box-shadow:0 18px 45px rgba(0,0,0,.10);
  padding:26px;
}
.fp-login-brandline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.fp-login-brand{display:flex;gap:12px;align-items:center}
.fp-login-mark{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,var(--fp-accent),var(--fp-accent2));
  box-shadow:0 8px 18px rgba(29,78,216,.25);
}
.fp-login-title{font-size:18px;font-weight:950;letter-spacing:.2px}
.fp-login-sub{font-size:13px;color:var(--fp-muted);margin-top:2px}
.fp-login-badge{
  font-size:12px;
  font-weight:900;
  color:var(--fp-accent);
  border:1px solid rgba(29,78,216,.22);
  background:rgba(29,78,216,.08);
  padding:6px 10px;
  border-radius:999px;
}
.fp-login-foot{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  font-size:13px;
  color:var(--fp-muted);
}


.fp-download-wrap{ margin-top: 14px; }
.fp-download-btn{
  display:block;
  width:100%;
  text-align:center;
  padding:12px 14px;
  border-radius:12px;
  font-weight:700;
  background: linear-gradient(135deg, #4f46e5, #2563eb);
  color:#fff;
  text-decoration:none;
  box-shadow: 0 10px 25px rgba(37, 99, 235, .18);
  transition: transform .15s ease, box-shadow .15s ease;
}
.fp-download-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(37, 99, 235, .25);
}

/* Dashboard improvements */
.fp-dashboard-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:20px;
    margin-top:30px;
}
.fp-card{
    background:#fff;
    padding:24px;
    border-radius:14px;
    box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.fp-download-wrap{
    margin-top:40px;
}

/* Corporate download button (right column, lower) */
.fp-download-wrap{ margin-top:18px; }
.fp-download-btn{
  display:block;
  width:100%;
  text-align:center;
  padding:12px 14px;
  border-radius:12px;
  font-weight:700;
  background:linear-gradient(135deg,#111827,#1f2937);
  color:#fff !important;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(17,24,39,.18);
}
.fp-download-btn:hover{
  filter:brightness(1.05);
  transform:translateY(-1px);
}


.fp-download-wrap{ margin-top:22px; }
.fp-download-btn{
  display:block; width:100%; text-align:center; padding:12px 14px;
  border-radius:12px; font-weight:700;
  background:linear-gradient(135deg,#111827,#1f2937);
  color:#fff !important; text-decoration:none;
  border:1px solid rgba(255,255,255,.08); box-shadow:0 10px 24px rgba(17,24,39,.18);
}
.fp-download-btn:hover{ filter:brightness(1.05); text-decoration:none; }
