/* Minimal accessible base styles. Colours come from per-instance CSS vars
   injected in <head> (--color-primary etc.). WCAG-conscious defaults. */
*,*::before,*::after{box-sizing:border-box}
html{font-size:16px}
body{margin:0;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--color-text,#1a1a1a);background:#f4f6f9;line-height:1.5}
.container{max-width:960px;margin:0 auto;padding:0 1rem}
a{color:var(--color-primary,#0b4a8f)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--color-primary);
  color:var(--color-primary-contrast);padding:.5rem 1rem;z-index:100}
.skip-link:focus{left:0}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
:focus-visible{outline:3px solid var(--color-accent,#c8102e);outline-offset:2px}

.site-header{background:var(--color-primary,#0b4a8f);color:var(--color-primary-contrast,#fff)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}
.brand{display:flex;align-items:center;gap:.6rem;color:inherit;text-decoration:none;font-weight:600}
.lang-nav select{padding:.3rem}

.site-footer{margin-top:3rem;padding:1.5rem 0;background:#e9edf2;color:#333;font-size:.9rem}

.hero{padding:2rem 0}
.hero h1{color:var(--color-primary,#0b4a8f)}
.lead{font-size:1.15rem}
.choice-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:1.5rem}
.choice-card{display:block;padding:1.25rem;background:var(--color-surface,#fff);border:1px solid #d4dae2;
  border-radius:10px;text-decoration:none;color:inherit}
.choice-card:hover,.choice-card:focus{border-color:var(--color-primary);box-shadow:0 2px 10px rgba(0,0,0,.08)}
.choice-card h2{margin-top:0;color:var(--color-primary,#0b4a8f);font-size:1.15rem}

.auth-card{max-width:420px;margin:2rem auto;padding:1.5rem;background:#fff;border-radius:10px;border:1px solid #d4dae2}
.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.3rem}
.field input{padding:.6rem;border:1px solid #b9c2cc;border-radius:6px;font-size:1rem}
.btn{display:inline-block;padding:.6rem 1.2rem;border:0;border-radius:6px;font-size:1rem;cursor:pointer}
.btn-primary{background:var(--color-primary,#0b4a8f);color:var(--color-primary-contrast,#fff)}

.alert{padding:.75rem 1rem;border-radius:6px;margin:.5rem 0}
.alert-error{background:#fde8e8;color:#8a1c1c;border:1px solid #f5b5b5}
.alert-success{background:#e7f6ec;color:#1c5b2e;border:1px solid #aee0bf}

/* Alpine: hide until initialised (nav buttons only — panels stay visible w/o JS) */
[x-cloak]{display:none !important}

/* Wizard */
.wizard{max-width:720px;margin:0 auto}
.wizard-steps{display:flex;gap:.5rem;list-style:none;padding:0;margin:1rem 0;flex-wrap:wrap}
.wizard-steps li{padding:.3rem .7rem;border-radius:999px;background:#e3e8ef;color:#566;font-size:.85rem}
.wizard-steps li.active{background:var(--color-primary,#0b4a8f);color:var(--color-primary-contrast,#fff)}
.wizard-panel{border:1px solid #d4dae2;border-radius:10px;padding:1.25rem;margin:1rem 0;background:#fff}
.wizard-panel legend{font-weight:600;color:var(--color-primary,#0b4a8f);padding:0 .4rem}
.wizard-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1rem}
.field-row{display:flex;gap:1rem;flex-wrap:wrap}
.field-row .field{flex:1;min-width:160px}
.field select,.field textarea,.field input[type=text],.field input[type=date],.field input[type=password]{
  padding:.55rem;border:1px solid #b9c2cc;border-radius:6px;font-size:1rem;width:100%}
.field-checkbox{flex-direction:row;align-items:flex-start;gap:.5rem}
.hint{font-size:.85rem;color:#566}
.errorlist{color:#8a1c1c;list-style:none;padding:0;margin:.25rem 0;font-size:.9rem}

/* Tracking */
.credentials dt{font-weight:600;margin-top:.5rem}
.credentials code{font-size:1.1rem;background:#f0f3f7;padding:.2rem .4rem;border-radius:4px}
.success-card{max-width:560px}
.status-panel{background:#fff;border:1px solid #d4dae2;border-radius:10px;padding:1rem 1.25rem}
.thread{list-style:none;padding:0}
.thread .msg{padding:.6rem .9rem;border-radius:8px;margin:.5rem 0;background:#f0f3f7}
.thread .msg-staff{background:#e7f6ec}
.msg-meta{font-size:.8rem;color:#566;display:block}

/* My reports */
.header-inline{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.data-table{width:100%;border-collapse:collapse;margin:1rem 0;background:#fff}
.data-table th,.data-table td{padding:.6rem .75rem;border-bottom:1px solid #e1e6ec;text-align:left}
.data-table th{background:#eef2f7}

/* Back-office */
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin:1rem 0;padding:.75rem;background:#fff;border:1px solid #d4dae2;border-radius:8px}
.filter-bar input,.filter-bar select{padding:.45rem;border:1px solid #b9c2cc;border-radius:6px}
.badge{display:inline-block;font-size:.8rem;padding:.2rem .6rem;border-radius:999px;background:#e3e8ef;color:#33414f;vertical-align:middle}
.case-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}
.case-main,.case-side{background:#fff;border:1px solid #d4dae2;border-radius:10px;padding:1.25rem}
.case-side form{margin:.75rem 0;display:flex;flex-direction:column;gap:.4rem}
.report-body{white-space:pre-wrap;background:#f7f9fb;padding:.75rem;border-radius:6px}
@media (max-width:760px){.case-grid{grid-template-columns:1fr}}

/* Deadline traffic lights */
.deadline{display:inline-block;padding:.15rem .5rem;border-radius:6px;font-variant-numeric:tabular-nums}
.deadline-ok{background:#e7f6ec;color:#1c5b2e}
.deadline-warn{background:#fff3cd;color:#8a5a00}
.deadline-overdue{background:#fde8e8;color:#8a1c1c;font-weight:600}
.deadline-none{color:#889}

/* Session timeout warning */
.session-warning{position:fixed;bottom:1rem;right:1rem;max-width:320px;background:#fff;border:2px solid var(--color-accent,#c8102e);
  border-radius:10px;padding:1rem;box-shadow:0 4px 20px rgba(0,0,0,.18);z-index:200}

/* ── Marketing landing page ─────────────────────────────────────────── */
main.landing{padding:0}
.btn-lg{padding:.85rem 1.6rem;font-size:1.05rem;font-weight:600}
.btn-ghost{background:transparent;color:var(--color-primary-contrast,#fff);border:2px solid currentColor}
.btn-ghost:hover,.btn-ghost:focus{background:rgba(255,255,255,.14)}
.lp-section{padding:3.5rem 0}
.lp-section h2{font-size:clamp(1.4rem,3vw,2rem);color:var(--color-primary,#0b4a8f);text-align:center;margin:0 0 2rem}
.lp-narrow{max-width:760px}
.lp-prose{font-size:1.1rem;color:#3a4654;text-align:center;line-height:1.65}

/* Hero */
.lp-hero{background:linear-gradient(135deg,var(--color-primary,#0b4a8f),#072f5c);
  color:var(--color-primary-contrast,#fff);padding:4.5rem 0 4rem;text-align:center}
.lp-hero-inner{max-width:820px}
.lp-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:700;
  opacity:.85;margin:0 0 1rem}
.lp-hero h1{color:#fff;font-size:clamp(1.8rem,4.5vw,3rem);line-height:1.15;margin:0 0 1.25rem}
.lp-lead{font-size:clamp(1.05rem,2.2vw,1.3rem);line-height:1.55;opacity:.95;margin:0 auto 2rem;max-width:680px}
.lp-cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.lp-trust{margin-top:1.75rem;font-size:.9rem;opacity:.8}

/* Feature grid */
.lp-features{background:#fff}
.lp-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.lp-card{padding:1.6rem;border:1px solid #e1e6ec;border-radius:14px;background:#fdfefe}
.lp-card h3{margin:.9rem 0 .5rem;color:var(--color-primary,#0b4a8f);font-size:1.15rem}
.lp-card p{margin:0;color:#46535f;font-size:.97rem;line-height:1.55}
.lp-ico{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;
  border-radius:12px;background:color-mix(in srgb,var(--color-primary,#0b4a8f) 12%,#fff);
  color:var(--color-primary,#0b4a8f)}
.lp-ico svg{width:26px;height:26px;stroke-linecap:round;stroke-linejoin:round}

/* How it works */
.lp-steps-wrap{background:#f4f6f9}
.lp-steps{list-style:none;padding:0;margin:0;display:grid;gap:1.5rem;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));counter-reset:step}
.lp-steps li{position:relative;padding:1.4rem;background:#fff;border-radius:14px;border:1px solid #e1e6ec}
.lp-step-n{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;
  border-radius:50%;background:var(--color-primary,#0b4a8f);color:var(--color-primary-contrast,#fff);
  font-weight:700;font-size:1.05rem}
.lp-steps h3{margin:.8rem 0 .4rem;color:var(--color-primary,#0b4a8f);font-size:1.1rem}
.lp-steps p{margin:0;color:#46535f;font-size:.95rem;line-height:1.55}

/* Compliance */
.lp-compliance{background:#fff}
.lp-split{display:grid;gap:2.5rem;grid-template-columns:1.3fr 1fr;align-items:start}
.lp-split h2{text-align:left;margin-top:0}
.lp-check{list-style:none;padding:0;margin:0;display:grid;gap:.9rem}
.lp-check li{position:relative;padding-left:2rem;color:#3a4654;line-height:1.55}
.lp-check li::before{content:"";position:absolute;left:0;top:.15rem;width:1.25rem;height:1.25rem;
  border-radius:50%;background:var(--color-primary,#0b4a8f);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.lp-aside{background:#f4f6f9;border:1px solid #e1e6ec;border-radius:14px;padding:1.6rem}
.lp-aside h3{margin-top:0;color:var(--color-primary,#0b4a8f)}
.lp-aside p{color:#46535f;line-height:1.55}

/* Final CTA */
.lp-finalcta{background:linear-gradient(135deg,#072f5c,var(--color-primary,#0b4a8f));
  color:#fff;text-align:center;padding:3.5rem 0}
.lp-finalcta h2{color:#fff;font-size:clamp(1.4rem,3vw,2rem);margin:0 0 .75rem}
.lp-finalcta p{margin:0 0 1.75rem;opacity:.92;font-size:1.05rem}

@media (max-width:760px){.lp-split{grid-template-columns:1fr}}

/* Statistics */
.dash-actions{display:flex;gap:.5rem;flex-wrap:wrap}
.export-links{display:flex;gap:.5rem}
.stat-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin:1rem 0}
.stat-card{background:#fff;border:1px solid #d4dae2;border-radius:10px;padding:1rem;text-align:center}
.stat-num{display:block;font-size:1.8rem;font-weight:700;color:var(--color-primary,#0b4a8f)}
