/* 1. Account menu */
.nav-action-group { display: inline-flex; align-items: center; justify-content: flex-end; gap: 12px; flex-shrink: 0; }
.account-menu { position: relative; display: inline-flex; align-items: center; justify-content: center; margin: 0; z-index: 80; }
.account-menu-trigger { position: relative; width: 54px; min-width: 54px; height: 54px; padding: 0; display: inline-flex; align-items: center; justify-content: center; gap: 0; overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 18px; background: #0f0f0f; color: var(--text); transition: border-color 0.25s ease, background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease; cursor: pointer; }
.account-menu-trigger:hover, .account-menu-trigger:focus-visible, .account-menu-trigger[aria-expanded="true"] { width: 54px; min-width: 54px; border-color: rgba(255, 255, 255, 0.3); background: #121212; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28); }
.account-avatar { width: 30px; min-width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: linear-gradient(135deg, #ff2b2b, #711111); color: #fff; font-size: 11px; font-weight: 900; line-height: 1; letter-spacing: 0.4px; text-transform: uppercase; }
.account-avatar-large { width: 44px; min-width: 44px; height: 44px; font-size: 13px; }
.account-label, .account-chevron { display: none !important; opacity: 0 !important; visibility: hidden !important; width: 0 !important; min-width: 0 !important; max-width: 0 !important; height: 0 !important; overflow: hidden !important; pointer-events: none !important; }
.account-dropdown[hidden] { display: none !important; }
.account-dropdown { position: absolute; top: calc(100% + 12px); right: 0; width: min(310px, calc(100vw - 32px)); padding: 12px; display: grid; gap: 6px; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 22px; background: rgba(8, 8, 10, 0.97); color: #fff; box-shadow: 0 24px 70px rgba(0, 0, 0, 0.45); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); z-index: 10000; }
.account-dropdown-header { padding: 12px; display: flex; align-items: center; gap: 12px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.account-dropdown-header strong { display: block; margin-bottom: 4px; color: #fff; font-size: 14px; font-weight: 900; line-height: 1.15; }
.account-dropdown-header p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.35; word-break: break-word; }
.account-dropdown-link { width: 100%; min-height: 42px; padding: 0 12px; display: flex; align-items: center; justify-content: flex-start; border: 0; border-radius: 14px; background: transparent; color: rgba(255, 255, 255, 0.82); font-size: 13px; font-weight: 800; text-align: left; text-decoration: none; transition: 0.22s ease; cursor: pointer; }
.account-dropdown-link:hover { background: rgba(255, 255, 255, 0.055); color: #fff; }
.account-dropdown-link.is-disabled { color: rgba(255, 255, 255, 0.38); cursor: not-allowed; pointer-events: none; }
.account-signout-btn { margin-top: 6px; color: #ff6b6b; }

/* 2. Page menu overrides */
.contact-page-shell .account-menu-trigger, .contact-page-shell .account-menu-trigger:hover, .contact-page-shell .account-menu-trigger:focus-visible, .contact-page-shell .account-menu-trigger[aria-expanded="true"] { width: 46px; min-width: 46px; height: 46px; border-radius: 12px; border-color: rgba(9, 12, 2, 0.28); background: #090c02; color: #dde2c6; box-shadow: none; transform: none; }
.contact-page-shell .account-avatar { width: 30px; min-width: 30px; height: 30px; background: #a72608; color: #dde2c6; font-size: 12px; }
.contact-page-shell .account-dropdown { width: 280px; padding: 14px; border-radius: 18px; border-color: rgba(9, 12, 2, 0.18); background: #dde2c6; color: #090c02; box-shadow: 0 22px 50px rgba(9, 12, 2, 0.18); backdrop-filter: none; -webkit-backdrop-filter: none; }
.contact-page-shell .account-dropdown-header { border-bottom-color: rgba(9, 12, 2, 0.12); }
.contact-page-shell .account-dropdown-header strong { color: #090c02; }
.contact-page-shell .account-dropdown-header p { color: rgba(9, 12, 2, 0.62); }
.contact-page-shell .account-dropdown-link { color: #090c02; }
.contact-page-shell .account-dropdown-link:hover { background: rgba(167, 38, 8, 0.1); color: #a72608; }
.contact-page-shell .account-signout-btn { color: #a72608; }
.about-page-shell .account-menu-trigger, .about-page-shell .account-menu-trigger:hover, .about-page-shell .account-menu-trigger:focus-visible, .about-page-shell .account-menu-trigger[aria-expanded="true"] { border-color: rgba(208, 83, 83, 0.22); background: rgba(208, 83, 83, 0.055); color: #d05353; box-shadow: none; }
.about-page-shell .account-avatar { background: linear-gradient(135deg, #d05353, #7c2525); color: #191919; }

/* 3. Auth page shell */
.login-page { min-height: 100svh; background: #030303; color: #fff; }
.login-shell { min-height: 100svh; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(420px, 0.95fr); background: radial-gradient(circle at 20% 30%, rgba(255, 43, 43, 0.18), transparent 28%), radial-gradient(circle at 70% 75%, rgba(255, 255, 255, 0.06), transparent 22%), linear-gradient(135deg, #050505, #0d0d10 48%, #150606); }
.login-brand-panel, .login-panel { min-height: 100svh; padding: clamp(28px, 5vw, 72px); display: flex; flex-direction: column; }
.login-brand-panel { justify-content: space-between; border-right: 1px solid rgba(255, 255, 255, 0.08); }
.login-panel { justify-content: center; align-items: center; background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)); }

/* 4. Auth brand panel */
.login-logo-block, .login-logo-row { width: fit-content; display: inline-flex; align-items: center; gap: 14px; }
.login-logo-text { display: flex; flex-direction: column; line-height: 1; }
.login-logo-text strong { font-size: 14px; text-transform: uppercase; letter-spacing: 1.4px; }
.login-logo-text span { margin-top: 4px; color: rgba(255, 255, 255, 0.62); font-size: 13px; letter-spacing: 1px; }
.login-product-copy { max-width: 660px; }
.login-kicker { margin-bottom: 14px; color: var(--accent); font-size: 11px; font-weight: 900; letter-spacing: 3px; text-transform: uppercase; }
.login-product-copy h1 { max-width: 760px; font-size: clamp(44px, 7vw, 92px); font-weight: 900; line-height: 0.95; letter-spacing: -4px; }
.login-product-copy p { max-width: 560px; margin-top: 24px; color: rgba(255, 255, 255, 0.62); font-size: 17px; line-height: 1.7; }
.login-status-card { max-width: 460px; padding: 18px; display: flex; align-items: center; gap: 14px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 22px; background: rgba(255, 255, 255, 0.035); }
.login-status-dot { width: 12px; height: 12px; border-radius: 999px; background: #ff2b2b; box-shadow: 0 0 0 8px rgba(255, 43, 43, 0.1); }
.login-status-card strong { display: block; margin-bottom: 4px; font-size: 14px; }
.login-status-card p { margin: 0; color: rgba(255, 255, 255, 0.58); font-size: 13px; line-height: 1.5; }

/* 5. Auth card */
.login-card { width: min(520px, 100%); padding: 34px; display: grid; gap: 22px; border: 1px solid rgba(255, 255, 255, 0.11); border-radius: 30px; background: rgba(5, 5, 6, 0.72); box-shadow: 0 30px 90px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.06); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); }
.login-card-compact { max-width: 470px; }
.login-panel-header { max-width: 500px; }
.login-panel-header h2 { margin-bottom: 12px; font-size: clamp(34px, 4vw, 52px); font-weight: 900; letter-spacing: -2px; }
.login-panel-header p:not(.login-kicker) { color: rgba(255, 255, 255, 0.6); font-size: 15px; line-height: 1.7; }

/* 6. Auth messages */
.auth-message { padding: 12px 14px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 14px; background: rgba(255, 255, 255, 0.055); color: rgba(255, 255, 255, 0.78); font-size: 13px; font-weight: 700; line-height: 1.5; }
.auth-message[data-type="error"] { border-color: rgba(255, 43, 43, 0.45); background: rgba(255, 43, 43, 0.1); color: #ffb2b2; }
.auth-message[data-type="info"] { border-color: rgba(255, 255, 255, 0.14); color: rgba(255, 255, 255, 0.76); }
.auth-message[data-type="success"] { border-color: rgba(86, 255, 154, 0.32); background: rgba(86, 255, 154, 0.08); color: #baffd4; }

/* 7. Auth forms */
.login-form-preview { display: grid; gap: 12px; }
.login-form-preview label { display: grid; gap: 8px; color: rgba(255, 255, 255, 0.58); font-size: 11px; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; }
.login-form-preview input { width: 100%; height: 48px; padding: 0 14px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 14px; background: rgba(255, 255, 255, 0.045); color: rgba(255, 255, 255, 0.84); outline: 0; transition: 0.22s ease; }
.login-form-preview input::placeholder { color: rgba(255, 255, 255, 0.32); }
.login-form-preview input:focus { border-color: rgba(255, 43, 43, 0.55); box-shadow: 0 0 0 4px rgba(255, 43, 43, 0.08); }
.login-form-preview button { height: 48px; border: 1px solid rgba(255, 43, 43, 0.5); border-radius: 14px; background: linear-gradient(135deg, #ff2b2b, #981919); color: #fff; font-size: 12px; font-weight: 900; letter-spacing: 0.8px; text-transform: uppercase; cursor: pointer; transition: 0.22s ease; }
.login-form-preview button:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 16px 40px rgba(255, 43, 43, 0.18); }
.login-form-preview button:disabled { opacity: 0.55; cursor: wait; transform: none; box-shadow: none; }

/* 8. Session and page switch */
.continue-session-btn { width: 100%; min-height: 54px; padding: 0 18px; border: 1px solid rgba(255, 43, 43, 0.34); border-radius: 18px; background: rgba(255, 43, 43, 0.08); color: #fff; font-weight: 900; cursor: pointer; transition: 0.22s ease; }
.continue-session-btn:hover { transform: translateY(-2px); border-color: rgba(255, 43, 43, 0.58); background: rgba(255, 43, 43, 0.12); }
.auth-page-switch { display: flex; align-items: center; justify-content: center; gap: 8px; color: rgba(255, 255, 255, 0.54); font-size: 13px; font-weight: 700; }
.auth-page-switch a { color: var(--accent); font-weight: 900; text-decoration: none; }
.auth-page-switch a:hover { text-decoration: underline; }

/* 9. Dividers */
.login-divider { display: flex; align-items: center; gap: 12px; color: rgba(255, 255, 255, 0.42); font-size: 11px; font-weight: 900; letter-spacing: 1px; text-transform: uppercase; }
.login-divider::before, .login-divider::after { content: ""; height: 1px; flex: 1; background: rgba(255, 255, 255, 0.08); }

/* 10. Demo and info cards */
.demo-user-card, .login-coming-soon-card { width: 100%; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 26px; background: rgba(5, 5, 6, 0.78); color: #fff; }
.demo-user-card { min-height: 104px; padding: 18px; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; text-align: left; transition: 0.25s ease; cursor: pointer; }
.demo-user-card:hover { border-color: rgba(255, 43, 43, 0.62); transform: translateY(-3px); box-shadow: 0 22px 60px rgba(0, 0, 0, 0.35); }
.demo-user-avatar { width: 58px; height: 58px; display: inline-flex; align-items: center; justify-content: center; border-radius: 20px; background: linear-gradient(135deg, #ff2b2b, #701010); font-size: 15px; font-weight: 900; letter-spacing: 1px; }
.demo-user-info strong { display: block; margin-bottom: 6px; font-size: 16px; }
.demo-user-info small { color: rgba(255, 255, 255, 0.54); font-size: 13px; line-height: 1.35; }
.demo-user-action { padding: 10px 14px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); color: rgba(255, 255, 255, 0.86); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.8px; }
.is-secondary-demo { opacity: 0.75; }
.is-secondary-demo:hover { opacity: 1; }
.login-coming-soon-card { padding: 18px; display: flex; align-items: center; justify-content: space-between; gap: 16px; opacity: 0.86; }
.login-coming-soon-card strong { display: block; margin-bottom: 5px; font-size: 14px; }
.login-coming-soon-card p { margin: 0; color: rgba(255, 255, 255, 0.52); font-size: 13px; line-height: 1.45; }
.login-coming-soon-card span { padding: 8px 10px; border-radius: 999px; background: rgba(255, 255, 255, 0.07); color: rgba(255, 255, 255, 0.58); font-size: 11px; font-weight: 900; text-transform: uppercase; }

/* 11. Footnote */
.login-footnote { width: 100%; display: flex; justify-content: space-between; gap: 18px; color: rgba(255, 255, 255, 0.46); font-size: 12px; font-weight: 800; }
.login-footnote a { color: rgba(255, 255, 255, 0.74); text-decoration: none; }
.login-footnote a:hover { color: var(--accent); }

/* 12. Tablet auth */
@media (max-width: 980px) {
  .login-shell { grid-template-columns: 1fr; }
  .login-brand-panel, .login-panel { min-height: auto; }
  .login-brand-panel { gap: 48px; border-right: 0; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
  .login-product-copy h1 { letter-spacing: -2px; }
}

/* 13. Mobile account menu */
@media (max-width: 900px) {
  .account-menu-trigger, .account-menu-trigger:hover, .account-menu-trigger:focus-visible, .account-menu-trigger[aria-expanded="true"] { width: 54px; min-width: 54px; height: 54px; padding: 0; justify-content: center; border-radius: 18px; transform: none; }
  .account-dropdown { position: fixed; top: calc(88px + env(safe-area-inset-top)); left: 28px; right: 28px; width: auto; max-width: none; max-height: calc(100svh - 116px); overflow-y: auto; padding: 12px; border-radius: 22px; z-index: 10001; }
  .account-dropdown-header { padding: 10px; gap: 10px; }
  .account-avatar-large { width: 40px; min-width: 40px; height: 40px; }
  .account-dropdown-header strong { font-size: 13px; }
  .account-dropdown-header p { font-size: 11px; }
  .account-dropdown-link { min-height: 44px; padding: 0 10px; border-radius: 12px; font-size: 13px; }
  .account-signout-btn { margin-top: 4px; }
}

@media (max-width: 430px) {
  .account-dropdown { left: 18px; right: 18px; }
}

/* 14. Mobile login/register layout */
@media (max-width: 760px) {
  .login-page { overflow-x: hidden; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
  .login-page .login-shell { min-height: 100svh; display: flex; flex-direction: column; }
  .login-page .login-brand-panel { padding: calc(16px + env(safe-area-inset-top)) 20px 8px; }
  .login-page .login-brand-panel .login-product-copy, .login-page .login-brand-panel .login-status-card { display: none; }
  .login-page .login-logo-block, .login-page .login-logo-row { gap: 10px; }
  .login-page .login-brand-panel .logo-mark { width: 52px; min-width: 52px; height: 52px; border-radius: 16px; font-size: 17px; }
  .login-page .login-logo-text strong { font-size: 12px; letter-spacing: 1.4px; }
  .login-page .login-logo-text span { margin-top: 3px; font-size: 12px; letter-spacing: 0.7px; }
  .login-page .login-panel { min-height: auto; align-items: stretch; justify-content: flex-start; padding: 10px 20px calc(26px + env(safe-area-inset-bottom)); background: transparent; }
  .login-page .login-card { width: 100%; max-width: none; padding: 20px 18px; gap: 14px; border-radius: 24px; }
  .login-page .login-kicker { margin-bottom: 8px; font-size: 10px; letter-spacing: 3px; }
  .login-page .login-panel-header h2 { margin-bottom: 8px; font-size: clamp(30px, 9.6vw, 42px); line-height: 1.02; letter-spacing: -1.4px; }
  .login-page .login-panel-header p:not(.login-kicker) { font-size: 14px; line-height: 1.45; }
  .login-page .login-form-preview { gap: 11px; }
  .login-page .login-form-preview label { gap: 6px; font-size: 10px; letter-spacing: 0.9px; }
  .login-page .login-form-preview input { height: 46px; padding: 0 14px; border-radius: 14px; font-size: 16px; line-height: 1.2; }
  .login-page .login-form-preview button { height: 48px; border-radius: 16px; font-size: 12px; }
  .login-page .auth-page-switch { gap: 5px; flex-direction: column; font-size: 12px; text-align: center; }
  .login-page .login-divider { gap: 10px; font-size: 10px; letter-spacing: 0.9px; }
  .login-page .demo-user-card { min-height: auto; padding: 14px; grid-template-columns: auto 1fr; gap: 10px; border-radius: 18px; }
  .login-page .demo-user-avatar { width: 42px; height: 42px; border-radius: 14px; font-size: 12px; }
  .login-page .demo-user-info strong { margin-bottom: 3px; font-size: 14px; }
  .login-page .demo-user-info small { font-size: 11.5px; line-height: 1.3; }
  .login-page .demo-user-action { grid-column: 1 / -1; padding: 7px 10px; font-size: 10px; text-align: center; }
  .login-page .login-coming-soon-card { padding: 14px; border-radius: 18px; }
  .login-page .login-coming-soon-card strong { font-size: 13px; }
  .login-page .login-coming-soon-card p { font-size: 12px; line-height: 1.35; }
  .login-page .login-coming-soon-card span { padding: 6px 8px; font-size: 10px; }
  .login-page .login-footnote { gap: 6px; flex-direction: column; align-items: center; font-size: 11px; text-align: center; }
}

@media (max-width: 430px) {
  .login-page .login-brand-panel { padding: calc(14px + env(safe-area-inset-top)) 18px 6px; }
  .login-page .login-panel { padding: 8px 18px calc(22px + env(safe-area-inset-bottom)); }
  .login-page .login-card { padding: 18px 16px; gap: 13px; border-radius: 22px; }
  .login-page .login-panel-header h2 { font-size: clamp(30px, 9.3vw, 38px); }
  .register-page .login-coming-soon-card { display: none; }
}

/* 15. Desktop auth shrink */
@media (min-width: 981px) {
  .login-brand-panel, .login-panel { padding: clamp(24px, 4vw, 58px); }
  .login-product-copy h1 { font-size: clamp(42px, 6vw, 76px); letter-spacing: -3px; }
  .login-product-copy p { max-width: 500px; font-size: 15px; }
  .login-status-card { max-width: 410px; padding: 15px; }
  .login-card { width: min(455px, 100%); padding: 28px; gap: 18px; border-radius: 26px; }
  .login-panel-header h2 { font-size: clamp(32px, 3.2vw, 44px); letter-spacing: -1.5px; }
  .login-panel-header p:not(.login-kicker) { font-size: 14px; }
  .login-form-preview input, .login-form-preview button { height: 44px; }
  .demo-user-card { min-height: 88px; padding: 14px; gap: 13px; border-radius: 22px; }
  .demo-user-avatar { width: 50px; height: 50px; border-radius: 17px; }
}

/* 16. Compact auth shell tightening */
@media (min-width: 901px) and (max-height: 900px) {
  .auth-page .login-card { transform: scale(0.96); transform-origin: center; }
  .auth-page .login-brand-panel, .auth-page .login-panel { padding-top: 36px; padding-bottom: 36px; }
}