/* ==========================================================================
   ANNEX HOUSE — Brand Portal
   Portal chrome, login gate, dashboard, sections & asset locker.
   Builds on colors_and_type.css. No new colors. No icons. No emoji.
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

body {
  min-height: 100vh;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }

/* small utility */
.ah-mono { font-family: var(--ah-font-mono); }
.ah-cap  { text-transform: uppercase; }
.ah-label {
  text-transform: uppercase;
  letter-spacing: var(--ah-track-x-wide);
  font-size: var(--ah-step--1);
  font-weight: var(--ah-weight-bold);
}
.ah-muted { color: var(--ah-fg-3); }
.ah-stamp-tag {
  font-style: italic;
  font-weight: var(--ah-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--ah-track-wide);
}
.ah-stamp-tag::before { content: "*"; margin-right: .12em; }
.ah-stamp-tag::after  { content: "*"; margin-left: .12em; }

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

/* ==========================================================================
   1. LOGIN GATE  — kraft poster moment
   ========================================================================== */
#login {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: var(--ah-space-5);
  overflow: hidden;
  background: var(--ah-kraft) url("assets/annex_house_cardboard_stamp.jpeg") center center / cover no-repeat;
}

/* stamped wordmark repeats behind the login card */
.login-stamps {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.login-stamps span {
  position: absolute;
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  color: var(--ah-kraft-ink);
  white-space: nowrap;
  letter-spacing: var(--ah-track-tight);
  user-select: none;
}

.login-card {
  position: relative;
  z-index: 2;
  width: min(440px, 100%);
  background: var(--ah-white);
  border: var(--ah-border-1);
  padding: var(--ah-space-7) var(--ah-space-6) var(--ah-space-6);
}
.login-card .login-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--ah-space-4);
  margin-bottom: var(--ah-space-6);
}
.login-card .login-mark {
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  font-size: var(--ah-step-2);
  line-height: 1;
  letter-spacing: var(--ah-track-tight);
}
.login-card .login-logo {
  width: min(210px, 62%);
  height: auto;
  margin-top: 4px;
}
.login-card .login-mark small {
  display: block;
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  font-style: normal;
  margin-top: var(--ah-space-2);
  color: var(--ah-fg-3);
}
.login-card .login-version {
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  font-weight: var(--ah-weight-bold);
  text-transform: uppercase;
  background: var(--ah-ink);
  color: var(--ah-paper);
  padding: 3px 8px;
  white-space: nowrap;
}
.login-card h1 {
  font-size: var(--ah-step-3);
  margin: 0 0 var(--ah-space-2);
}
.login-card .login-sub {
  font-size: var(--ah-step-0);
  color: var(--ah-fg-2);
  margin: 0 0 var(--ah-space-5);
  line-height: var(--ah-leading-body);
}

.field { margin-bottom: var(--ah-space-4); }
.field > label {
  display: block;
  margin-bottom: var(--ah-space-2);
}
.field input,
.field select {
  width: 100%;
  font-family: var(--ah-font-mono);
  font-size: var(--ah-step-1);
  color: var(--ah-ink);
  background: var(--ah-paper);
  border: var(--ah-border-1);
  border-radius: 0;
  padding: var(--ah-space-3) var(--ah-space-3);
  appearance: none;
  -webkit-appearance: none;
  transition: box-shadow var(--ah-dur) var(--ah-ease);
}
.field select {
  background-image: none;
  cursor: pointer;
}
.field input:focus,
.field select:focus {
  outline: none;
  box-shadow: inset 0 0 0 1.5px var(--ah-ink);
}
.field input::placeholder { color: var(--ah-fg-3); }

/* role pills (segmented) */
.role-row {
  display: flex;
  gap: 0;
  border: var(--ah-border-1);
}
.role-row button {
  flex: 1;
  font-family: var(--ah-font-mono);
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  text-transform: uppercase;
  font-weight: var(--ah-weight-bold);
  background: var(--ah-white);
  color: var(--ah-ink);
  border: 0;
  border-right: var(--ah-border-hair);
  padding: var(--ah-space-3) var(--ah-space-2);
  cursor: pointer;
  transition: background var(--ah-dur) var(--ah-ease), color var(--ah-dur) var(--ah-ease);
}
.role-row button:last-child { border-right: 0; }
.role-row button[aria-pressed="true"] {
  background: var(--ah-ink);
  color: var(--ah-paper);
}

