/* FPG Critical Control Self-Check — shared styles.
   Palette and type mirror the InDesign rebrand used in the prototype. */

@font-face{font-family:'Kapra Neue';src:url("../fonts/KapraNeue-BoldExpanded.aaf144b2065c.otf") format('opentype');font-weight:700;font-display:swap;}
@font-face{font-family:'FS Albert';src:url("../fonts/FSAlbert.92f1a5ede710.otf") format('opentype');font-weight:400;font-display:swap;}
@font-face{font-family:'FS Albert';src:url("../fonts/FSAlbert-Bold.3026e0236e0a.otf") format('opentype');font-weight:700;font-display:swap;}
@font-face{font-family:'Aeonik';src:url("../fonts/aeonik-regular.64a57ec99afa.otf") format('opentype');font-weight:400;font-display:swap;}
@font-face{font-family:'Quickbrush';src:url("../fonts/Quickbrush.2602e73ad585.otf") format('opentype');font-weight:400;font-display:swap;}

:root{
  --green:#088840; --green-dark:#15351f; --ink:#23301d; --muted:#54624c;
  --bg:#f3f6ee; --line:#dce4d4; --card:#ffffff; --red:#c0392b;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:'FS Albert',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:var(--green);}

.eyebrow{font-family:'FS Albert',sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green);}
h1,h2,h3{font-family:'Kapra Neue',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.005em;color:var(--green-dark);}

/* ── Site header ─────────────────────────────────────────── */
.site-header{background:#fff;border-bottom:4px solid var(--green);padding:18px 24px;}
.site-header .inner{max-width:1020px;margin:0 auto;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.site-header img{height:40px;width:auto;display:block;}
.site-header .title{flex:1;min-width:200px;font-family:'Kapra Neue',sans-serif;font-size:18px;text-transform:uppercase;color:var(--green-dark);}
.site-header nav{display:flex;gap:14px;align-items:center;font-size:13px;}
.site-header nav .who{color:var(--muted);}
.script{font-family:'Quickbrush',cursive;font-size:26px;color:var(--green);white-space:nowrap;}

/* ── Auth card ───────────────────────────────────────────── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 18px;}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 50px rgba(20,53,31,.08);width:100%;max-width:440px;padding:34px 32px;}
.auth-card .brand{display:flex;align-items:center;gap:12px;margin-bottom:22px;}
.auth-card .brand img{height:38px;}
.auth-card h1{font-size:23px;margin:0 0 4px;}
.auth-card .sub{color:var(--muted);font-size:13.5px;margin:0 0 22px;}

.field{margin-bottom:15px;}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em;}
.form-input{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font-size:14.5px;font-family:'FS Albert',sans-serif;color:var(--ink);background:#fff;}
.form-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(8,136,64,.12);}
.row-2{display:flex;gap:12px;}
.row-2 .field{flex:1;}

.btn{display:inline-block;width:100%;text-align:center;font-family:'FS Albert',sans-serif;font-weight:700;font-size:14.5px;border:none;border-radius:10px;padding:12px 18px;cursor:pointer;background:var(--green);color:#fff;transition:background .12s ease;}
.btn:hover{background:#0a7a3a;}
.btn-secondary{background:#fff;color:var(--muted);border:1.5px solid var(--line);}

.alt-link{margin-top:18px;font-size:13px;color:var(--muted);text-align:center;}
.helptext{font-size:11.5px;color:var(--muted);margin-top:4px;}
.errorlist{list-style:none;margin:6px 0 0;padding:0;color:var(--red);font-size:12.5px;}
.nonfield-errors{background:#fdecea;border:1px solid #f5c6c2;color:#a13127;border-radius:9px;padding:10px 12px;font-size:13px;margin-bottom:16px;}
.messages{list-style:none;margin:0 0 16px;padding:0;}
.messages li{border-radius:9px;padding:10px 12px;font-size:13px;margin-bottom:8px;}
.messages li.success{background:#e7f4ec;border:1px solid #b6dcc4;color:#1d6a39;}
.messages li.error{background:#fdecea;border:1px solid #f5c6c2;color:#a13127;}
.messages li.info{background:#eef4e6;border:1px solid #d9e6c9;color:#46603a;}

.notice{max-width:520px;margin:60px auto;background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 30px;text-align:center;}
.notice h1{font-size:22px;margin:0 0 10px;}
.notice p{color:var(--muted);font-size:14px;margin:0 auto 8px;max-width:420px;}
.notice .em{color:var(--green-dark);font-weight:700;}
