:root {
  --paper: #f5f7fa;
  --white: #ffffff;
  --ink: #071d34;
  --graphite: #182231;
  --muted: #5f6f82;
  --line: #d7e0ea;
  --gold: #d6ac47;
  --blue: #123e66;
  --steel: #e8eef5;
  --green: #0f766e;
  --red: #b42318;
  --shadow: 0 18px 42px rgba(7, 29, 52, 0.12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--paper); }
body {
  margin: 0;
  background: linear-gradient(180deg, #ffffff 0%, var(--paper) 58%, #ffffff 100%);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  letter-spacing: 0;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
[hidden] { display: none !important; }

.site-header,
.portal-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: grid;
  grid-template-columns: minmax(220px, 300px) 1fr auto;
  align-items: center;
  gap: 28px;
  min-height: 88px;
  padding: 12px clamp(20px, 5vw, 72px);
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 32px rgba(7, 29, 52, 0.06);
}
.portal-header { position: sticky; grid-template-columns: minmax(220px, 300px) 1fr; }
.brand img { width: 260px; height: auto; display: block; }
nav { display: flex; justify-content: center; gap: clamp(18px, 4vw, 44px); font-size: 14px; font-weight: 800; color: var(--ink); }
nav a { padding: 10px 0; border-bottom: 2px solid transparent; }
nav a:hover { color: var(--blue); border-color: var(--gold); }
.header-actions,
.hero-actions,
.checkout-actions,
.portal-status { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; justify-content: flex-end; }
.portal-status { color: var(--muted); font-size: 13px; font-weight: 800; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 20px;
  border: 1px solid var(--blue);
  background: var(--white);
  color: var(--blue);
  font: 800 14px/1 Arial, Helvetica, sans-serif;
  cursor: pointer;
}
.button.primary { background: linear-gradient(180deg, #dcb957, var(--gold)); border-color: var(--gold); color: #10151d; }
.button.secondary { background: var(--white); color: var(--blue); }
.button.small { min-height: 34px; padding: 0 12px; font-size: 12px; }
.button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible { outline: 3px solid rgba(214, 172, 71, 0.42); outline-offset: 2px; }

.section { padding: clamp(56px, 7vw, 96px) clamp(22px, 5vw, 72px); }
.hero {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(480px, 1.1fr);
  gap: clamp(42px, 6vw, 84px);
  align-items: center;
  min-height: calc(100vh - 88px);
  border-bottom: 1px solid var(--line);
}
h1,
h2 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-weight: 700; letter-spacing: 0; color: var(--ink); }
h1 { max-width: 780px; font-size: clamp(50px, 6vw, 92px); line-height: 0.99; }
h1::after { content: ""; display: block; width: 72px; height: 3px; margin-top: 28px; background: var(--gold); }
h2 { font-size: clamp(32px, 4vw, 56px); line-height: 1.07; }
h3 { margin: 0; font-size: 20px; line-height: 1.2; color: var(--ink); }
p { color: var(--muted); font-size: 17px; line-height: 1.7; }
.lead { margin-top: 28px; color: var(--graphite); font-size: clamp(22px, 2.1vw, 30px); line-height: 1.35; }
.hero-actions { justify-content: flex-start; margin: 32px 0 40px; }
.proof-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin: 0; padding-top: 22px; border-top: 1px solid var(--line); }
.proof-strip dt { color: var(--gold); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.proof-strip dd { margin: 7px 0 0; color: var(--ink); font-size: 15px; font-weight: 800; }

.secure-panel,
.portal-card,
.admin-panel {
  background: var(--white);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.secure-panel { padding: clamp(28px, 4vw, 46px); }
.secure-panel h2 { margin-top: 10px; font-family: Arial, Helvetica, sans-serif; font-size: clamp(28px, 3vw, 42px); line-height: 1.14; }
.panel-label,
.panel-kicker,
.section-heading span {
  display: block;
  color: var(--gold);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}
.access-steps { display: grid; gap: 16px; margin: 30px 0 0; padding: 0; list-style: none; }
.access-steps li { display: grid; grid-template-columns: 48px 1fr; gap: 14px; align-items: start; padding: 18px 0; border-top: 1px solid var(--line); }
.access-steps strong { color: var(--gold); font-size: 13px; }
.access-steps span { color: var(--graphite); font-weight: 800; line-height: 1.45; }

.section-heading { max-width: 960px; margin-bottom: 40px; }
.section-heading h2,
.signup-copy h2 { margin-top: 10px; }
.services-section,
.membership-section,
.inquiry-section { background: var(--white); border-bottom: 1px solid var(--line); }
.principals-section,
.security-section { background: var(--paper); border-bottom: 1px solid var(--line); }
.service-rail,
.pricing-grid,
.principal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.service-rail article,
.pricing-grid article,
.principal-grid article {
  min-height: 300px;
  padding: 30px 26px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--white);
}
.service-rail span { color: var(--gold); font-weight: 900; }
.service-rail small { display: block; margin: 0 0 10px; color: var(--muted); font-size: 12px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; }
.service-rail h3 { margin-top: 26px; padding-bottom: 24px; border-bottom: 3px solid var(--gold); }
.service-rail p,
.pricing-grid p,
.principal-grid p { font-size: 15px; }
.split { display: grid; grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr); gap: clamp(32px, 5vw, 80px); align-items: start; }
.split > * { min-width: 0; }
.principal-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.pricing-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.section-note { margin-top: 28px; }
.control-list { display: grid; gap: 16px; }
.control-list article { padding: 26px; background: var(--white); border: 1px solid var(--line); box-shadow: 0 12px 30px rgba(7, 29, 52, 0.07); }
.control-list p { margin-bottom: 0; }

.inquiry-section {
  display: grid;
  grid-template-columns: minmax(280px, 0.78fr) minmax(360px, 1.22fr);
  gap: clamp(32px, 5vw, 78px);
  align-items: start;
}
.signup-form,
.portal-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 28px;
  background: var(--paper);
  border: 1px solid var(--line);
}
.portal-form { padding: 0; border: 0; background: transparent; }
.portal-form.compact { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 18px; }
.signup-form label,
.portal-form label {
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.signup-form input,
.signup-form select,
.signup-form textarea,
.portal-form input,
.portal-form select,
.portal-form textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  background: var(--white);
  color: var(--graphite);
  font: 600 15px/1.45 Arial, Helvetica, sans-serif;
  padding: 13px 14px;
}
textarea { resize: vertical; }
.wide,
.signup-form .button,
.signup-form .form-note,
.turnstile-slot { grid-column: 1 / -1; }
.signup-form .button { width: fit-content; }
.hp-field { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.55; }
.form-note[data-tone="success"],
[data-tone="success"] { color: var(--green); }
.form-note[data-tone="error"],
[data-tone="error"] { color: var(--red); }
.turnstile-slot { min-height: 70px; display: grid; align-items: center; }