.btn {
  font-family: var(--ah-font-mono);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: var(--ah-track-wide);
  font-size: var(--ah-step-1);
  background: var(--ah-ink);
  color: var(--ah-paper);
  border: var(--ah-border-1);
  border-radius: 0;
  padding: var(--ah-space-3) var(--ah-space-5);
  cursor: pointer;
  transition: opacity var(--ah-dur) var(--ah-ease), box-shadow var(--ah-dur-fast) var(--ah-ease);
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ah-space-2);
}
.btn:hover { opacity: .8; }
.btn:active { box-shadow: var(--ah-shadow-flash); opacity: 1; }
.btn--ghost {
  background: transparent;
  color: var(--ah-ink);
}
.btn--sm { font-size: var(--ah-step-0); padding: var(--ah-space-2) var(--ah-space-4); width: auto; }

.login-error {
  font-size: var(--ah-step-0);
  color: var(--ah-blood);
  margin-top: var(--ah-space-3);
  min-height: 1.2em;
}
.login-foot {
  margin-top: var(--ah-space-5);
  padding-top: var(--ah-space-4);
  border-top: var(--ah-border-hair);
  font-size: var(--ah-step--1);
  color: var(--ah-fg-3);
  letter-spacing: var(--ah-track-wide);
  display: flex;
  justify-content: space-between;
  gap: var(--ah-space-3);
  flex-wrap: wrap;
}

/* ==========================================================================
   2. APP SHELL
   ========================================================================== */
#app { display: none; }
#app.is-on { display: block; }

.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ah-space-4);
  background: var(--ah-paper);
  border-bottom: var(--ah-border-1);
  padding: var(--ah-space-3) var(--ah-space-5);
  height: 60px;
}
.topbar .tb-left { display: flex; align-items: center; gap: var(--ah-space-4); }
.menu-toggle {
  display: none;
  font-family: var(--ah-font-mono);
  font-weight: var(--ah-weight-bold);
  font-size: var(--ah-step-0);
  letter-spacing: var(--ah-track-wide);
  background: transparent;
  border: var(--ah-border-hair);
  color: var(--ah-ink);
  padding: 6px 10px;
  cursor: pointer;
}
.tb-mark {
  display: inline-flex;
  align-items: center;
  gap: var(--ah-space-2);
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  font-size: calc(var(--tb-mark-base, var(--ah-step-1)) * var(--tb-mark-scale, 1));
  letter-spacing: var(--ah-track-tight);
  white-space: nowrap;
  min-width: 0;
}
.tb-mark .tb-logo { height: calc(var(--tb-logo-base, 15px) * var(--tb-mark-scale, 1)); width: auto; display: block; }
.tb-mark span { color: var(--ah-fg-3); font-weight: var(--ah-weight-reg); font-style: normal; }
.tb-right { display: flex; align-items: center; gap: var(--ah-space-4); }
.role-tag {
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  text-transform: uppercase;
  font-weight: var(--ah-weight-bold);
  background: var(--ah-white);
  color: var(--ah-ink);
  border: var(--ah-border-hair);
  padding: 4px 9px;
  white-space: nowrap;
}
.tb-logout {
  font-family: var(--ah-font-mono);
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-wide);
  text-transform: uppercase;
  color: var(--ah-link);
  text-decoration: underline;
  text-underline-offset: 2px;
  background: none;
  border: 0;
  cursor: pointer;
}
.tb-logout:hover { opacity: .7; }

.shell {
  display: grid;
  grid-template-columns: var(--shell-nav-width, 280px) 1fr;
  min-height: calc(100vh - 60px);
}

/* ----- Sidebar nav ----- */
.sidebar {
  border-right: var(--ah-border-1);
  background: var(--ah-paper);
  position: sticky;
  top: 60px;
  align-self: start;
  height: calc(100vh - 60px);
  overflow-y: auto;
  padding: var(--ah-space-5) 0 var(--ah-space-8);
}
.nav-group-label {
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  text-transform: uppercase;
  color: var(--ah-fg-3);
  font-weight: var(--ah-weight-bold);
  padding: var(--ah-space-4) var(--ah-space-5) var(--ah-space-2);
}
.nav-group-label::before { content: "{ "; }
.nav-group-label::after { content: " }"; }
.nav-link {
  display: flex;
  align-items: baseline;
  gap: var(--ah-space-3);
  width: 100%;
  text-align: left;
  background: none;
  border: 0;
  border-left: 3px solid transparent;
  padding: var(--ah-space-3) var(--ah-space-5);
  cursor: pointer;
  font-family: var(--ah-font-mono);
  color: var(--ah-fg-1);
  text-decoration: none;
  transition: background var(--ah-dur) var(--ah-ease), opacity var(--ah-dur) var(--ah-ease);
}
.nav-link:hover { background: var(--ah-paper-2); }
.nav-link .nav-num {
  font-size: var(--ah-step--1);
  color: var(--ah-fg-3);
  font-weight: var(--ah-weight-bold);
  min-width: 1.6em;
}
.nav-link .nav-title {
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: var(--ah-track-tight);
  font-size: var(--ah-step-0);
}
.sidebar .nav-link.is-active {
  background-color: var(--ah-ink);
  border-left-color: var(--ah-ink);
}
.sidebar .nav-link.is-active:hover { background-color: var(--ah-ink); }
.nav-link.is-active .nav-title { color: var(--ah-paper); }
.nav-link.is-active .nav-num { color: var(--ah-kraft); }
.nav-link.is-locked { opacity: .42; cursor: not-allowed; }
.nav-link.is-locked:hover { background: none; }
.nav-link .nav-lock {
  margin-left: auto;
  font-size: var(--ah-step--1);
  color: var(--ah-fg-3);
  font-style: italic;
}

