@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --bg0:#0b0d10;
  --bg1:#11151b;
  --text:#e7e3da;
  --muted:rgba(231,227,218,0.7);
  --dim:rgba(231,227,218,0.55);
  --glass:rgba(10,12,16,0.55);
  --border:rgba(231,227,218,0.16);
  --accent:#b7ff5a;
  --accent2:#66ffd1;
  --shadow:rgba(0,0,0,0.55);
  --mx:50vw;
  --my:35vh;
  --radius:28px;
  --ease:cubic-bezier(.2,.8,.2,1);
}
/* Akilli Enterprise access screen v2 */
:root {
  --ae-bg: #0B0B0D;
  --ae-surface: #111114;
  --ae-surface-hover: #151519;
  --ae-border: #1D1D22;
  --ae-border-hover: #2A2A31;
  --ae-text: #F4F4F5;
  --ae-muted: #A1A1AA;
  --ae-subtle: #71717A;
  --ae-green: #22C55E;
}

html {
  color-scheme: dark;
  background: var(--ae-bg) !important;
}

body.access-login-page {
  min-height: 100vh;
  min-height: 100dvh;
  margin: 0;
  overflow: auto;
  color: var(--ae-text);
  background: var(--ae-bg) !important;
  font-family: "Manrope", sans-serif;
}

body.access-login-page::before,
body.access-login-page::after {
  content: none !important;
}

.ae-page {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 24px;
  background: var(--ae-bg);
}

.ae-shell {
  width: min(100%, 720px);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 40px;
}

.ae-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 16px;
}

.ae-system-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--ae-muted);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.ae-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ae-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--ae-green);
}

.ae-version {
  color: var(--ae-subtle);
}

.ae-logo {
  display: block;
  width: min(100%, 340px);
  height: auto;
  object-fit: contain;
}

.ae-subtitle {
  margin: 0;
  color: var(--ae-muted);
  font-size: 17px;
  font-weight: 500;
  line-height: 1.5;
}

.ae-access-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.ae-access-card,
.ae-admin-panel {
  background: var(--ae-surface);
  border: 1px solid var(--ae-border);
  border-radius: 24px;
}

.ae-access-card {
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 24px;
  padding: 28px;
  color: inherit;
  text-decoration: none;
}

.ae-access-card:hover {
  background: var(--ae-surface-hover);
  border-color: var(--ae-border-hover);
}

.ae-card-icon {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--ae-border);
  border-radius: 14px;
  color: var(--ae-text);
  font-size: 21px;
}

.ae-card-copy {
  display: grid;
  gap: 8px;
}

.ae-card-title {
  color: var(--ae-text);
  font-size: 22px;
  font-weight: 650;
  letter-spacing: -0.025em;
  line-height: 1.15;
}

.ae-card-desc {
  max-width: 28ch;
  color: var(--ae-muted);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
}

.ae-card-action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #D4D4D8;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: 0.01em;
}

.ae-admin-panel {
  width: min(100%, 520px);
  align-self: center;
  padding: 28px;
}

.ae-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  color: var(--ae-muted);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
}

.ae-back:hover {
  color: var(--ae-text);
}

.ae-panel-heading {
  display: grid;
  gap: 8px;
  margin-bottom: 24px;
}

.ae-panel-heading h1 {
  margin: 0;
  color: var(--ae-text);
  font-size: 28px;
  font-weight: 650;
  line-height: 1.15;
  letter-spacing: -0.035em;
}

.ae-panel-heading p {
  margin: 0;
  color: var(--ae-muted);
  font-size: 14px;
  line-height: 1.5;
}

.ae-mode-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 24px;
  padding: 4px;
  border: 1px solid var(--ae-border);
  border-radius: 16px;
}

.ae-mode-pill {
  height: 40px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--ae-muted);
  font: inherit;
  font-size: 13px;
  font-weight: 650;
  cursor: pointer;
}

.ae-mode-pill.is-on {
  background: #1A1A1F;
  color: var(--ae-text);
}

.ae-auth-form {
  display: grid;
  gap: 16px;
}

.ae-field {
  display: grid;
  gap: 8px;
}

