  body{background:var(--ink)}
  .login{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}

  /* brand side */
  .brandside{position:relative;color:#fff;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:46px 54px}
  .brandside .bg{position:absolute;inset:0;background:url('/assets/images/hero.webp') center 28%/cover no-repeat;opacity:.32}
  .brandside .ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(1,11,0,.82),rgba(4,48,8,.9))}
  .brandside > *{position:relative;z-index:1}
  .blogo{display:flex;align-items:center;gap:14px}
  .blogo .emblem{width:50px;height:50px}
  .blogo .bt b{display:block;font-size:20px;font-weight:800;letter-spacing:.04em}
  .blogo .bt span{display:block;font-size:11px;letter-spacing:.2em;font-weight:600;color:#9fb09c;text-transform:uppercase}
  .bmid{max-width:440px}
  .bmid .eyebrow{margin-bottom:14px}
  .bmid h1{font-size:clamp(28px,3.4vw,40px);font-weight:800;line-height:1.14;margin:0 0 16px;letter-spacing:.01em}
  .bmid p{color:#cdd5ca;font-size:16px;line-height:1.7;margin:0}
  .bfeat{display:flex;flex-direction:column;gap:14px;margin-top:26px}
  .bfeat .f{display:flex;align-items:center;gap:12px;font-size:14.5px;color:#e7ece4}
  .bfeat .f .ic{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;background:rgba(255,149,41,.16);color:var(--accent)}
  .bfeat .f .ic svg{width:18px;height:18px}
  .bfoot{font-size:12.5px;color:#8fa08c}

  /* form side */
  .formside{background:#fff;display:flex;align-items:center;justify-content:center;padding:46px 40px}
  .lcard{width:100%;max-width:400px}
  .lcard .tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-700);background:rgba(255,149,41,.1);border:1px solid rgba(255,149,41,.3);padding:6px 13px;border-radius:999px;margin-bottom:18px}
  .lcard .tag svg{width:14px;height:14px}
  .lcard h2{font-size:26px;font-weight:800;color:var(--ink);margin:0 0 6px}
  .lcard .sub{color:var(--muted);font-size:14.5px;margin:0 0 28px}
  .field{margin-bottom:18px}
  .field label{display:block;font-size:13.5px;font-weight:600;color:#33402f;margin-bottom:7px}
  .inwrap{position:relative;display:flex;align-items:center}
  .inwrap > svg{position:absolute;left:14px;width:18px;height:18px;color:#9aa295;pointer-events:none}
  .inwrap input{width:100%;font:inherit;font-size:15px;color:#1a1f1a;background:#fbfbf9;border:1px solid var(--line);border-radius:10px;padding:13px 14px 13px 44px;outline:0;transition:.16s}
  .inwrap input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(255,149,41,.15)}
  .inwrap .toggle{position:absolute;right:8px;width:34px;height:34px;border:0;background:transparent;cursor:pointer;color:#7e8a7c;display:grid;place-items:center;border-radius:8px}
  .inwrap .toggle:hover{color:var(--green);background:var(--paper)}
  .inwrap .toggle svg{width:18px;height:18px}
  .frow{display:flex;align-items:center;justify-content:space-between;margin:4px 0 22px}
  .chk{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#33402f;cursor:pointer}
  .chk input{accent-color:var(--accent);width:16px;height:16px}
  .frow a{font-size:13.5px;font-weight:600;color:var(--green)}
  .frow a:hover{color:var(--accent-700)}
  .btn-login{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;font:inherit;font-size:15.5px;font-weight:700;letter-spacing:.02em;background:var(--green);color:#fff;border:0;padding:14px;border-radius:10px;cursor:pointer;transition:.16s}
  .btn-login:hover{background:#064210}
  .btn-login svg{width:18px;height:18px}
  .err{display:none;margin:0 0 18px;padding:12px 15px;border-radius:10px;background:#fdecea;border:1px solid #f4c7c2;color:#b3261e;font-size:13.5px;align-items:center;gap:9px}
  .err svg{width:18px;height:18px;flex:none}
  .lback{margin-top:26px;text-align:center;font-size:13.5px}
  .lback a{color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:7px}
  .lback a:hover{color:var(--green)}
  .lback svg{width:15px;height:15px}
  .secnote{margin-top:22px;display:flex;gap:10px;padding:13px 15px;background:var(--paper);border:1px solid var(--line);border-radius:10px;font-size:12.5px;color:var(--muted);line-height:1.55}
  .secnote svg{width:18px;height:18px;color:var(--accent-700);flex:none;margin-top:1px}

  @media(max-width:900px){.login{grid-template-columns:1fr}.brandside{display:none}.formside{min-height:100vh}}

/* footer credit (bottom-right of form side) */
.formside{position:relative}
.lcredit{position:absolute;right:22px;bottom:16px;font-size:11.5px;color:var(--muted);letter-spacing:.01em;cursor:default}
@media(max-width:900px){.lcredit{position:static;text-align:center;margin-top:20px}}

/* Fix 2026-06-08: mobile login — desktop .brandside (with logo) is hidden ≤900px,
   so show a compact logo header on the form, and tighten padding on small phones. */
.mlogo{display:none}
@media(max-width:900px){
  .mlogo{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 0 22px}
  .mlogo img{height:50px;width:auto;display:block}
  .mlogo span{font-size:15px;font-weight:700;color:#1a1f1a;line-height:1.2}
  .mlogo b{color:var(--green,#0a5b16)}
  .formside{padding:36px 22px}
  .lcard{max-width:420px}
}
@media(max-width:420px){
  .formside{padding:26px 16px}
  .lcard h2{font-size:22px}
  .frow{flex-wrap:wrap;gap:10px}
}