/* ----- Content column ----- */
.content {
  min-width: 0;
  padding: var(--ah-space-7) var(--ah-space-8) var(--ah-space-10);
  max-width: 1100px;
}
@media (max-width: 1400px) { .content { padding-left: var(--ah-space-7); padding-right: var(--ah-space-7); } }

/* section header block */
.sec-head { margin-bottom: var(--ah-space-7); }
.sec-eyebrow {
  display: flex;
  align-items: center;
  gap: var(--ah-space-3);
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  text-transform: uppercase;
  font-weight: var(--ah-weight-bold);
  color: var(--ah-fg-3);
  margin-bottom: var(--ah-space-4);
}
.sec-eyebrow .num {
  background: var(--ah-ink);
  color: var(--ah-paper);
  padding: 3px 8px;
  letter-spacing: var(--ah-track-wide);
}
.sec-head h1 {
  font-size: var(--ah-step-5);
  margin: 0 0 var(--ah-space-4);
  text-wrap: balance;
}
.sec-head .sec-lede {
  font-size: var(--ah-step-2);
  color: var(--ah-fg-2);
  max-width: 60ch;
  line-height: var(--ah-leading-snug);
  font-style: italic;
}

/* generic prose */
.prose p { font-size: var(--ah-step-1); color: var(--ah-fg-2); line-height: var(--ah-leading-body); }
.prose p + p { margin-top: var(--ah-space-4); }
.scope-h {
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  font-size: var(--ah-step-2);
  letter-spacing: var(--ah-track-tight);
  margin: 0 0 var(--ah-space-3);
}
.scope-h::before { content: "{ "; color: var(--ah-fg-3); }
.scope-h::after  { content: " }"; color: var(--ah-fg-3); }

/* rule between blocks */
.rule { border: 0; border-top: var(--ah-border-1); margin: var(--ah-space-7) 0; }
.rule--hair { border-top: var(--ah-border-hair); margin: var(--ah-space-5) 0; }

/* cards & grid */
.grid { display: grid; gap: var(--ah-space-4); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

.card {
  border: var(--ah-border-1);
  background: var(--ah-white);
  padding: var(--ah-space-5);
}
.card--kraft {
  background-color: var(--ah-kraft);
  background-image: url("assets/texture-kraft.png");
  background-size: 240px 240px;
  color: var(--ah-kraft-ink);
  border-color: var(--ah-ink);
}
.card--ink { background: var(--ah-ink); color: var(--ah-paper); border-color: var(--ah-ink); }
.card--ink .scope-h::before, .card--ink .scope-h::after { color: var(--ah-kraft); }
.card .card-num {
  font-size: var(--ah-step-3);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  color: var(--ah-fg-3);
  line-height: 1;
  margin-bottom: var(--ah-space-3);
}
.card h3 {
  font-size: var(--ah-step-2);
  margin: 0 0 var(--ah-space-3);
  letter-spacing: var(--ah-track-tight);
}
.card p { font-size: var(--ah-step-0); color: var(--ah-fg-2); margin: 0 0 var(--ah-space-3); }
.card--ink p { color: var(--ah-paper); opacity: .85; }
.card .card-meta {
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-wide);
  color: var(--ah-fg-3);
  border-top: var(--ah-border-hair);
  padding-top: var(--ah-space-3);
  margin: 0;
}
.card--ink .card-meta { color: var(--ah-kraft); border-top-color: rgba(255,255,255,.25); }

/* highlight inline */
.hl { background: var(--ah-white); color: var(--ah-ink); padding: .1em .35em; box-decoration-break: clone; -webkit-box-decoration-break: clone; }

