@import url("/access-tokens.css");

:root{
  --portal-bg:var(--erp-bg);
  --portal-bg-secondary:var(--erp-bg-secondary);
  --portal-surface:var(--erp-surface);
  --portal-surface-muted:var(--erp-surface-muted);
  --portal-border:var(--erp-border);
  --portal-text:var(--erp-text);
  --portal-text-secondary:var(--erp-text-secondary);
  --portal-text-tertiary:var(--erp-text-tertiary);
  --portal-primary:var(--erp-primary);
  --portal-primary-hover:var(--erp-primary-hover);
  --portal-primary-active:var(--erp-primary-active);
  --portal-primary-soft:var(--erp-primary-soft);
  --portal-success:var(--erp-success);
  --portal-error:var(--erp-error);
  --portal-warning:var(--erp-warning);
  --portal-info:var(--erp-info);
  --portal-shadow:var(--erp-shadow-sm);
}

*{box-sizing:border-box}

html,body{
  margin:0;
  min-height:100%;
}

body{
  min-height:100vh;
  font-family:"Segoe UI",Arial,sans-serif;
  color:var(--portal-text);
  background:
    radial-gradient(circle at top left, rgba(31,122,99,.025), transparent 24%),
    linear-gradient(180deg, var(--portal-bg-secondary) 0%, var(--portal-bg) 34%, var(--portal-bg-secondary) 100%);
}

.portal-shell{
  width:min(100%, 1360px);
  margin:0 auto;
  padding:14px 24px 18px;
}

.portal-header{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  margin-bottom:18px;
}

.portal-brand{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.portal-logo-wrap{
  width:52px;
  height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--portal-border);
  border-radius:14px;
  background:var(--portal-surface);
}

.portal-logo{
  width:42px;
  height:42px;
  object-fit:contain;
}

.portal-brand-copy{
  display:grid;
  gap:2px;
  padding-top:0;
}

.portal-title{
  margin:0;
  font-size:18px;
  line-height:1.05;
  letter-spacing:-.03em;
}

.portal-subtitle{
  margin:0;
  color:var(--portal-text-secondary);
  font-size:12px;
  line-height:1.3;
}

.portal-subtitle-secondary{
  margin-top:1px;
  color:var(--portal-text-tertiary);
  font-size:12px;
}

.portal-section-kicker,
.portal-card-meta{
  margin:0;
  color:var(--portal-text-tertiary);
  font-size:10px;
  font-weight:700;
  line-height:1.2;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.portal-hero{
  margin:0;
}

.portal-hero-split{
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(380px, .82fr);
  gap:42px;
  align-items:start;
}

.portal-hero-content{
  padding-top:18px;
  max-width:720px;
}

.portal-hero-title{
  margin:14px 0 0;
  max-width:690px;
  font-size:60px;
  line-height:.95;
  letter-spacing:-.05em;
  text-wrap:balance;
}

.portal-hero-subheadline{
  margin:18px 0 0;
  max-width:690px;
  color:var(--portal-text-secondary);
  font-size:18px;
  line-height:1.56;
}

.portal-bullet-list{
  list-style:none;
  margin:22px 0 0;
  padding:0;
  display:grid;
  gap:14px;
  max-width:520px;
}

.portal-bullet-list li{
  position:relative;
  padding-left:18px;
  color:var(--portal-text-secondary);
  font-size:15px;
  line-height:1.45;
}

.portal-bullet-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:7px;
  width:6px;
  height:6px;
  border-radius:999px;
  background:var(--portal-primary);
}

.portal-access-stack{
  display:grid;
  gap:12px;
  align-self:stretch;
  padding-top:14px;
}

.portal-access-heading{
  display:grid;
  gap:4px;
}

.portal-block-title{
  margin:0;
  font-size:16px;
  line-height:1.22;
  letter-spacing:-.02em;
}

.portal-access-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.portal-access-card,
.portal-capability-item,
.portal-trust-card{
  border:1px solid var(--portal-border);
  border-radius:20px;
  background:var(--portal-surface);
  box-shadow:var(--portal-shadow);
}

.portal-access-card{
  min-height:154px;
  padding:18px 18px 16px;
  display:flex;
  flex-direction:column;
}

.portal-access-card.is-active{
  border-color:rgba(32, 107, 86, 0.28);
  box-shadow:0 0 0 1px rgba(32, 107, 86, 0.08), var(--portal-shadow);
}

.portal-access-card p:not(.portal-card-meta),
.portal-capability-item p,
.portal-trust-card p{
  margin:10px 0 0;
  color:var(--portal-text-secondary);
  font-size:13px;
  line-height:1.5;
}

.portal-capability-item h3,
.portal-trust-card h3{
  margin:0;
  font-size:18px;
  line-height:1.18;
  letter-spacing:-.02em;
}

.portal-cta{
  display:inline-flex;
  width:100%;
  min-height:48px;
  margin-top:auto;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:var(--portal-primary);
  color:#fff;
  text-decoration:none;
  font-size:14px;
  font-weight:700;
  transition:background-color .18s ease;
}

.portal-cta + .portal-cta{
  margin-top:10px;
}