.ae-label {
  color: #D4D4D8;
  font-size: 13px;
  font-weight: 650;
}

.ae-input {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--ae-border);
  border-radius: 14px;
  background: #0B0B0D;
  color: var(--ae-text);
  padding: 0 14px;
  font: inherit;
  font-size: 15px;
}

.ae-input::placeholder {
  color: #52525B;
}

.ae-input:focus {
  outline: none;
  border-color: #3F3F46;
}

.ae-submit {
  min-height: 48px;
  margin-top: 8px;
  border: 1px solid #F4F4F5;
  border-radius: 14px;
  background: #F4F4F5;
  color: #0B0B0D;
  font: inherit;
  font-size: 14px;
  font-weight: 750;
  cursor: pointer;
}

.ae-submit:hover {
  background: #FFFFFF;
}

.ae-form-error {
  padding: 12px 14px;
  border: 1px solid #7F1D1D;
  border-radius: 14px;
  background: #1F1111;
  color: #FCA5A5;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
}

.ae-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px 24px;
  color: var(--ae-subtle);
  font-size: 12px;
  font-weight: 550;
}

.ae-footer > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ae-footer strong {
  color: var(--ae-muted);
  font-weight: 600;
}

.is-hidden,
.isHidden {
  display: none !important;
}

@media (max-width: 720px) {
  .ae-page {
    align-items: flex-start;
    padding: 48px 16px;
  }

  .ae-shell {
    gap: 32px;
  }

  .ae-access-grid {
    grid-template-columns: 1fr;
  }

  .ae-access-card {
    min-height: 188px;
    padding: 24px;
  }

  .ae-admin-panel {
    padding: 24px;
  }
}
*{box-sizing:border-box}
html,body{height:100%}
html{color-scheme:dark}
body{
  margin:0;
  color:var(--text);
  background:#000 !important;
  font-family:"Manrope", sans-serif;
  overflow-x:hidden;
  overflow-y:hidden; /* keep login page from scrolling */
}

body.access-login-page,
body.access-login-page .bg,
body.access-login-page .bgPhoto,
body.access-login-page .bgPhoto::after {
  background:#000 !important;
  background-color:#000 !important;
  background-image:none !important;
  filter:none !important;
  opacity:1 !important;
}

body.access-login-page .bgGradient,
body.access-login-page .bgGrid,
body.access-login-page .grain {
  display:none !important;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:transparent;
  mix-blend-mode:screen;
  opacity:.52;
  transition:opacity 250ms var(--ease);
}

/* Leave transition (after successful submit) */
body.isLeaving .page{
  opacity: 0;
  transform: translateY(10px) scale(0.99);
  filter: blur(6px);
  transition: opacity 420ms var(--ease), transform 420ms var(--ease), filter 420ms var(--ease);
}
.page{
  transition: opacity 420ms var(--ease), transform 420ms var(--ease), filter 420ms var(--ease);
}

.bg{position:fixed; inset:0; pointer-events:none}
.bgPhoto{
  background:#000;
  opacity:1;
}
.bgPhoto::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:#000;
  opacity:1;
}
.bgGradient{
  display:none;
}

.bgGrid{
  display:none;
}

.grain{
  display:none;
}

@keyframes grainMove{
  0%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(-6%,4%,0)}
  100%{transform:translate3d(0,0,0)}
}

.page{
  position:relative;
  height:100dvh;
  min-height:100dvh;
  display:grid;
  grid-template-columns:minmax(420px, 600px) 1fr;
  gap:min(6vw, 72px);
  padding:clamp(16px, 3.2vw, 44px);
  max-width:1280px;
  margin:0 auto;
  align-items:center;
}

.leftModule{
  grid-column:1;
  align-self:center;
  justify-self:center;
  width:min(560px, 100%);
}
.rightPane{grid-column:2; min-height:60vh}
.brandLeft{
  padding:8px 0;
  width:min(520px, 92vw);
  margin-inline:auto;
  text-align:center;
}
.authRight{margin-top:22px}
.authRight{display:flex; justify-content:center}
.cardWrap{position:relative; width:min(520px, 92vw); margin-inline:auto}
.brandTopline{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:rgba(231,227,218,0.78);
  font-size:13px;
  letter-spacing:.06em;
}
.dotStatus{
  width:9px;height:9px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 6px rgba(183,255,90,0.12), 0 0 24px rgba(183,255,90,0.28);
}
.brandSep{opacity:.55}
.brandClock,.brandDate{font-variant-numeric:tabular-nums}