/* do / don't columns */
.dodont { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: var(--ah-border-1); }
@media (max-width: 600px){ .dodont { grid-template-columns: 1fr; } }
.dodont .col { padding: var(--ah-space-5); }
.dodont .col + .col { border-left: var(--ah-border-1); }
@media (max-width: 600px){ .dodont .col + .col { border-left: 0; border-top: var(--ah-border-1); } }
.dodont .col h4 { font-size: var(--ah-step-1); margin: 0 0 var(--ah-space-4); }
.dodont ul { list-style: none; margin: 0; padding: 0; }
.dodont li { font-size: var(--ah-step-0); color: var(--ah-fg-2); padding: var(--ah-space-2) 0; border-bottom: var(--ah-border-hair); line-height: var(--ah-leading-snug); }
.dodont li:last-child { border-bottom: 0; }
.dodont li::before { font-weight: var(--ah-weight-bold); font-style: italic; margin-right: .5em; }
.dodont .yes li::before { content: "+"; }
.dodont .no li::before { content: "\2212"; color: var(--ah-blood); }

/* meta list */
.metalist { display: flex; flex-wrap: wrap; gap: var(--ah-space-2) var(--ah-space-3); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; letter-spacing: var(--ah-track-wide); font-size: var(--ah-step-0); }
.metalist span:not(:last-child)::after { content: " /"; color: var(--ah-fg-3); margin-left: var(--ah-space-2); }

/* spec table */
.spec { width: 100%; border-collapse: collapse; border: var(--ah-border-1); }
.spec th, .spec td { text-align: left; padding: var(--ah-space-3) var(--ah-space-4); border-bottom: var(--ah-border-hair); font-size: var(--ah-step-0); vertical-align: top; }
.spec tr:last-child td { border-bottom: 0; }
.spec th { background: var(--ah-paper-2); font-weight: var(--ah-weight-bold); text-transform: uppercase; letter-spacing: var(--ah-track-wide); font-size: var(--ah-step--1); }
.spec td:first-child { font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; white-space: nowrap; }

/* ==========================================================================
   3. DASHBOARD HOME
   ========================================================================== */
.hero-poster {
  position: relative;
  border: var(--ah-border-1);
  background: var(--ah-kraft) url("assets/craftpaper-bg.jpg") center 30% / cover no-repeat;
  color: var(--ah-kraft-ink);
  padding: var(--ah-space-8) var(--ah-space-7);
  overflow: hidden;
  margin-bottom: var(--ah-space-7);
}
.hero-poster .hp-stamps { position: absolute; inset: 0; pointer-events: none; }
.hero-poster .hp-stamps span {
  position: absolute;
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--ah-kraft-ink);
}
.hero-poster .hp-body { position: relative; z-index: 2; max-width: 40ch; }
.hero-poster .hp-eyebrow { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); text-transform: uppercase; font-weight: var(--ah-weight-bold); margin-bottom: var(--ah-space-4); }
.hero-poster h1 { font-size: var(--ah-step-5); margin: 0 0 var(--ah-space-4); }
.hero-poster .hp-sub { font-size: clamp(0.5rem, 1.55vw, 0.92rem); font-style: normal; text-transform: uppercase; letter-spacing: var(--ah-track-tight); line-height: var(--ah-leading-snug); white-space: nowrap; max-width: none; }
.hero-poster .hp-body { max-width: none; }
.hero-poster .hp-sub .hl { white-space: nowrap; }
.hero-poster .hp-sub .hl { background: var(--ah-white); }

/* dashboard section cards */
.dash-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--ah-space-4); }
.dash-card {
  text-align: left;
  border: var(--ah-border-1);
  background: var(--ah-white);
  padding: var(--ah-space-5);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: var(--ah-space-3);
  min-height: 168px;
  transition: box-shadow var(--ah-dur-fast) var(--ah-ease), background var(--ah-dur) var(--ah-ease);
  font-family: var(--ah-font-mono);
  color: var(--ah-fg-1);
}
.dash-card:hover { background: var(--ah-paper-2); }
.dash-card:active { box-shadow: var(--ah-shadow-flash); }
.dash-card.is-locked { opacity: .42; cursor: not-allowed; }
.dash-card.is-locked:hover { background: var(--ah-bg-card); box-shadow: none; }
.dash-card .dc-num { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); color: var(--ah-fg-3); font-weight: var(--ah-weight-bold); }
.dash-card .dc-title { font-size: var(--ah-step-3); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; letter-spacing: var(--ah-track-tight); line-height: 1.05; }
.dash-card .dc-desc { font-size: var(--ah-step-0); color: var(--ah-fg-3); margin-top: auto; }
.dash-card .dc-go { font-size: var(--ah-step-0); color: var(--ah-link); text-decoration: underline; text-underline-offset: 2px; }

/* ==========================================================================
   4. ASSET LOCKER
   ========================================================================== */