.portal-cta-secondary{
  background:transparent;
  color:var(--portal-primary);
  border:1px solid rgba(32, 107, 86, 0.18);
}

.portal-cta:hover{background:var(--portal-primary-hover)}
.portal-cta:active{background:var(--portal-primary-active)}
.portal-cta-secondary:hover{
  background:rgba(32, 107, 86, 0.08);
}
.portal-cta-secondary:active{
  background:rgba(32, 107, 86, 0.14);
}
.portal-cta:focus-visible{
  outline:2px solid var(--portal-primary-active);
  outline-offset:3px;
}

.portal-access-support{
  margin:0;
  color:var(--portal-text-tertiary);
  font-size:11px;
  line-height:1.45;
}

.portal-login-panel{
  border:1px solid var(--portal-border);
  border-radius:20px;
  background:var(--portal-surface);
  box-shadow:var(--portal-shadow);
  padding:18px;
  display:grid;
  gap:14px;
}

.portal-login-panel__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.portal-login-panel__back{
  color:var(--portal-primary);
  font-size:12px;
  font-weight:600;
  text-decoration:none;
}

.portal-login-panel__back:hover{
  text-decoration:underline;
}

.portal-login-panel__copy,
.portal-login-panel__support{
  margin:0;
  color:var(--portal-text-secondary);
  font-size:13px;
  line-height:1.5;
}

.portal-login-alert{
  border:1px solid rgba(59, 130, 246, 0.26);
  border-radius:12px;
  background:rgba(59, 130, 246, 0.08);
  color:#1d4ed8;
  padding:12px 14px;
  font-size:13px;
  line-height:1.45;
}

.portal-login-alert.error{
  border-color:rgba(220, 38, 38, 0.22);
  background:rgba(220, 38, 38, 0.08);
  color:#b91c1c;
}

.portal-login-form{
  display:grid;
  gap:14px;
}

.portal-login-field{
  display:grid;
  gap:6px;
}

.portal-login-field label{
  font-size:13px;
  font-weight:600;
}

.portal-login-field input{
  width:100%;
  min-height:46px;
  padding:0 14px;
  border:1px solid var(--portal-border);
  border-radius:12px;
  background:var(--portal-surface);
  color:var(--portal-text);
  font:inherit;
}

.portal-login-field input:focus{
  outline:2px solid rgba(32, 107, 86, 0.18);
  outline-offset:1px;
  border-color:rgba(32, 107, 86, 0.34);
}

.portal-login-password{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:10px;
  align-items:center;
}

.portal-login-password__toggle{
  min-width:88px;
  min-height:46px;
  border:1px solid rgba(32, 107, 86, 0.2);
  border-radius:12px;
  background:transparent;
  color:var(--portal-primary);
  font:inherit;
  font-weight:600;
  cursor:pointer;
}

.portal-login-password__toggle:hover{
  background:rgba(32, 107, 86, 0.06);
}

.portal-capabilities,
.portal-trust{
  margin-top:24px;
  border:1px solid var(--portal-border);
  border-radius:24px;
  background:var(--portal-bg-secondary);
  padding:14px 14px 12px;
}

.portal-capability-grid,
.portal-trust-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
  margin-top:10px;
}

.portal-capability-item,
.portal-trust-card{
  min-height:86px;
  padding:14px;
}

.portal-capability-item{
  background:var(--portal-surface-muted);
}

.portal-footer{
  display:flex;
  justify-content:space-between;
  gap:18px;
  margin-top:12px;
  padding-top:10px;
  border-top:1px solid var(--portal-border);
  color:var(--portal-text-tertiary);
  font-size:11px;
}

@media (max-width: 1200px){
  .portal-shell{
    width:min(100%, 1220px);
    padding:14px 20px 18px;
  }

  .portal-hero-split{
    grid-template-columns:minmax(0, 1fr) minmax(340px, .88fr);
    gap:28px;
  }

  .portal-hero-title{
    font-size:52px;
  }

  .portal-hero-subheadline{
    font-size:16px;
  }
}

@media (max-width: 900px){
  .portal-shell{
    padding:14px 16px 20px;
  }

  .portal-hero-split{
    grid-template-columns:1fr;
    gap:22px;
  }

  .portal-hero-content{
    padding-top:6px;
  }

  .portal-hero-title{
    font-size:44px;
    max-width:760px;
  }

  .portal-hero-subheadline{
    max-width:none;
  }

  .portal-access-stack{
    padding-top:0;
    max-width:760px;
  }
}

@media (max-width: 768px){
  .portal-shell{
    padding:12px 12px 18px;
  }

  .portal-title{
    font-size:17px;
  }

  .portal-subtitle,
  .portal-subtitle-secondary{
    font-size:11px;
  }

  .portal-hero-title{
    font-size:36px;
    line-height:1.02;
  }

  .portal-hero-subheadline{
    font-size:15px;
  }

  .portal-bullet-list li{
    font-size:14px;
  }

  .portal-capability-grid,
  .portal-trust-grid{
    grid-template-columns:1fr;
  }

  .portal-footer{
    flex-direction:column;
    align-items:flex-start;
  }
}
