@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

*{box-sizing:border-box}
:root{
  --bg:#f6f8fb;
  --card:#ffffff;
  --ink:#0f172a;
  --ink-2:#1e293b;
  --muted:#64748b;
  --line:#e6e9ef;
  --accent:#2abd87;
  --accent-dark:#079669;
  --accent-soft:#e7f8f0;
  --soft:#f1f4f8;
}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:26px 18px 46px}

/* Brand bar with NEXD Media logo (matches luqqo.nl light header) */
.brandbar{display:flex;align-items:center;justify-content:flex-start;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:12px 20px;margin-bottom:16px;box-shadow:0 4px 16px rgba(15,23,42,.04)}
.brandlogo{height:32px;max-height:32px;width:auto;display:block}
.brandname{font-size:36px;line-height:1;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brandbar .tagline{color:var(--muted);font-weight:700;font-size:13px;letter-spacing:.01em}

/* Hero: light, dark heading with green highlight (like luqqo.nl) */
.hero{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:20px;padding:34px;border-radius:24px;background:linear-gradient(180deg,#ffffff,#f2f7fb);border:1px solid var(--line);color:var(--ink);box-shadow:0 10px 30px rgba(15,23,42,.05)}
.eyebrow{display:inline-block;background:var(--accent);color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:12px;border-radius:999px;padding:7px 13px;margin:0 0 14px}
h1{font-size:44px;line-height:1.04;margin:0 0 12px;letter-spacing:-.03em;font-weight:800;color:var(--ink)}
.hl{color:var(--accent-dark)}
h2{margin-top:0;font-size:23px;letter-spacing:-.02em;font-weight:800;color:var(--ink)}
h3{margin:0 0 12px;font-size:18px;font-weight:800}
.hero p{color:var(--muted);max-width:760px}
.hero a{color:var(--accent-dark);font-weight:700}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;margin-bottom:18px;box-shadow:0 8px 24px rgba(15,23,42,.05)}
.loginbox{background:var(--soft);border:1px solid var(--line);border-radius:20px;padding:20px;margin-bottom:18px}

label{display:block;font-weight:700;margin:14px 0 6px;font-size:14px}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid #d4dae3;border-radius:12px;background:#fff;color:var(--ink);font:inherit;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(42,189,135,.2)}
textarea{resize:vertical}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.check{display:flex;align-items:center;gap:10px;font-weight:700;margin:11px 0}
.check input{width:auto;accent-color:var(--accent)}

.button,button{display:inline-block;border:0;background:var(--accent);color:#fff;border-radius:999px;padding:12px 20px;font-weight:700;text-decoration:none;cursor:pointer;margin-top:14px;box-shadow:0 8px 20px rgba(42,189,135,.28);transition:transform .12s,background .15s}
.button:hover,button:hover{transform:translateY(-1px);background:var(--accent-dark)}
.secondary{background:#fff!important;color:var(--accent-dark)!important;border:1px solid var(--accent)!important;box-shadow:none!important}
.secondary:hover{background:var(--accent-soft)!important;color:var(--accent-dark)!important}
.button:focus-visible,button:focus-visible,a:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
button:disabled{opacity:.65;cursor:wait;transform:none}

a{color:var(--accent-dark);font-weight:600}
a:hover{text-decoration:underline}

.success{background:var(--accent-soft);border:1px solid var(--accent);color:#06694a;padding:11px 14px;border-radius:12px;font-weight:600}
.error{background:#fef2f2;border:1px solid #ef4444;color:#991b1b;padding:11px 14px;border-radius:12px;font-weight:600}
.hint{font-size:13px;color:var(--muted);margin-top:6px}
.modulebox{margin-top:18px;padding:16px;border:1px dashed #cdd5e0;border-radius:16px;background:var(--soft)}
code,pre{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:10px;display:block;overflow:auto;font-size:13px}

table{border-collapse:collapse;width:100%;font-size:13px}
th,td{border:1px solid var(--line);padding:9px 10px;text-align:left;vertical-align:top}
th{background:var(--soft);color:var(--ink);font-weight:700;border-bottom:2px solid var(--accent)}
tbody tr:nth-child(even) td{background:#fafbfd}

.progressbox{margin-top:14px;background:var(--accent-soft);border:1px solid #a9e6cd;border-radius:16px;padding:14px}
.progressbox p{margin:6px 0 10px;color:var(--muted)}
.bar{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden}
.bar span{display:block;height:100%;width:45%;background:var(--accent);border-radius:999px;animation:loadmove 1.2s infinite alternate}
@keyframes loadmove{from{margin-left:0;width:25%}to{margin-left:60%;width:40%}}

@media(max-width:800px){
  .grid,.hero{grid-template-columns:1fr;display:block}
  .two{grid-template-columns:1fr}
  h1{font-size:32px}
  .brandbar{flex-wrap:wrap}
}

.actionbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:18px 0 26px}
.actionbar .button{margin-top:0}

.domain-heading{margin-top:34px;margin-bottom:12px;padding:14px 18px;border-radius:14px;background:var(--soft);border:1px solid var(--line);border-left:5px solid var(--accent);color:var(--ink);font-size:20px;font-weight:800}
.domain-heading strong{color:var(--accent-dark);font-weight:800}

.statuslist{display:flex;flex-direction:column;gap:10px;margin:8px 0 6px}
.statusrow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--soft);font-weight:700}
.badge{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;font-weight:800;font-size:13px;letter-spacing:.03em;text-transform:uppercase}
.badge::before{content:"";width:9px;height:9px;border-radius:50%;background:currentColor}
.badge.ok{background:var(--accent-soft);color:var(--accent-dark);border:1px solid var(--accent)}
.badge.bad{background:#fef2f2;color:#b91c1c;border:1px solid #ef4444}

/* ============================================================
   Concurrentie Analyse module (competitors.php) — v2.6
   Reuses the existing tokens: --accent, --line, --soft, --muted,
   --card, --accent-soft. No existing rule is modified.
   ============================================================ */

.sub{margin:0 0 6px}

/* Tabbed interface */
.tabs{margin-top:18px}
.tabnav{display:flex;flex-wrap:wrap;gap:8px;border-bottom:2px solid var(--line);padding-bottom:0;margin-bottom:18px}
.tabnav .tab{margin:0;background:var(--soft);color:var(--ink-2);border:1px solid var(--line);border-bottom:none;border-radius:12px 12px 0 0;padding:10px 16px;font-weight:700;font-size:14px;box-shadow:none;cursor:pointer;transform:none;position:relative;top:2px}
.tabnav .tab:hover{background:var(--accent-soft);color:var(--accent-dark);transform:none}
.tabnav .tab.active{background:var(--card);color:var(--accent-dark);border-color:var(--line);border-bottom:2px solid var(--card);box-shadow:0 -3px 10px rgba(15,23,42,.04)}
.tabnav .tab.active::after{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--accent);border-radius:3px 3px 0 0}
.tabpanel{display:none;animation:fadein .18s ease}
.tabpanel.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* Scrollable wrappers for large tables */
.tablewrap{width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:14px;margin-top:6px}
.tablewrap table{border:0;border-radius:14px;overflow:hidden}
.tablewrap th,.tablewrap td{border-left:0;border-right:0}
.tablewrap td a{word-break:break-all}

/* Score pills */
.scorepill{display:inline-block;min-width:34px;text-align:center;padding:3px 9px;border-radius:999px;font-weight:800;font-size:12px;color:#fff;background:var(--muted)}
.scorepill.hi{background:#ef4444}
.scorepill.mid{background:#f59e0b}
.scorepill.lo{background:var(--accent)}

/* Term type label */
.termtype{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:700;background:var(--accent-soft);color:#06694a;border:1px solid #a9e6cd;white-space:nowrap}

/* Recommendation cards */
.reccard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;margin-bottom:14px;box-shadow:0 6px 18px rgba(15,23,42,.04)}
.rechead{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px}
.rechead h3{margin:0;font-size:17px}
.problem{display:inline-block;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:800;text-transform:capitalize}
.problem-content{background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe}
.problem-autoriteit{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}
.problem-techniek{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}

/* Score bars in recommendation cards */
.scorebars{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-top:8px}
.scorebar{display:flex;flex-direction:column;gap:5px}
.scorebar-lbl{font-size:12px;color:var(--muted);font-weight:700;display:flex;justify-content:space-between;gap:8px}
.scorebar-lbl strong{color:var(--ink)}
.scorebar-track{display:block;height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}
.scorebar-track span{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s}

@media(max-width:800px){
  .scorebars{grid-template-columns:1fr}
  .tabnav{gap:4px}
  .tabnav .tab{padding:9px 11px;font-size:13px}
}

/* Brandbar: titel + tagline netjes naast het logo (v2.6.2) */
.brandbar .brandtitle{display:flex;flex-direction:column;line-height:1.05;gap:2px}
.brandbar .brandtitle .brandname{font-size:26px}
.brandbar .brandtitle .tagline{font-size:13px}