.locker-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--ah-space-5); }
.asset {
  border: var(--ah-border-1);
  background: var(--ah-white);
  display: flex;
  flex-direction: column;
}
.asset .asset-preview {
  height: 180px;
  border-bottom: var(--ah-border-1);
  display: grid;
  place-items: center;
  overflow: hidden;
  position: relative;
}
.asset .asset-preview.on-paper { background: var(--ah-paper); }
.asset .asset-preview.on-kraft { background: var(--ah-kraft) url("assets/craftpaper-bg.jpg") center center / cover no-repeat; }
.asset .asset-preview.on-ink { background: var(--ah-ink); }
.asset .asset-preview img.logo-ex { width: 64%; }
.asset .asset-preview img.photo-ex { width: 100%; height: 100%; object-fit: cover; }
.asset .asset-body { padding: var(--ah-space-4) var(--ah-space-5); display: flex; flex-direction: column; gap: var(--ah-space-2); flex: 1; }
.asset .asset-body h4 { font-size: var(--ah-step-1); margin: 0; }
.asset .asset-body .asset-meta { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-wide); color: var(--ah-fg-3); }
.asset .asset-body .asset-foot { margin-top: auto; padding-top: var(--ah-space-3); display: flex; align-items: center; justify-content: space-between; gap: var(--ah-space-3); }
.asset .dl {
  font-family: var(--ah-font-mono);
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-wide);
  text-transform: uppercase;
  font-weight: var(--ah-weight-bold);
  color: var(--ah-link);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.asset .dl:hover { opacity: .7; }
.asset .asset-size { font-size: var(--ah-step--1); color: var(--ah-fg-3); }

.locker-locked {
  border: var(--ah-border-1);
  background: var(--ah-paper-2);
  padding: var(--ah-space-7);
  text-align: center;
}
.locker-locked .scope-h { margin-bottom: var(--ah-space-3); }

/* swatch grid (color section) */
.swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 0; border: var(--ah-border-1); }
.swatch { border-right: var(--ah-border-hair); border-bottom: var(--ah-border-hair); }
.swatch .chip { height: 96px; }
.swatch .meta { padding: var(--ah-space-3) var(--ah-space-4); }
.swatch .meta .nm { font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; font-size: var(--ah-step-0); }
.swatch .meta .hex { font-size: var(--ah-step--1); color: var(--ah-fg-3); letter-spacing: var(--ah-track-wide); }
.swatch .meta .use { font-size: var(--ah-step--1); color: var(--ah-fg-3); margin-top: var(--ah-space-1); display:block; }

/* type specimens */
.specimen { border: var(--ah-border-1); padding: var(--ah-space-5); margin-bottom: var(--ah-space-4); background: var(--ah-white); }
.specimen .spec-label { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); text-transform: uppercase; color: var(--ah-fg-3); font-weight: var(--ah-weight-bold); margin-bottom: var(--ah-space-3); }
.specimen .spec-display { font-size: var(--ah-step-5); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; letter-spacing: var(--ah-track-tight); line-height: 1.05; }
.specimen .spec-body { font-size: var(--ah-step-2); }
.specimen .spec-italic { font-size: var(--ah-step-2); font-style: italic; }
.specimen .spec-tracked { font-size: var(--ah-step-1); text-transform: uppercase; letter-spacing: var(--ah-track-x-wide); font-weight: var(--ah-weight-bold); }

/* symbol grid */
.symbols { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 0; border: var(--ah-border-1); }
.symbol { border-right: var(--ah-border-hair); border-bottom: var(--ah-border-hair); padding: var(--ah-space-5); display: flex; gap: var(--ah-space-4); align-items: center; }
.symbol .glyph { font-size: var(--ah-step-5); font-weight: var(--ah-weight-bold); font-style: italic; line-height: 1; min-width: 1.4em; text-align: center; }
.symbol .sd { font-size: var(--ah-step-0); color: var(--ah-fg-2); }

/* photo gallery */
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: var(--ah-space-4); }
.gallery figure { margin: 0; border: var(--ah-border-1); background: var(--ah-white); }
.gallery img { width: 100%; aspect-ratio: 3/2; object-fit: cover; border-bottom: var(--ah-border-1); }
.gallery figcaption { padding: var(--ah-space-3) var(--ah-space-4); display: flex; justify-content: space-between; gap: var(--ah-space-2); align-items: center; }
.gallery .cap-pill { background: var(--ah-white); border: var(--ah-border-hair); font-size: var(--ah-step--1); letter-spacing: var(--ah-track-wide); padding: 2px 8px; }