.heroTitle{
  margin:18px 0 0;
  font-family:"Manrope", sans-serif;
  font-weight:600;
  letter-spacing:-0.02em;
}
.heroKicker{
  display:block;
  font-size:clamp(18px, 2.2vw, 28px);
  color:rgba(231,227,218,0.86);
}
.heroMain{
  display:block;
  margin-top:10px;
  font-size:clamp(44px, 6.5vw, 84px);
  line-height:0.98;
}
.heroMain{
  width:fit-content;
  margin-inline:auto;
}
.heroLogo{
  display:block;
  height:clamp(62px, 9vw, 120px);
  width:auto;
  max-width:min(560px, 92%);
  object-fit:contain;
  filter:drop-shadow(0 24px 70px rgba(0,0,0,0.55));
  transform:none;
}

.heroSlogan{
  margin:18px 0 0;
  font-size:clamp(14px, 1.7vw, 18px);
  color:var(--muted);
  max-width:52ch;
  margin-inline:auto;
}

/* Prevent vertical scroll on shorter screens by tightening the layout. */
@media (max-height: 760px){
  .authRight{ margin-top: 12px; }
  .heroTitle{ margin-top: 12px; }
  .heroSlogan{ margin-top: 12px; }
  .glassCard{ padding: 18px 18px 18px; }
  .sequence{ min-height: 44px; }
  .mantra{ display:none; }
}
@media (max-height: 680px){
  .page{ padding: 14px 14px 16px; gap: 18px; }
  .chartBehind{ display:none; }
  .authMeta{ display:none; }
}
.sloganLine{
  display:block;
  opacity:0;
  transform:translateY(8px);
  filter:blur(4px);
  transition:opacity 900ms var(--ease), transform 900ms var(--ease), filter 900ms var(--ease);
}
.sloganLine.isActive{
  opacity:1;
  transform:translateY(0);
  filter:blur(0);
}

.mantra{
  position:fixed;
  left:59%;
  top:72%;
  transform:translate(-50%, -50%);
  width:min(760px, 84vw);
  text-align:center;
  font-size:clamp(14px, 1.45vw, 18px);
  color:rgba(231,227,218,0.70);
  letter-spacing:0.01em;
  text-shadow:0 18px 60px rgba(0,0,0,0.75);
  pointer-events:none;
  opacity:0.92;
}
.mantraWord{
  display:inline-block;
  opacity:0;
  transform:translateY(6px);
  filter:blur(4px);
  transition:opacity 700ms var(--ease), transform 700ms var(--ease), filter 700ms var(--ease);
  will-change:opacity, transform, filter;
}
.mantraWord.isOn{
  opacity:1;
  transform:translateY(0);
  filter:blur(0);
}
.mantraGap{
  display:inline-block;
  width:0.35em;
}

.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace}
.pill{
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(231,227,218,0.16);
  color:rgba(231,227,218,0.86);
  font-size:12px;
  background:rgba(10,12,16,0.25);
}
.pill.ok{
  border-color:rgba(183,255,90,0.34);
  box-shadow:0 0 0 6px rgba(183,255,90,0.10);
}

.authRight{display:flex; justify-content:flex-start}
.cardWrap{position:relative; width:min(460px, 92vw)}
.chartBehind{
  position:absolute;
  inset:-26px -18px auto -18px;
  height:160px;
  opacity:.65;
  filter:blur(0.2px);
  pointer-events:none;
}
.chartSvg{width:100%; height:100%}

