:root{
  --ink:#152238;
  --muted:#68758a;
  --line:#dfe5ee;
  --surface:#ffffff;
  --soft:#f4f7fb;
  --brand:#3357d5;
  --brand-dark:#223eaa;
  --hero-heading:#4557d5;
  --success:#18794e;
  --warning:#9a6700;
  --danger:#b42318;
  --manual:#6941c6;
  --shadow:0 18px 55px rgba(22,34,56,.09);
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--ink);background:linear-gradient(180deg,#f8faff 0,#f3f6fb 100%);line-height:1.55}
button,select,input{font:inherit}
.topbar{height:76px;padding:0 max(24px,calc((100vw - 1240px)/2));display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.9);border-bottom:1px solid var(--line);backdrop-filter:blur(12px);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none}
.brand-mark{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;background:var(--brand);color:#fff;font-weight:800}
.brand strong,.brand small{display:block}.brand small{color:var(--muted);font-size:.78rem}
.beta{font-size:.78rem;padding:6px 10px;border-radius:999px;background:#eef2ff;color:var(--brand-dark);font-weight:700}
.page-shell{max-width:1240px;margin:auto;padding:48px 24px 70px}
.hero{display:grid;grid-template-columns:1.4fr .6fr;gap:38px;align-items:center;margin-bottom:38px}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.73rem;font-weight:800;color:var(--brand);margin:0 0 8px}
h1{font-size:clamp(2.25rem,4.8vw,4.5rem);line-height:1.02;letter-spacing:-.055em;margin:0;max-width:850px}
.hero h1{color:var(--ink)}
.hero h2{
  max-width:980px;
  margin:14px 0 0;
  color:var(--ink);
  font-size:clamp(1.45rem,2.7vw,2.5rem);
  line-height:1.2;
  letter-spacing:-.025em;
  font-weight:750;
}
.v-prof-name{
  color:var(--hero-heading);
  font-weight:850;
}
.hero-copy{max-width:760px;color:var(--muted);font-size:1.08rem;margin:22px 0}
.trust-row{display:flex;gap:10px;flex-wrap:wrap}.trust-row span{padding:8px 11px;background:#fff;border:1px solid var(--line);border-radius:999px;font-size:.8rem;font-weight:650}
.hero-card{background:linear-gradient(145deg,#223eaa,#3357d5);color:#fff;border-radius:26px;padding:28px;box-shadow:var(--shadow)}
.score-preview span,.score-preview small{display:block;opacity:.78}.score-preview strong{display:block;font-size:3.5rem;line-height:1;margin:10px 0}
.preview-list{margin-top:24px;border-top:1px solid rgba(255,255,255,.22);padding-top:16px}.preview-list p{margin:9px 0;font-size:.88rem}.preview-list b{display:inline-block;width:72px}
.workspace{display:grid;grid-template-columns:390px 1fr;gap:24px;align-items:start}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}
.setup-panel{padding:25px;position:sticky;top:100px}.result-panel{padding:28px;min-height:650px}
.panel-heading,.section-title,.result-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.panel-heading h2,.result-top h2,.section-title h3{margin:0}.step{padding:6px 10px;border-radius:999px;background:var(--soft);font-size:.75rem;font-weight:750;color:var(--muted)}
.field{display:block;margin-top:18px}.field>span{display:block;font-weight:700;font-size:.86rem;margin-bottom:7px}
select{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px;background:#fff;color:var(--ink);outline:none}
select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(51,87,213,.12)}
.segmented{display:grid;grid-template-columns:1fr 1fr;background:var(--soft);border-radius:12px;padding:4px}
.segmented input{display:none}.segmented span{display:block;padding:9px;text-align:center;border-radius:9px;font-size:.81rem;font-weight:700;cursor:pointer;color:var(--muted)}
.segmented input:checked+span{background:#fff;color:var(--brand);box-shadow:0 3px 10px rgba(20,34,56,.08)}
.segmented.three-option{grid-template-columns:repeat(3,minmax(0,1fr))}
.upload-box{margin-top:20px;border:1.5px dashed #aeb9ca;border-radius:16px;padding:23px;text-align:center;display:block;cursor:pointer;background:var(--soft);transition:.2s}
.upload-box:hover{border-color:var(--brand);background:#f0f3ff}.upload-box input{display:none}.upload-box strong,.upload-box small,.upload-box em{display:block}
.upload-box small{color:var(--muted);margin-top:4px}.upload-box em{font-style:normal;color:var(--brand);font-size:.78rem;margin-top:10px;word-break:break-all}.upload-icon{font-size:1.6rem;color:var(--brand);font-weight:800}
.primary-button,.secondary-button,.ghost-button{border:0;border-radius:12px;padding:13px 17px;font-weight:750;cursor:pointer;transition:.2s}
.primary-button{width:100%;margin-top:18px;background:var(--brand);color:#fff}.primary-button:hover{background:var(--brand-dark)}.primary-button:disabled{opacity:.6;cursor:wait}
.secondary-button{background:var(--brand);color:#fff}.ghost-button{background:var(--soft);color:var(--ink)}
.form-note{font-size:.75rem;color:var(--muted);text-align:center;margin:12px 0 0}
.empty-state,.loading-state{min-height:590px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:50px}
.empty-state h2,.loading-state h2{color:var(--ink);margin-bottom:4px}.empty-icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:#eef2ff;color:var(--brand);font-weight:900;font-size:1.7rem}
.spinner{width:48px;height:48px;border:4px solid #e6eaf1;border-top-color:var(--brand);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}
.score-ring{min-width:150px;padding:18px;border-radius:18px;background:var(--soft);text-align:center}.score-ring strong,.score-ring span{display:block}.score-ring strong{font-size:2.2rem}.score-ring span{font-size:.78rem;color:var(--muted);font-weight:700}
.metrics{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin:24px 0}.metric{padding:14px;border:1px solid var(--line);border-radius:14px;background:#fff}.metric strong,.metric span{display:block}.metric strong{font-size:1.3rem}.metric span{font-size:.72rem;color:var(--muted)}
.result-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}.result-section{border-top:1px solid var(--line);padding-top:25px;margin-top:25px}
.action-list,.finding-list{display:grid;gap:10px;margin-top:16px}.action-item{border:1px solid var(--line);border-left:4px solid var(--warning);border-radius:13px;padding:14px}.action-item.critical{border-left-color:var(--danger)}.action-item.major{border-left-color:#d97706}.action-item.moderate{border-left-color:var(--warning)}.action-item.minor{border-left-color:#64748b}.action-item.strength{border-left-color:var(--success);background:#fbfffd}.action-item strong{margin-right:8px}.action-item p{margin:5px 0 0;color:var(--muted);font-size:.88rem}
.finding{border:1px solid var(--line);border-radius:15px;overflow:hidden}.finding-summary{width:100%;border:0;background:#fff;text-align:left;padding:15px;display:grid;grid-template-columns:minmax(135px,190px) 1fr 155px;gap:12px;align-items:center;cursor:pointer}.finding-summary:hover{background:#fbfcff}.code{font-weight:850;color:var(--brand)}.category-tag{font-size:.72rem;line-height:1.25;text-transform:none}.criterion{font-weight:700}.status-pill{justify-self:end;padding:6px 9px;border-radius:999px;font-size:.72rem;font-weight:800}
.status-meets_requirement{background:#ecfdf3;color:var(--success)}.status-partly_meets_requirement{background:#fff8e6;color:var(--warning)}.status-does_not_meet_requirement{background:#fff0ee;color:var(--danger)}.status-manual_review_required{background:#f4f0ff;color:var(--manual)}.status-not_applicable{background:var(--soft);color:var(--muted)}
.finding-body{border-top:1px solid var(--line);padding:16px;background:#fbfcff}.finding-body p{margin:7px 0}.label{font-weight:800}.evidence{margin-top:12px;padding:12px;background:#fff;border:1px solid var(--line);border-radius:11px;font-size:.86rem}.evidence small{display:block;color:var(--muted);font-weight:750;margin-bottom:5px}
.compact-select{width:auto;min-width:190px;padding:9px}
.error-banner{padding:12px;border-radius:12px;background:#fff0ee;color:var(--danger);font-weight:650;margin-bottom:16px}
@media(max-width:1000px){.hero{grid-template-columns:1fr}.hero-card{display:none}.workspace{grid-template-columns:1fr}.setup-panel{position:static}.metrics{grid-template-columns:repeat(3,1fr)}}
@media(max-width:650px){.page-shell{padding:28px 14px}.result-panel,.setup-panel{padding:18px}.metrics{grid-template-columns:repeat(2,1fr)}.finding-summary{grid-template-columns:1fr}.status-pill{grid-column:1;justify-self:start}.result-top{display:block}.score-ring{margin-top:16px}.section-title{display:block}.compact-select{width:100%;margin-top:10px}.context-file{display:block}.context-file span{display:block;text-align:left;margin-top:4px}}


.field-help{margin:7px 0 0;color:var(--muted);font-size:.76rem;line-height:1.45}
.context-card{margin-top:18px;padding:16px;border:1px solid #cfd8ff;border-radius:16px;background:#f7f8ff}
.context-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.context-heading h3{margin:6px 0 0;font-size:1rem}
.context-card>p{margin:8px 0 0;color:var(--muted);font-size:.82rem}
.required-badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#fff0ee;color:var(--danger);font-size:.67rem;font-weight:850;text-transform:uppercase;letter-spacing:.06em}
.context-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#eef2ff;color:var(--brand);font-size:1.15rem;font-weight:850}
.context-upload{margin-top:14px;background:#fff;padding:18px}
.context-upload:hover{background:#fbfcff}
.alignment-score{padding:8px 11px;border-radius:999px;background:#eef2ff;color:var(--brand-dark);font-size:.82rem;font-weight:850;white-space:nowrap}
.context-summary{display:grid;gap:8px;margin-top:15px}
.context-file{display:flex;justify-content:space-between;gap:16px;padding:11px 13px;border:1px solid var(--line);border-radius:12px;background:var(--soft);font-size:.82rem}
.context-file strong{overflow-wrap:anywhere}
.context-file span{color:var(--muted);text-align:right}
.alignment-details{margin-top:12px;padding:12px;border-radius:11px;background:#fff8e6;border:1px solid #f2d38b;font-size:.85rem}
.alignment-details strong{display:block;margin-bottom:6px}
.alignment-details ol{margin:0;padding-left:20px}
.alignment-details li+li{margin-top:5px}
textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px;background:#fff;color:var(--ink);outline:none;resize:vertical;min-height:116px;line-height:1.5}
textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(51,87,213,.12)}
.compact-field{margin-top:14px}
.revision-card{border-color:#b7dfc9;background:#f5fcf8}
.revision-card .required-badge{background:#e8f8ef;color:var(--success)}
.optional-upload{margin-top:16px;padding-top:16px;border-top:1px solid #d7e8de}
.optional-upload>p{margin:7px 0 0;color:var(--muted);font-size:.8rem}
.optional-badge{display:inline-block;padding:5px 8px;border-radius:999px;background:#eef2ff;color:var(--brand-dark);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}

.ai-review-card{display:flex;justify-content:space-between;gap:22px;align-items:center;margin:0 0 24px;padding:18px;border:1px solid #cfd7ff;border-radius:16px;background:linear-gradient(135deg,#f5f7ff,#fbfcff)}
.ai-review-card h3{margin:0}.ai-review-card p{margin:4px 0;color:var(--muted)}
.ai-review-stats{display:grid;grid-template-columns:repeat(4,minmax(82px,1fr));gap:8px;min-width:420px}
.ai-review-stats span{padding:10px;border-radius:11px;background:#fff;border:1px solid var(--line);text-align:center}
.ai-review-stats strong,.ai-review-stats small{display:block}.ai-review-stats small{font-size:.68rem;color:var(--muted)}
.ai-warning{color:var(--warning);font-size:.8rem;font-weight:650}
@media(max-width:850px){.ai-review-card{display:block}.ai-review-stats{min-width:0;margin-top:12px;grid-template-columns:repeat(2,1fr)}}

.light-note{margin-top:10px;padding:10px 12px;border-radius:10px;background:#eef7ff;color:#264f73;font-size:.78rem;font-weight:650}
.doctoral-note{margin-top:10px;padding:10px 12px;border-radius:10px;background:#f4f0ff;color:#553c9a;font-size:.78rem;font-weight:650}
.progress-track{width:min(430px,90%);height:9px;background:#e7ebf2;border-radius:999px;overflow:hidden;margin:18px auto 8px}
.progress-track span{display:block;height:100%;width:2%;background:var(--brand);border-radius:999px;transition:width .35s ease}
#progressText{color:var(--muted);font-weight:700}

@media(max-width:520px){.segmented.three-option{grid-template-columns:1fr}.segmented.three-option span{padding:8px}}

/* Institutional authentication and portal */
input[type="text"],input[type="password"],input[type="email"],input[type="tel"]{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px;background:#fff;color:var(--ink);outline:none}
input[type="text"]:focus,input[type="password"]:focus,input[type="email"]:focus,input[type="tel"]:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(51,87,213,.12)}
.field small{display:block;color:var(--muted);font-weight:500;margin-top:5px}
.auth-body{min-height:100vh;background:#f5f7fb}.auth-shell{min-height:100vh;display:grid;grid-template-columns:minmax(390px,.9fr) 1.1fr}.auth-brand-panel{padding:52px max(42px,8vw);background:linear-gradient(145deg,#162c78,#3357d5);color:#fff;display:flex;flex-direction:column;justify-content:space-between}.brand-light{color:#fff}.brand-light small{color:rgba(255,255,255,.75)}.auth-brand-copy{max-width:620px;margin:80px 0}.auth-brand-copy h1{font-size:clamp(2.3rem,4.5vw,4.6rem);max-width:720px}.auth-brand-copy p{font-size:1.05rem;color:rgba(255,255,255,.78);max-width:620px}.light-eyebrow{color:#cbd5ff}.auth-feature-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.auth-feature-list span{padding:12px 14px;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:rgba(255,255,255,.08);font-size:.84rem}.auth-form-panel{display:grid;place-items:center;padding:36px}.auth-form-card{width:min(470px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:var(--shadow)}.auth-heading h2{font-size:2rem;margin:0}.auth-heading>p:last-child{color:var(--muted);margin:7px 0 0}.auth-form .primary-button{margin-top:22px}.auth-links{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:18px;margin-top:20px}.auth-links a{color:var(--brand);font-size:.82rem;font-weight:700;text-decoration:none}.simple-auth{display:grid;place-items:center;padding:30px}.simple-auth-shell{width:min(500px,100%)}.simple-auth-shell>.brand{margin-bottom:22px}.flash{padding:12px 14px;border-radius:12px;margin:16px 0;font-weight:700;font-size:.86rem}.flash-success{background:#ecfdf3;color:var(--success);border:1px solid #b7e7ce}.flash-error{background:#fff0ee;color:var(--danger);border:1px solid #f5c4bf}.flash-warning{background:#fff8e6;color:var(--warning);border:1px solid #f1d591}.flash-info{background:#eef2ff;color:var(--brand-dark);border:1px solid #cfd7ff}
.portal-topbar{position:sticky}.portal-nav{display:flex;align-items:center;gap:8px}.portal-nav form{margin:0}.nav-link,.nav-button{border:0;background:transparent;color:var(--muted);padding:8px 10px;border-radius:9px;font-size:.82rem;font-weight:750;text-decoration:none;cursor:pointer}.nav-link:hover,.nav-button:hover,.nav-link.active{background:var(--soft);color:var(--brand)}.compact-nav{margin-left:auto}.user-chip{padding:7px 10px;border-radius:999px;background:#eef2ff;color:var(--brand-dark);font-size:.76rem;font-weight:800}.portal-shell{max-width:1240px;margin:auto;padding:38px 24px 70px}.portal-welcome{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.portal-welcome h1{font-size:clamp(2rem,4vw,3.4rem);margin:0;letter-spacing:-.04em}.portal-welcome p:last-child{margin:8px 0 0;color:var(--muted)}.primary-link-button,.ghost-link-button,.link-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:12px;padding:12px 16px;font-weight:800}.primary-link-button{background:var(--brand);color:#fff}.ghost-link-button{background:var(--soft);color:var(--ink)}.portal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.portal-stats article{background:#fff;border:1px solid var(--line);border-radius:17px;padding:18px;box-shadow:0 9px 28px rgba(22,34,56,.05)}.portal-stats span,.portal-stats strong{display:block}.portal-stats span{font-size:.76rem;color:var(--muted);font-weight:700}.portal-stats strong{font-size:1.8rem;margin-top:4px}.portal-card{background:#fff;border:1px solid var(--line);border-radius:21px;padding:24px;box-shadow:var(--shadow);margin-bottom:24px}.portal-card-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:18px}.portal-card-heading h2{margin:0}.table-wrap{overflow-x:auto}.portal-table{width:100%;border-collapse:collapse;min-width:760px}.portal-table th{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.portal-table td{padding:13px 12px;border-bottom:1px solid #edf0f5;vertical-align:top;font-size:.84rem}.portal-table td strong,.portal-table td small{display:block}.portal-table td small{color:var(--muted);margin-top:3px}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.table-actions a{color:var(--brand);font-weight:750;text-decoration:none;font-size:.78rem}.record-status{display:inline-block;padding:5px 8px;border-radius:999px;font-size:.7rem;font-weight:850}.status-record-completed{background:#ecfdf3;color:var(--success)}.status-record-processing,.status-record-queued{background:#eef2ff;color:var(--brand-dark)}.status-record-failed{background:#fff0ee;color:var(--danger)}.portal-empty{text-align:center;padding:46px 18px;color:var(--muted)}.portal-empty h3{color:var(--ink);margin:0}.portal-empty .primary-link-button{margin-top:12px}.muted-text{color:var(--muted);font-size:.8rem}
.admin-grid{display:grid;grid-template-columns:360px 1fr;gap:24px;align-items:start}.create-account-card{position:sticky;top:100px}.admin-form .field{margin-top:14px}.admin-form .primary-button{margin-top:18px}.count-badge{padding:6px 10px;background:var(--soft);border-radius:999px;font-weight:850;color:var(--muted)}.lecturer-list{display:grid;gap:9px}.lecturer-row{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:13px}.lecturer-avatar{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;background:#eef2ff;color:var(--brand);font-weight:900}.lecturer-info strong,.lecturer-info span,.lecturer-info small{display:block}.lecturer-info span,.lecturer-info small{color:var(--muted);font-size:.75rem}.lecturer-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}.lecturer-actions form{margin:0}.mini-button{border:1px solid var(--line);background:#fff;padding:7px 9px;border-radius:9px;font-size:.71rem;font-weight:800;cursor:pointer}.danger-outline{border-color:#f1b6b0;color:var(--danger)}.success-outline{border-color:#b7e7ce;color:var(--success)}.credentials-banner{display:grid;grid-template-columns:1fr 1.3fr;gap:20px;background:linear-gradient(135deg,#eef2ff,#f9faff);border:1px solid #cfd7ff;border-radius:20px;padding:22px;margin-bottom:24px}.credentials-banner h2{margin:0}.credentials-banner p:last-child{color:var(--muted);margin:6px 0 0}.credential-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.credential-grid>div{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}.credential-grid span,.credential-grid strong{display:block}.credential-grid span{font-size:.7rem;color:var(--muted)}.credential-grid strong{margin-top:5px;word-break:break-all}.detail-shell{max-width:930px}.review-summary-card h1{font-size:2.2rem;margin:0}.review-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:22px 0}.review-summary-grid>div{padding:13px;border-radius:13px;background:var(--soft)}.review-summary-grid span,.review-summary-grid strong{display:block}.review-summary-grid span{font-size:.7rem;color:var(--muted)}.review-summary-grid strong{margin-top:5px}.review-meaning{color:var(--muted)}.link-button.secondary-button{color:#fff}.link-button.ghost-button{color:var(--ink)}
@media(max-width:980px){.auth-shell{grid-template-columns:1fr}.auth-brand-panel{display:none}.admin-grid{grid-template-columns:1fr}.create-account-card{position:static}.credentials-banner{grid-template-columns:1fr}.portal-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:650px){.portal-topbar{height:auto;padding:12px 14px;align-items:flex-start}.portal-nav{flex-wrap:wrap;justify-content:flex-end}.portal-nav .user-chip{display:none}.portal-shell{padding:28px 14px}.portal-welcome{display:block}.portal-welcome .primary-link-button{margin-top:16px}.portal-stats{grid-template-columns:1fr 1fr}.auth-form-panel{padding:16px}.auth-form-card{padding:24px}.credential-grid,.review-summary-grid{grid-template-columns:1fr}.lecturer-row{grid-template-columns:40px 1fr}.lecturer-actions{grid-column:2;justify-content:flex-start}}

/* v1.3 unified institutional access page */
.access-body{
  min-height:100vh;margin:0;
  background:radial-gradient(circle at 86% 18%,rgba(51,87,213,.10),transparent 30%),
             linear-gradient(135deg,#fbfcff 0%,#f2f6ff 55%,#eef4ff 100%);
  color:#14213a;
}
.access-header{
  min-height:92px;padding:14px max(28px,calc((100vw - 1500px)/2));
  display:flex;align-items:center;justify-content:space-between;gap:28px;
  background:rgba(255,255,255,.94);border-bottom:1px solid #dfe6f2;
  box-shadow:0 3px 18px rgba(29,48,87,.035);backdrop-filter:blur(14px);
}
.access-brand{display:inline-flex;align-items:center;gap:14px;color:#14213a;text-decoration:none}
.access-brand-mark{
  width:54px;height:54px;display:grid;place-items:center;border-radius:17px;
  background:linear-gradient(145deg,#253da9,#4c68ea);color:#fff;font-size:1.05rem;
  font-weight:900;letter-spacing:.04em;box-shadow:0 12px 28px rgba(51,87,213,.24)
}
.access-brand-copy strong,.access-brand-copy small{display:block}
.access-brand-copy strong{font-size:1.2rem;line-height:1.2}
.access-brand-copy small{color:#69778d;font-size:.8rem;margin-top:3px}
.access-role-tabs{
  display:grid;grid-template-columns:repeat(2,minmax(126px,1fr));gap:5px;padding:6px;
  border:1px solid #e1e6ef;border-radius:18px;background:#f1f4f8
}
.access-role-tab{
  display:flex;align-items:center;justify-content:center;min-height:48px;padding:9px 24px;
  border-radius:13px;color:#647083;text-decoration:none;font-weight:800;
  transition:background .18s ease,color .18s ease,box-shadow .18s ease
}
.access-role-tab:hover{color:#2848be}
.access-role-tab.active{background:#fff;color:#243fae;box-shadow:0 4px 14px rgba(35,55,97,.10)}
.access-main{min-height:calc(100vh - 92px);padding:72px max(28px,calc((100vw - 1500px)/2)) 80px}
.access-hero{
  display:grid;grid-template-columns:minmax(0,1.35fr) minmax(390px,.65fr);
  gap:72px;align-items:center
}
.access-intro{max-width:900px}
.access-kicker,.access-card-kicker{
  margin:0 0 14px;color:#3652ca;font-size:.76rem;font-weight:900;
  letter-spacing:.13em;text-transform:uppercase
}
.access-intro h1{
  max-width:920px;margin:0;color:#14213a;font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(3.2rem,6.1vw,6.6rem);font-weight:700;letter-spacing:-.055em;line-height:.98
}
.access-lead{
  max-width:800px;margin:28px 0 0;color:#5d6b80;
  font-size:clamp(1.05rem,1.55vw,1.35rem);line-height:1.75
}
.access-capabilities{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px;
  max-width:780px;margin-top:34px
}
.access-capabilities article{
  min-height:112px;padding:20px;border:1px solid #dfe6f2;border-radius:18px;
  background:rgba(255,255,255,.78);box-shadow:0 12px 35px rgba(31,49,85,.05)
}
.access-capabilities strong,.access-capabilities span{display:block}
.access-capabilities strong{color:#2946bc;font-size:1.08rem}
.access-capabilities span{margin-top:7px;color:#69778d;font-size:.83rem;line-height:1.45}
.access-assurance{
  max-width:780px;margin-top:30px;padding:24px 28px;border-radius:22px;
  background:#172b55;color:#fff;box-shadow:0 22px 55px rgba(18,39,84,.16)
}
.access-assurance h2{margin:0 0 12px;font-family:Georgia,"Times New Roman",serif;font-size:1.45rem}
.access-assurance ul{margin:0;padding-left:20px;color:rgba(255,255,255,.82)}
.access-assurance li+li{margin-top:8px}
.access-login-wrap{width:100%;max-width:510px;justify-self:end}
.access-login-card{
  padding:36px;border:1px solid #dce4ef;border-radius:26px;background:rgba(255,255,255,.97);
  box-shadow:0 28px 70px rgba(26,44,80,.14)
}
.access-login-heading{display:flex;align-items:center;gap:16px}
.access-login-icon{
  flex:0 0 52px;width:52px;height:52px;display:grid;place-items:center;border-radius:16px;
  background:#edf1ff;color:#3150ca;font-size:1.1rem;font-weight:900
}
.access-login-heading h2{margin:0;color:#14213a;font-size:1.85rem;letter-spacing:-.025em}
.access-login-heading .access-card-kicker{margin-bottom:3px}
.access-card-copy{margin:18px 0 24px;color:#69778d;line-height:1.65}
.access-form{display:grid;gap:17px}
.access-field{display:grid;gap:7px}
.access-field span{color:#26344f;font-size:.84rem;font-weight:800}
.access-field input{
  width:100%;min-height:52px;padding:13px 15px;border:1px solid #ccd5e3;
  border-radius:13px;background:#fff;color:#14213a;outline:none;
  transition:border-color .18s ease,box-shadow .18s ease
}
.access-field input::placeholder{color:#9aa5b5}
.access-field input:focus{border-color:#4662d9;box-shadow:0 0 0 4px rgba(70,98,217,.13)}
.access-submit{
  width:100%;min-height:54px;margin-top:3px;border:0;border-radius:14px;
  background:linear-gradient(135deg,#304bc5,#4c67e7);color:#fff;font-weight:850;
  cursor:pointer;box-shadow:0 13px 28px rgba(51,87,213,.23);
  transition:transform .18s ease,box-shadow .18s ease
}
.access-submit:hover{transform:translateY(-1px);box-shadow:0 17px 34px rgba(51,87,213,.29)}
.access-help{
  margin-top:22px;padding-top:18px;border-top:1px solid #e4e9f1;
  color:#778398;font-size:.8rem
}
.access-help a{color:#3150ca;font-weight:800;text-decoration:none}
.access-help a:hover{text-decoration:underline}
.access-security-note{
  max-width:440px;margin:16px auto 0;color:#778398;text-align:center;
  font-size:.76rem;line-height:1.55
}
@media(max-width:1100px){
  .access-main{padding-top:50px}
  .access-hero{grid-template-columns:1fr;gap:42px}
  .access-intro{max-width:none}
  .access-intro h1{max-width:950px;font-size:clamp(3rem,8vw,5.4rem)}
  .access-login-wrap{max-width:680px;justify-self:start}
}
@media(max-width:720px){
  .access-header{min-height:auto;padding:13px 16px;align-items:flex-start}
  .access-brand-copy small{display:none}
  .access-role-tabs{grid-template-columns:repeat(2,minmax(92px,1fr))}
  .access-role-tab{min-height:42px;padding:8px 13px;font-size:.82rem}
  .access-main{padding:40px 17px 55px}
  .access-intro h1{font-size:clamp(2.65rem,13vw,4rem)}
  .access-lead{font-size:1rem}
  .access-capabilities{grid-template-columns:1fr}
  .access-capabilities article{min-height:auto}
  .access-assurance{padding:21px}
  .access-login-card{padding:25px 21px;border-radius:21px}
}
@media(max-width:480px){
  .access-brand{gap:9px}
  .access-brand-mark{width:45px;height:45px;border-radius:14px}
  .access-brand-copy strong{font-size:1rem}
  .access-role-tabs{padding:4px}
  .access-role-tab{min-width:0;padding:7px 10px}
}