/* ---- Brand architecture: house / rooms / events diagram ---- */
.arch { display: flex; flex-direction: column; align-items: center; gap: 0; }
.arch .arch-node {
  border: var(--ah-border-1);
  background: var(--ah-white);
  padding: var(--ah-space-4) var(--ah-space-5);
  text-align: center;
  width: 100%;
}
.arch .arch-house { background: transparent; border: 0; color: var(--ah-ink); padding: var(--ah-space-2) 0; }
.arch .arch-house .an-mark { font-family: var(--ah-font-display); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; font-size: var(--ah-step-4); letter-spacing: var(--ah-track-tight); line-height: 1; color: var(--ah-ink); }
.arch .arch-house .an-role { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); text-transform: uppercase; color: var(--ah-fg-3); margin-top: var(--ah-space-2); }
.arch .arch-stem { width: 1.5px; height: var(--ah-space-5); background: var(--ah-ink); }
.arch .arch-label { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); text-transform: uppercase; font-weight: var(--ah-weight-bold); color: var(--ah-fg-3); margin: var(--ah-space-3) 0; }
.arch .arch-label::before { content: "{ "; } .arch .arch-label::after { content: " }"; }
.arch .arch-row { display: grid; gap: var(--ah-space-3); width: 100%; }
.arch .arch-row.rooms { grid-template-columns: repeat(4, 1fr); }
.arch .arch-row.events { grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); max-width: 760px; }
.arch .arch-row.locations { grid-template-columns: repeat(2, 1fr); max-width: 640px; }
@media (max-width: 760px){ .arch .arch-row.rooms { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 460px){ .arch .arch-row.rooms, .arch .arch-row.events, .arch .arch-row.locations { grid-template-columns: 1fr; } }
.arch .rn-name { display: block; font-family: var(--ah-font-display); font-weight: var(--ah-weight-reg); font-style: normal; text-transform: uppercase; font-size: var(--ah-step-1); }
.arch .rn-kind { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-wide); color: var(--ah-fg-3); display: block; margin-top: var(--ah-space-1); }
.arch .event-node { background: var(--ah-white); border-color: var(--ah-ink); }
.arch .event-node .rn-name { font-style: normal; }

/* clickable location nodes */
.arch .location-node {
  font: inherit;
  text-align: center;
  cursor: pointer;
  transition: background .12s ease, color .12s ease, transform .12s ease;
  -webkit-appearance: none; appearance: none;
}
.arch .location-node:hover { transform: translateY(-1px); }
.arch .location-node:focus-visible { outline: 2px solid var(--ah-ink); outline-offset: 2px; }
.arch .location-node.is-active { background: var(--ah-ink); }
.arch .location-node.is-active .rn-name { color: var(--ah-paper); }
.arch .location-node.is-active .rn-kind { color: var(--ah-fg-3-on-ink, rgba(245,241,234,.62)); }
.arch .arch-hint {
  display: block; width: 100%; text-align: center;
  font-size: var(--ah-step--2); letter-spacing: var(--ah-track-wide);
  text-transform: uppercase; color: var(--ah-fg-3); font-weight: var(--ah-weight-reg);
  margin: calc(var(--ah-space-2) * -1) 0 var(--ah-space-3);
}
.arch .arch-house .an-logo { display: block; width: 240px; max-width: 70%; height: auto; margin: 0 auto var(--ah-space-1); }
.scope-h.arch-loc-title::before, .scope-h.arch-loc-title::after { content: none; }
.arch-city {
  font-style: italic; font-weight: var(--ah-weight-bold);
  text-transform: none; color: var(--ah-ink);
}

/* lockup specimen blocks */
.lockups { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--ah-space-4); }
@media (max-width: 640px){ .lockups { grid-template-columns: 1fr; } }
.lockup {
  border: var(--ah-border-1);
  background: var(--ah-white);
  padding: var(--ah-space-6) var(--ah-space-5);
  display: flex; flex-direction: column; gap: var(--ah-space-3);
  align-items: flex-start; justify-content: center;
  min-height: 150px;
}
.lockup.on-ink { background: var(--ah-ink); }
.lockup.on-kraft { background: var(--ah-kraft) url("assets/craftpaper-bg.jpg") center center / cover no-repeat; }
.lockup .lk-mark { font-family: var(--ah-font-display); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; font-size: var(--ah-step-2); letter-spacing: var(--ah-track-tight); line-height: 1; }
.lockup.on-ink .lk-mark { color: var(--ah-paper); }
.lockup .lk-line { display: flex; align-items: baseline; gap: var(--ah-space-3); flex-wrap: wrap; }
.lockup .lk-div { color: var(--ah-fg-3); font-weight: var(--ah-weight-bold); }
.lockup.on-ink .lk-div { color: var(--ah-kraft); }
.lockup .lk-sub { font-family: var(--ah-font-display); font-weight: var(--ah-weight-bold); font-style: italic; font-size: var(--ah-step-2); }
.lockup.on-ink .lk-sub { color: var(--ah-paper); }
.lockup .lk-cap { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); text-transform: uppercase; color: var(--ah-fg-3); border-top: var(--ah-border-hair); padding-top: var(--ah-space-3); width: 100%; margin-top: auto; }
.lockup.on-ink .lk-cap { color: var(--ah-kraft); border-top-color: rgba(255,255,255,.25); }
.lockup .lk-stamp { font-family: var(--ah-font-display); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; font-size: var(--ah-step-2); letter-spacing: var(--ah-track-tight); }
.lockup.on-kraft .lk-stamp, .lockup.on-kraft .lk-cap, .lockup.on-kraft .lk-mark { color: var(--ah-kraft-ink); }