.glassCard{
  position:relative;
  border-radius:var(--radius);
  padding:22px 20px 26px;
  background:linear-gradient(180deg, rgba(10,12,16,0.62), rgba(10,12,16,0.28));
  border:1px solid rgba(231,227,218,0.14);
  box-shadow:0 24px 80px rgba(0,0,0,0.55);
  backdrop-filter:blur(18px);
  transform-style:preserve-3d;
  transition:transform 250ms var(--ease), border-color 250ms var(--ease), box-shadow 250ms var(--ease);
}
.glassCard::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:calc(var(--radius) + 1px);
  background:radial-gradient(700px 280px at 30% 20%, rgba(183,255,90,0.20), transparent 52%),
             radial-gradient(700px 280px at 70% 10%, rgba(102,255,209,0.12), transparent 54%);
  opacity:.0;
  transition:opacity 260ms var(--ease);
  pointer-events:none;
}
.glassCard.isFocus{
  border-color:rgba(183,255,90,0.28);
  box-shadow:0 26px 96px rgba(0,0,0,0.64), 0 0 0 8px rgba(183,255,90,0.06);
}
.glassCard.isFocus::before{opacity:1}

.cardHeader{display:flex; align-items:baseline; justify-content:space-between; gap:12px}
.cardTitle{font-family:"Manrope", sans-serif; font-weight:600; letter-spacing:-0.01em; font-size:22px}
.cardSubtitle{color:rgba(231,227,218,0.64); font-size:13px}

.authForm{margin-top:16px; display:grid; gap:14px}
.field{display:grid; gap:8px}
.label{font-size:12px; color:rgba(231,227,218,0.72); letter-spacing:.08em; text-transform:uppercase}
.inputShell{
  position:relative;
  border-radius:16px;
  border:1px solid rgba(231,227,218,0.14);
  background:rgba(0,0,0,0.18);
  overflow:hidden;
  transition:border-color 220ms var(--ease), box-shadow 220ms var(--ease), background-color 220ms var(--ease);
}
.input{
  width:100%;
  padding:14px 44px 14px 14px;
  border:0;
  outline:none;
  background:transparent;
  color:rgba(231,227,218,0.92);
  font-size:15px;
  font-variant-numeric:tabular-nums;
}
.input::placeholder{color:rgba(231,227,218,0.38)}
.input:focus-visible + .caret{opacity:1}
.inputShell:has(.input:focus-visible),
.inputShell.isActiveFocus{
  border-color:rgba(183,255,90,0.30);
  box-shadow:0 0 0 6px rgba(183,255,90,0.08);
  background:rgba(0,0,0,0.22);
}
.caret{
  position:absolute;
  right:14px; top:50%;
  width:10px; height:18px;
  transform:translateY(-50%);
  border-radius:4px;
  background:linear-gradient(180deg, rgba(183,255,90,0.0), rgba(183,255,90,0.85), rgba(183,255,90,0.0));
  opacity:0;
  animation:caretPulse 1.15s var(--ease) infinite;
}
@keyframes caretPulse{0%,100%{opacity:.15}50%{opacity:.85}}

