/* 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}

/* 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)}