.admin-page { background: var(--paper); }
.admin-shell { min-height: 100vh; display: grid; align-content: center; gap: 28px; }
.admin-panel { padding: 30px; max-width: 900px; }
.admin-panel h1 { font-size: clamp(38px, 5vw, 68px); }

.portal-page { background: var(--paper); }
.portal-shell {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  min-height: calc(100vh - 88px);
}
.portal-nav {
  position: sticky;
  top: 88px;
  align-self: start;
  min-height: calc(100vh - 88px);
  padding: 28px 20px;
  background: #0b223b;
  color: #eef5ff;
  border-right: 1px solid #173856;
}
.portal-nav a { display: block; padding: 13px 12px; border-left: 3px solid transparent; color: rgba(255, 255, 255, 0.78); font-size: 13px; font-weight: 800; }
.portal-nav a:hover { color: var(--white); border-color: var(--gold); background: rgba(255, 255, 255, 0.06); }
.portal-content { display: grid; gap: 24px; padding: clamp(24px, 4vw, 44px); }
.portal-band {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  padding: 28px;
  background: var(--white);
  border: 1px solid var(--line);
}
.portal-band h1 { font-size: clamp(40px, 5vw, 72px); }
.portal-band h2 { font-size: clamp(28px, 3vw, 44px); }
.security-summary { display: grid; gap: 10px; min-width: 240px; }
.security-summary span,
.permission-note {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--graphite);
  font-size: 12px;
  font-weight: 900;
}
.portal-grid { display: grid; gap: 24px; }
.portal-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.portal-card { padding: 26px; }
.portal-card h2 { font-family: Arial, Helvetica, sans-serif; font-size: 26px; margin-bottom: 20px; }
.portal-card-header { display: flex; justify-content: space-between; gap: 20px; align-items: start; margin-bottom: 18px; }
.portal-card-header h2 { margin: 8px 0 0; }
.resource-list,
.queue-list,
.audit-table { display: grid; gap: 12px; }
.resource-row,
.queue-row {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--line);
  background: var(--paper);
}
.resource-row strong,
.queue-row strong { display: block; color: var(--ink); }
.resource-row span,
.queue-row span { display: block; margin-top: 4px; color: var(--muted); font-size: 13px; }
.resource-row em { color: var(--green); font-style: normal; font-size: 12px; font-weight: 900; text-transform: uppercase; }
table { width: 100%; border-collapse: collapse; font-size: 14px; background: var(--white); }
th,
td { padding: 14px 16px; border-bottom: 1px solid var(--line); text-align: left; }
th { color: var(--gold); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
td { color: var(--graphite); font-weight: 700; }

@media (max-width: 1100px) {
  .site-header { grid-template-columns: 1fr auto; }
  .portal-header { grid-template-columns: 1fr; }
  nav { grid-column: 1 / -1; order: 3; justify-content: flex-start; overflow-x: auto; }
  .hero,
  .split,
  .inquiry-section,
  .portal-band { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .service-rail,
  .pricing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .portal-shell { grid-template-columns: 1fr; }
  .portal-nav { position: static; min-height: 0; display: flex; gap: 8px; overflow-x: auto; }
  .portal-grid.two { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .site-header,
  .portal-header { display: flex; flex-wrap: wrap; min-height: 0; }
  .brand img { width: 238px; }
  .header-actions,
  .portal-status { width: 100%; justify-content: flex-start; }
  h1 { font-size: 45px; }
  .proof-strip,
  .service-rail,
  .pricing-grid,
  .principal-grid,
  .signup-form,
  .portal-form,
  .portal-form.compact { grid-template-columns: 1fr; }
  .service-rail article,
  .pricing-grid article,
  .principal-grid article { min-height: 0; }
  .signup-form .button,
  .portal-form .button { width: 100%; }
  .portal-content { padding: 18px; }
  .portal-card-header,
  .resource-row,
  .queue-row { align-items: stretch; flex-direction: column; }
  table { min-width: 520px; }
  .audit-table { overflow-x: auto; }
}