.btnPrimary{
  margin-top:4px;
  position:relative;
  border:0;
  border-radius:16px;
  padding:14px 14px;
  color:#0b0d10;
  font-weight:700;
  letter-spacing:.02em;
  background:
    radial-gradient(100% 140% at 30% 20%, rgba(255,255,255,0.35), rgba(255,255,255,0) 60%),
    linear-gradient(90deg, var(--accent), rgba(102,255,209,0.78));
  cursor:pointer;
  transition:transform 180ms var(--ease), filter 180ms var(--ease);
}
.btnPrimary:hover{transform:translateY(-1px); filter:saturate(1.05)}
.btnPrimary:active{transform:translateY(0)}
.btnPrimary:disabled{cursor:not-allowed; filter:grayscale(.2) saturate(.85); opacity:.95}
.btnText{position:relative; z-index:1}
.btnSpinner{
  position:absolute;
  right:14px; top:50%;
  width:18px;height:18px;
  margin-top:-9px;
  border-radius:999px;
  border:2px solid rgba(11,13,16,0.22);
  border-top-color:rgba(11,13,16,0.68);
  opacity:0;
  transform:scale(.9);
  transition:opacity 160ms var(--ease), transform 160ms var(--ease);
  animation:spin 800ms linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.btnPrimary.isLoading .btnSpinner{opacity:1; transform:scale(1)}

.authMeta{
  margin-top:6px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.metaRow{
  padding:10px 10px;
  border-radius:16px;
  border:1px solid rgba(231,227,218,0.10);
  background:rgba(0,0,0,0.14);
}
.metaKey{display:block; font-size:11px; color:rgba(231,227,218,0.62); letter-spacing:.1em; text-transform:uppercase}
.metaVal{display:block; margin-top:6px; font-size:13px; color:rgba(231,227,218,0.88); font-variant-numeric:tabular-nums}

.sequence{
  margin-top:10px;
  border-radius:16px;
  border:1px solid rgba(231,227,218,0.10);
  background:rgba(0,0,0,0.14);
  padding:12px 12px;
  min-height:56px;
}
.seqLine{font-size:12px; line-height:1.55}
.dim{color:rgba(231,227,218,0.58)}

/* --- Integration additions (real auth + passcode) --- */
.modeRow{
  display:flex;
  gap:10px;
  margin: 6px 0 2px;
}
.modePill{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:30px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(231,227,218,0.12);
  background:rgba(0,0,0,0.16);
  color:rgba(231,227,218,0.78);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  user-select:none;
  transition: border-color 180ms var(--ease), background 180ms var(--ease), color 180ms var(--ease), transform 180ms var(--ease);
}
.modePill:hover{ transform: translateY(-1px); }
.modePill input{ position:absolute; opacity:0; pointer-events:none; }
.modePill.isOn{
  border-color:rgba(183,255,90,0.32);
  background:rgba(183,255,90,0.08);
  color:rgba(231,227,218,0.92);
  box-shadow:0 0 0 6px rgba(183,255,90,0.06);
}
.formError{
  margin-top: 6px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(239,68,68,0.25);
  background: rgba(127,29,29,0.22);
  color: rgba(254,226,226,0.92);
  font-size: 12px;
  line-height: 1.4;
}
.isHidden{ display:none !important; }

/* --- Portal chooser (admin vs staff) --- */
.portalHeader{ margin-bottom:4px; }
.portalGrid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-top:4px;
}
.portalCard{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  padding:16px 16px 14px;
  border-radius:20px;
  border:1px solid rgba(231,227,218,0.14);
  background:rgba(0,0,0,0.18);
  color:inherit;
  text-decoration:none;
  transition:border-color 200ms var(--ease), background 200ms var(--ease), transform 200ms var(--ease), box-shadow 200ms var(--ease);
}
.portalCard:hover{
  transform:translateY(-2px);
  border-color:rgba(183,255,90,0.28);
  background:rgba(183,255,90,0.06);
  box-shadow:0 12px 40px rgba(0,0,0,0.28);
}
.portalCard-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(231,227,218,0.12);
  background:rgba(0,0,0,0.22);
  font-size:20px;
  color:var(--accent);
}
.portalCard--staff .portalCard-ico{ color:var(--accent2); }
.portalCard-title{
  font-family:"Manrope", sans-serif;
  font-size:18px;
  font-weight:600;
  letter-spacing:-0.02em;
}
.portalCard-desc{
  font-size:13px;
  line-height:1.45;
  color:rgba(231,227,218,0.72);
}
.portalCard-cta{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(183,255,90,0.92);
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.portalCard--staff .portalCard-cta{ color:rgba(102,255,209,0.92); }
.portalBack{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:8px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.04em;
  color:rgba(231,227,218,0.68);
  text-decoration:none;
  transition:color 180ms var(--ease);
}
.portalBack:hover{ color:rgba(231,227,218,0.95); }

@media (max-width: 980px){
  .page{grid-template-columns:1fr; gap:28px; align-items:start; padding:24px 18px 28px}
  .bgPhoto{background-position:center; opacity:1}
  .rightPane{display:none}
  .authRight{margin-top:16px}
  .mantra{
    left:50%;
    top:76%;
    width:min(720px, 90vw);
    opacity:0.86;
  }
}

@media (prefers-reduced-motion: reduce){
  .grain,.bgGrid{animation:none !important}
  body::before{transition:none}
  .sloganLine{transition:none}
  .mantraWord{transition:none}
  .caret{animation:none}
  .btnPrimary,.glassCard{transition:none}
}