/* ==========================================================================
   THE BRAND FILTER  — pass/fail decision gate
   ========================================================================== */
.filter-verdict {
  display: flex;
  align-items: center;
  gap: var(--ah-space-5);
  border: var(--ah-border-1);
  padding: var(--ah-space-5);
  margin-bottom: var(--ah-space-6);
  background: var(--ah-white);
  transition: background var(--ah-dur) var(--ah-ease), color var(--ah-dur) var(--ah-ease);
}
.filter-verdict .fv-main { flex: 1; min-width: 0; }
.filter-verdict .fv-label {
  font-family: var(--ah-font-display);
  font-weight: var(--ah-weight-bold);
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: var(--ah-track-tight);
  font-size: var(--ah-step-3);
  line-height: 1.05;
}
.filter-verdict .fv-line { font-size: var(--ah-step-0); color: var(--ah-fg-3); margin-top: var(--ah-space-2); }
.filter-verdict .fv-meter {
  width: 120px;
  height: 8px;
  border: var(--ah-border-hair);
  flex: none;
}
.filter-verdict .fv-meter span {
  display: block;
  height: 100%;
  background: var(--ah-ink);
  transition: width var(--ah-dur) var(--ah-ease);
}
/* pending = default white. pass = ink fill. fail = kept light, marked by copy. */
.filter-verdict[data-state="pass"] {
  background: var(--ah-ink);
  color: var(--ah-paper);
  box-shadow: var(--ah-shadow-flash);
}
.filter-verdict[data-state="pass"] .fv-line { color: var(--ah-kraft); }
.filter-verdict[data-state="pass"] .fv-meter { border-color: rgba(255,255,255,.4); }
.filter-verdict[data-state="pass"] .fv-meter span { background: var(--ah-paper); }
.filter-verdict[data-state="pass"] .btn--ghost { color: var(--ah-paper); border-color: var(--ah-paper); }
.filter-verdict[data-state="fail"] { background: var(--ah-paper-2); }

.filter { border: var(--ah-border-1); background: var(--ah-white); }
.filter-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ah-space-5);
  padding: var(--ah-space-5);
  border-bottom: var(--ah-border-hair);
  transition: background var(--ah-dur) var(--ah-ease);
}
.filter-q:last-child { border-bottom: 0; }
.filter-q[data-state="yes"] { background: var(--ah-paper); }
.filter-q[data-state="no"] { background: repeating-linear-gradient(135deg, var(--ah-paper-2) 0 6px, var(--ah-white) 6px 12px); }
.filter-q .fq-text { min-width: 0; }
.filter-q .fq-num { font-size: var(--ah-step--1); letter-spacing: var(--ah-track-x-wide); color: var(--ah-fg-3); font-weight: var(--ah-weight-bold); margin-right: var(--ah-space-3); }
.filter-q .fq-title { font-family: var(--ah-font-display); font-weight: var(--ah-weight-bold); font-style: italic; text-transform: uppercase; letter-spacing: var(--ah-track-tight); font-size: var(--ah-step-2); }
.filter-q .fq-sub { display: block; font-size: var(--ah-step-0); color: var(--ah-fg-3); margin-top: var(--ah-space-2); max-width: 60ch; }

.fq-toggle { display: flex; flex: none; border: var(--ah-border-1); }
.fq-toggle button {
  font-family: var(--ah-font-mono);
  font-size: var(--ah-step--1);
  letter-spacing: var(--ah-track-x-wide);
  text-transform: uppercase;
  font-weight: var(--ah-weight-bold);
  background: var(--ah-white);
  color: var(--ah-ink);
  border: 0;
  border-right: var(--ah-border-hair);
  padding: var(--ah-space-3) var(--ah-space-4);
  cursor: pointer;
  min-width: 56px;
  transition: background var(--ah-dur-fast) var(--ah-ease), color var(--ah-dur-fast) var(--ah-ease);
}
.fq-toggle button:last-child { border-right: 0; }
.fq-toggle button:hover { background: var(--ah-paper-2); }
.filter-q[data-state="yes"] .fq-toggle button[data-ans="yes"],
.filter-q[data-state="no"] .fq-toggle button[data-ans="no"] {
  background: var(--ah-ink);
  color: var(--ah-paper);
}
.filter-q[data-state="yes"] .fq-toggle button[data-ans="yes"]:hover,
.filter-q[data-state="no"] .fq-toggle button[data-ans="no"]:hover {
  background: var(--ah-ink);
}

