/* ============================================================
   Staff Portal — login front door
   ============================================================ */
.portal { min-height: 100svh; display: grid; grid-template-columns: 1.05fr 1fr; background: var(--paper); }

/* ---- Left brand / system panel ---- */
.portal__aside {
  position: relative; overflow: hidden;
  background: var(--espresso); color: var(--cream-on-dark);
  display: flex; flex-direction: column; justify-content: space-between;
  padding: clamp(32px, 4vw, 56px);
}
.portal__aside .slot { position: absolute; inset: 0; border: 0; opacity: 0.5; }
.portal__aside .scrim { position: absolute; inset: 0; background: linear-gradient(160deg, oklch(0.205 0.02 50 / 0.82), oklch(0.205 0.02 50 / 0.96)); z-index: 1; }
.portal__aside > * { position: relative; z-index: 2; }

.portal__brand { display: flex; align-items: baseline; gap: 10px; }
.portal__brand .m { font-family: var(--display); font-size: 26px; font-weight: 600; }
.portal__brand .s { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.24em; text-transform: uppercase; opacity: 0.7; }

.portal__hero h1 { font-family: var(--display); font-weight: 500; font-size: clamp(34px, 4vw, 56px); line-height: 1.04; max-width: 14ch; }
.portal__hero p { color: var(--faint-on-dark); max-width: 40ch; margin-top: 18px; font-size: 15px; }

.portal__modules { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: oklch(1 0 0 / 0.12); border: 1px solid oklch(1 0 0 / 0.12); border-radius: var(--radius); overflow: hidden; margin-top: 34px; }
.portal__modules .mod { background: var(--espresso); padding: 15px 16px; display: flex; align-items: center; gap: 11px; }
.portal__modules .mod .ico { width: 30px; height: 30px; flex: none; border-radius: 6px; display: grid; place-items: center; background: oklch(1 0 0 / 0.06); font-family: var(--mono); font-size: 13px; color: var(--gold); }
.portal__modules .mod .txt { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.portal__modules .mod .t { font-size: 13.5px; font-weight: 600; line-height: 1.15; }
.portal__modules .mod .st { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green); display: flex; align-items: center; gap: 5px; }
.portal__modules .mod .st i { width: 5px; height: 5px; border-radius: 50%; background: var(--green); display: inline-block; }

.portal__foot { display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; color: var(--faint-on-dark); flex-wrap: wrap; }

/* ---- Right form panel ---- */
.portal__main { display: flex; flex-direction: column; padding: clamp(28px, 3.5vw, 56px); }
.portal__top { display: flex; align-items: center; justify-content: space-between; }
.portal__back { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); display: inline-flex; gap: 8px; align-items: center; transition: color .2s, gap .2s; }
.portal__back:hover { color: var(--ink); gap: 11px; }
.portal__chip { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-d); display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); border-radius: 100px; padding: 7px 13px; }
.portal__chip i { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }

.portal__form-wrap { flex: 1; display: flex; flex-direction: column; justify-content: center; max-width: 400px; width: 100%; margin: 0 auto; }
.portal__form-wrap h2 { font-family: var(--display); font-weight: 500; font-size: clamp(30px, 3.4vw, 44px); }
.portal__form-wrap .sub { color: var(--ink-soft); margin-top: 8px; font-size: 15px; }

.pform { display: flex; flex-direction: column; gap: 16px; margin-top: 32px; }
.pfield { display: flex; flex-direction: column; gap: 8px; }
.pfield label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-faint); }
.pinput { position: relative; display: flex; align-items: center; }
.pinput input {
  width: 100%; font: inherit; font-size: 15px; color: var(--ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 13px 15px; outline: none; transition: border-color .2s, box-shadow .2s;
}
.pinput input:focus { border-color: var(--clay); box-shadow: 0 0 0 3px oklch(0.585 0.105 47 / 0.14); }
.pinput .toggle { position: absolute; right: 12px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); padding: 4px 6px; }
.pinput .toggle:hover { color: var(--ink); }

.pform__row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 2px; }
.pcheck { display: flex; align-items: center; gap: 9px; font-size: 13.5px; color: var(--ink-soft); cursor: pointer; white-space: nowrap; }
.pcheck input { appearance: none; width: 17px; height: 17px; border: 1px solid var(--line); border-radius: 4px; background: var(--paper); display: grid; place-content: center; cursor: pointer; transition: background .2s, border-color .2s; }
.pcheck input:checked { background: var(--clay); border-color: var(--clay); }
.pcheck input:checked::after { content: "✓"; color: var(--paper); font-size: 11px; }
.pform__row a { font-size: 13.5px; color: var(--clay-d); font-weight: 600; }
.pform__row a:hover { text-decoration: underline; }

.psubmit { width: 100%; justify-content: center; margin-top: 8px; position: relative; }
.psubmit[data-state="loading"] { pointer-events: none; opacity: 0.85; }

.psso { display: flex; align-items: center; gap: 14px; margin-top: 22px; color: var(--ink-faint); font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; }
.psso::before, .psso::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.pgov { display: flex; gap: 12px; margin-top: 18px; }
.pgov button { flex: 1; border: 1px solid var(--line); border-radius: var(--radius); padding: 12px; font-size: 13.5px; font-weight: 600; color: var(--ink); transition: background .2s, border-color .2s; display: flex; align-items: center; justify-content: center; gap: 9px; }
.pgov button:hover { background: var(--paper-2); border-color: var(--ink-faint); }
.pgov .g { width: 16px; height: 16px; border-radius: 4px; background: var(--green); display: inline-block; }
.pgov .o { width: 16px; height: 16px; border-radius: 4px; background: var(--clay); display: inline-block; }

.portal__help { text-align: center; margin-top: 30px; font-size: 13px; color: var(--ink-faint); }
.portal__help a { color: var(--ink-soft); font-weight: 600; }
.portal__help a:hover { color: var(--ink); }

.pnotice { font-size: 12.5px; color: var(--ink-faint); display: flex; align-items: flex-start; gap: 9px; margin-top: 26px; padding: 12px 14px; background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius); }
.pnotice b { color: var(--ink-soft); }

@media (max-width: 880px) {
  .portal { grid-template-columns: 1fr; }
  .portal__aside { display: none; }
  .portal__main { min-height: 100svh; }
}