@media (max-width: 640px) {
  .filter-q { flex-direction: column; align-items: stretch; gap: var(--ah-space-4); }
  .fq-toggle { align-self: flex-start; }
  .filter-verdict { flex-wrap: wrap; }
  .filter-verdict .fv-meter { order: 3; width: 100%; }
}

/* bottom contact marginalia */
.content-foot {
  margin-top: var(--ah-space-9);
  padding-top: var(--ah-space-5);
  border-top: var(--ah-border-1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--ah-space-4);
  flex-wrap: wrap;
  font-size: var(--ah-step-0);
  color: var(--ah-fg-3);
  letter-spacing: var(--ah-track-wide);
}

/* sidebar backdrop on mobile */
.nav-backdrop { display: none; }

/* ==========================================================================
   5. RESPONSIVE — tablet & mobile
   ========================================================================== */
@media (max-width: 1024px) {
  .shell { grid-template-columns: var(--shell-nav-width, 240px) 1fr; }
  .content { padding: var(--ah-space-6) var(--ah-space-6) var(--ah-space-9); }
}

@media (max-width: 820px) {
  .menu-toggle { display: inline-block; }
  .shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed;
    top: 60px;
    left: 0;
    width: 280px;
    max-width: 84vw;
    height: calc(100vh - 60px);
    z-index: 60;
    transform: translateX(-102%);
    transition: transform var(--ah-dur-slow) var(--ah-ease);
    border-right: var(--ah-border-1);
    background: var(--ah-paper);
  }
  body.nav-open .sidebar { transform: translateX(0); }
  body.nav-open .nav-backdrop {
    display: block;
    position: fixed;
    inset: 60px 0 0 0;
    z-index: 55;
    background: rgba(0,0,0,.4);
  }
  .sec-head h1 { font-size: var(--ah-step-4); }
}

@media (max-width: 560px) {
  .topbar { padding: var(--ah-space-3) var(--ah-space-4); gap: var(--ah-space-2); }
  .role-tag { display: none; }
  /* shrink the center brand mark so the menu + log-out controls have room */
  .topbar { --tb-mark-base: var(--ah-step-0); --tb-logo-base: 12px; }
  .topbar .tb-left { gap: var(--ah-space-2); min-width: 0; }
  /* stack the wordmark over "/ BRAND PORTAL", centered in the bar */
  .tb-mark {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 5px;
    line-height: 1;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    pointer-events: auto;
  }
  /* stacked layout reads better without the leading slash */
  .tb-mark .tb-slash { display: none; }
  .menu-toggle { padding: 5px 7px; font-size: var(--ah-step--1); }
  .content { padding: var(--ah-space-5) var(--ah-space-4) var(--ah-space-8); }
  .hero-poster { padding: var(--ah-space-6) var(--ah-space-5); }
  /* display headings: smaller on phones so they read in 2–3 lines, not 6 */
  .hero-poster h1 { font-size: var(--ah-step-4); line-height: 1.04; }
  .sec-head h1 { font-size: var(--ah-step-4); }
  .login-card { padding: var(--ah-space-6) var(--ah-space-5) var(--ah-space-5); }
  .specimen .spec-display { font-size: var(--ah-step-4); }
  /* wide spec tables: let them scroll inside the column instead of pushing the page */
  .prose .spec { display: block; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* the 7-day cadence strip becomes a horizontal scroll row on phones */
  .ig-week { display: flex; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .ig-week > .card { flex: 0 0 64px; }
}

@media (max-width: 400px) {
  /* tightest phones: keep the stacked mark but ease the type down a touch */
  .topbar { --tb-mark-base: var(--ah-step--1); }
  .hero-poster h1 { font-size: var(--ah-step-3); }
  .sec-head h1 { font-size: var(--ah-step-3); }
  .specimen .spec-display { font-size: var(--ah-step-3); }
}

/* Links: no underlines anywhere (brand portal direction) */
a, a:hover, a:visited,
.ah-link, .ah-link:hover,
.asset .dl, .tb-logout, .dc-go,
.login-foot a, .content-foot a {
  text-decoration: none;
}

@media (prefers-reduced-motion: reduce) {
  * { transition-duration: .01ms !important; }
}
