:root {
  --cih-ink: #221144;
  --cih-purple: #502080;
  --cih-heading: #53237f;
  --cih-lavender: #d0b0ff;
  --cih-soft-lavender: #f3ecff;
  --cih-magenta: #ff0066;
  --cih-blue: #3366ff;
  --cih-cyan: #66ccff;
  --award-cyan: #48c0f0;
  --award-gold: #d8a830;
  --paper: #ffffff;
  --paper-soft: #f7f6fb;
  --line: #ddd3ea;
  --text: #201a2a;
  --muted: #645a72;
  --shadow: 0 24px 70px rgba(34, 17, 68, 0.16);
  --radius: 8px;
  --scroll-progress: 0%;
  color-scheme: light;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 128px;
}

body {
  margin: 0;
  min-width: 320px;
  font-family: Arial, Helvetica, "Noto Sans TC", "Microsoft JhengHei", sans-serif;
  color: var(--text);
  background: var(--paper);
}

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

[hidden] {
  display: none !important;
}

a {
  color: inherit;
}

section,
[id] {
  scroll-margin-top: 128px;
}

button,
a.button {
  font: inherit;
}

[hidden] {
  display: none !important;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: grid;
  grid-template-columns: minmax(340px, 0.9fr) minmax(0, auto) auto;
  align-items: center;
  gap: 12px;
  padding: 12px clamp(18px, 4vw, 56px);
  background: var(--cih-ink);
  color: var(--paper);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  transition: box-shadow 180ms ease, padding 180ms ease;
}

.site-header[data-elevated="true"] {
  box-shadow: 0 18px 45px rgba(20, 10, 40, 0.24);
}

.section-heading p:empty {
  display: none;
}

.site-header::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: var(--scroll-progress);
  height: 3px;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
  transition: width 120ms linear;
}

.brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  gap: 14px;
  text-decoration: none;
}

.brand img {
  width: 48px;
  height: 60px;
  object-fit: contain;
  flex: 0 0 auto;
}

.brand strong {
  display: block;
  font-size: 16px;
  line-height: 1.1;
  white-space: nowrap;
}

.brand small {
  display: block;
  max-width: 360px;
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.76);
  font-size: 12px;
  line-height: 1.25;
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 2px;
  justify-content: center;
  min-width: 0;
}

.main-nav a,
.nav-disclosure {
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.86);
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.main-nav a {
  position: relative;
  padding: 9px 7px;
}

.nav-group {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.nav-disclosure {
  display: grid;
  place-items: center;
  width: 24px;
  height: 34px;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.nav-disclosure span {
  width: 0;
  height: 0;
  border-top: 5px solid currentColor;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  transition: transform 160ms ease;
}

.nav-group.open .nav-disclosure span,
.nav-group:hover .nav-disclosure span,
.nav-group:focus-within .nav-disclosure span {
  transform: rotate(180deg);
}

.submenu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 60;
  display: grid;
  min-width: 220px;
  padding: 8px;
  border: 1px solid rgba(34, 17, 68, 0.12);
  border-radius: 6px;
  background: #ffffff;
  box-shadow: 0 22px 48px rgba(18, 8, 40, 0.2);
  opacity: 0;
  transform: translateY(-6px);
  visibility: hidden;
  pointer-events: none;
  transition: opacity 150ms ease, transform 150ms ease, visibility 150ms ease;
}

.submenu a {
  padding: 10px 12px;
  color: var(--cih-ink);
  font-size: 13px;
  line-height: 1.25;
  white-space: normal;
}

.nav-group.open .submenu,
.nav-group:hover .submenu,
.nav-group:focus-within .submenu {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
  pointer-events: auto;
}

.main-nav .nav-top:hover,
.main-nav .nav-disclosure:hover,
.main-nav .nav-cta:hover {
  color: var(--paper);
  background: rgba(255, 255, 255, 0.11);
}

.submenu a:hover {
  color: var(--cih-heading);
  background: #f5f0ff;
}

.main-nav a.active,
.nav-group.active > .nav-top,
.nav-cta.active {
  color: var(--paper);
  background: transparent;
  box-shadow: none;
}

.main-nav > a.active::after,
.nav-group.active > .nav-top::after,
.nav-cta.active::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 4px;
  height: 2px;
  border-radius: 99px;
  background: var(--award-cyan);
}

.submenu a.active {
  color: var(--cih-heading);
  background: transparent;
  box-shadow: none;
  text-decoration: underline;
  text-decoration-color: var(--award-cyan);
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}

.nav-cta {
  margin-left: 4px;
  border: 1px solid rgba(102, 204, 255, 0.55);
  background: rgba(255, 255, 255, 0.08);
}

.language-switcher {
  display: inline-grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  width: 126px;
  padding: 3px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.12);
}

.language-switcher button {
  min-height: 30px;
  border: 0;
  border-radius: 4px;
  background: transparent;
  color: rgba(255, 255, 255, 0.76);
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.language-switcher button.active {
  color: var(--cih-ink);
  background: var(--cih-lavender);
}

.menu-toggle {
  display: none;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
}

.menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 5px auto;
  background: var(--paper);
  border-radius: 99px;
  transition: transform 180ms ease, opacity 180ms ease;
}

.menu-toggle[aria-expanded="true"] span:first-child {
  transform: translateY(3.5px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] span:last-child {
  transform: translateY(-3.5px) rotate(-45deg);
}

.hero-section {
  position: relative;
  min-height: clamp(500px, calc(100vh - 190px), 680px);
  display: grid;
  align-items: stretch;
  overflow: hidden;
  color: var(--paper);
  background: var(--cih-ink);
  isolation: isolate;
}

.hero-backdrop {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse at 20% 28%, rgba(63, 32, 118, 0.58) 0%, rgba(42, 15, 86, 0.5) 35%, rgba(36, 8, 80, 0.2) 56%, rgba(36, 8, 80, 0) 74%),
    linear-gradient(105deg, rgba(16, 5, 42, 0.98) 0%, rgba(33, 10, 76, 0.9) 30%, rgba(67, 24, 108, 0.68) 51%, rgba(78, 32, 113, 0.25) 72%, rgba(45, 14, 75, 0.08) 100%),
    linear-gradient(180deg, rgba(27, 8, 61, 0.12) 0%, rgba(8, 2, 30, 0.44) 100%),
    url("assets/cih/hero-kv.png");
  background-size: cover;
  background-position: center right;
}

.hero-backdrop::before {
  content: none;
}

.hero-backdrop::after {
  content: none;
}

.hero-section.revealable {
  opacity: 1;
  transform: none;
}

.hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
  gap: clamp(28px, 5vw, 80px);
  align-items: center;
  width: min(1180px, calc(100% - 36px));
  margin: 0 auto;
  padding: clamp(42px, 7vh, 76px) 0 clamp(34px, 6vh, 58px);
}

.hero-copy {
  position: relative;
  z-index: 1;
  max-width: 720px;
}

.hero-copy::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -36px;
  left: -58px;
  width: min(540px, 90vw);
  height: 250px;
  background:
    radial-gradient(ellipse at 42% 46%, rgba(162, 121, 218, 0.42) 0%, rgba(116, 70, 172, 0.32) 42%, rgba(76, 33, 126, 0.18) 67%, rgba(76, 33, 126, 0) 84%),
    radial-gradient(circle at 20% 30%, rgba(92, 213, 255, 0.18) 0%, rgba(92, 213, 255, 0) 34%),
    radial-gradient(circle at 73% 36%, rgba(235, 197, 83, 0.16) 0%, rgba(235, 197, 83, 0) 34%);
  border-radius: 50%;
  pointer-events: none;
}

.award-logo {
  box-sizing: border-box;
  display: block;
  width: min(270px, 52vw);
  height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  margin: 0 0 18px;
  box-shadow: none;
  filter:
    contrast(1.14)
    saturate(1.12)
    drop-shadow(0 1px 0 rgba(255, 255, 255, 0.7))
    drop-shadow(0 0 2px rgba(255, 255, 255, 0.36))
    drop-shadow(0 14px 26px rgba(5, 0, 24, 0.68))
    drop-shadow(0 0 28px rgba(72, 192, 240, 0.28));
  animation: awardFloat 5s ease-in-out infinite;
}

.hero-copy h1 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(36px, 4.4vw, 58px);
  line-height: 0.98;
  letter-spacing: 0;
  text-wrap: balance;
  text-shadow: 0 18px 42px rgba(0, 0, 0, 0.32);
}

.hero-lede {
  max-width: 580px;
  margin: 20px 0 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(17px, 1.75vw, 21px);
  line-height: 1.45;
  text-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 26px;
}

.button {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 20px;
  border-radius: 6px;
  border: 1px solid transparent;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease, border-color 180ms ease;
}

.button::after {
  content: "";
  position: absolute;
  inset: -1px;
  background: linear-gradient(110deg, transparent 0 35%, rgba(255, 255, 255, 0.36) 45%, transparent 55% 100%);
  transform: translateX(-120%);
  transition: transform 520ms ease;
  pointer-events: none;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(34, 17, 68, 0.2);
}

.button:hover::after,
.button:focus-visible::after {
  transform: translateX(120%);
}

.button.primary {
  color: var(--paper);
  background: var(--cih-magenta);
}

.button.primary:hover {
  background: #d80058;
}

.button.secondary {
  color: var(--paper);
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.1);
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(102, 204, 255, 0.42);
  outline-offset: 2px;
}

.deadline-panel {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 26px;
  align-content: start;
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.deadline-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  border-top: 3px solid rgba(216, 168, 48, 0.82);
  background: linear-gradient(135deg, rgba(102, 204, 255, 0.16), transparent 34%);
  pointer-events: none;
}

.deadline-panel::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -35%;
  width: 28%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.18), transparent);
  transform: skewX(-18deg);
  animation: panelSweep 5.8s ease-in-out infinite;
  pointer-events: none;
}

.panel-label {
  display: block;
  color: var(--cih-lavender);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.countdown {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}

.countdown span {
  position: relative;
  min-height: 86px;
  display: grid;
  place-items: center;
  padding: 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.15);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.countdown span::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 8px;
  height: 2px;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
  border-radius: 999px;
  transform-origin: left center;
  animation: meterSweep 4s ease-in-out infinite alternate;
}

.countdown strong {
  font-size: 34px;
  line-height: 1;
}

.countdown small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 11px;
  text-transform: uppercase;
}

.fee-list {
  display: grid;
  gap: 10px;
  margin: 0;
}

.fee-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.fee-list dt {
  color: rgba(255, 255, 255, 0.7);
  font-size: 13px;
}

.fee-list dd {
  margin: 0;
  font-size: 20px;
  font-weight: 900;
}

.signal-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--line);
  background: var(--paper);
}

.signal-strip div {
  display: grid;
  gap: 4px;
  padding: 26px clamp(18px, 4vw, 42px);
  border-right: 1px solid var(--line);
  transition: background 180ms ease, transform 180ms ease;
}

.signal-strip div:hover {
  background: var(--cih-soft-lavender);
  transform: translateY(-2px);
}

.signal-strip div:last-child {
  border-right: 0;
}

.signal-strip strong {
  color: var(--cih-purple);
  font-size: 28px;
  line-height: 1;
}

.signal-strip span {
  color: var(--muted);
  font-size: 13px;
}

.announcement-band {
  padding: clamp(58px, 8vw, 90px) clamp(18px, 5vw, 64px);
  background:
    linear-gradient(135deg, rgba(80, 32, 128, 0.06) 0 25%, transparent 25% 50%, rgba(80, 32, 128, 0.04) 50% 75%, transparent 75% 100%),
    linear-gradient(180deg, #ffffff, #faf7ff);
  background-size: 36px 36px, auto;
}

.announcement-shell {
  max-width: 1180px;
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 22px 70px rgba(34, 17, 68, 0.12);
  overflow: hidden;
}

.announcement-controls {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  background: var(--cih-ink);
}

.announcement-controls button {
  min-height: 54px;
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.76);
  background: transparent;
  cursor: pointer;
  font-weight: 850;
}

.announcement-controls button:last-child {
  border-right: 0;
}

.announcement-controls button.active {
  color: var(--cih-ink);
  background: var(--cih-lavender);
}

.announcement-board {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  padding: 18px;
}

.announcement-card {
  position: relative;
  min-height: 250px;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: linear-gradient(180deg, #ffffff, #fbf8ff);
  overflow: hidden;
  animation: liftIn 320ms ease both;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.announcement-card::after {
  content: "";
  position: absolute;
  inset: auto 18px 0;
  height: 3px;
  border-radius: 99px 99px 0 0;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan));
}

.announcement-card:hover {
  transform: translateY(-4px);
  border-color: rgba(255, 0, 102, 0.28);
  box-shadow: 0 18px 45px rgba(34, 17, 68, 0.14);
}

.announcement-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 16px;
  border-radius: 8px;
  color: var(--paper);
  background: var(--cih-purple);
}

.announcement-icon svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.announcement-card small,
.announcement-card time,
.announcement-card strong,
.announcement-card p {
  display: block;
}

.announcement-card small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.announcement-card time {
  margin-top: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.announcement-card strong {
  margin-top: 14px;
  color: var(--cih-ink);
  font-size: 18px;
  line-height: 1.18;
}

.announcement-card p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.content-band,
.portal-band,
.sponsor-band,
.contact-band {
  padding: clamp(58px, 8vw, 96px) clamp(18px, 5vw, 64px);
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(260px, 0.8fr) minmax(280px, 1fr);
  gap: clamp(20px, 5vw, 68px);
  align-items: end;
  max-width: 1180px;
  margin: 0 auto 34px;
}

.section-heading.narrow {
  display: block;
  max-width: 760px;
  text-align: center;
}

.section-heading h1,
.section-heading h2 {
  margin: 0;
  color: var(--cih-heading);
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1;
  letter-spacing: 0;
}

.section-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.65;
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  max-width: 1180px;
  margin: 0 auto;
}

.feature-grid article {
  position: relative;
  overflow: hidden;
  min-height: 238px;
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.feature-grid article::after {
  content: "";
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 0;
  height: 3px;
  border-radius: 99px 99px 0 0;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
  transform: scaleX(0.42);
  transform-origin: left center;
  transition: transform 220ms ease;
}

.feature-grid article:hover {
  transform: translateY(-4px);
  border-color: rgba(80, 32, 128, 0.25);
  box-shadow: 0 18px 46px rgba(34, 17, 68, 0.12);
}

.feature-grid article:hover::after {
  transform: scaleX(1);
}

.feature-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 6px;
  color: var(--paper);
  background: linear-gradient(135deg, var(--cih-purple), var(--cih-magenta));
  box-shadow: 0 14px 28px rgba(80, 32, 128, 0.18);
}

.feature-icon svg,
.material-icon svg,
.pillar-icon svg,
.timeline-icon svg {
  width: 26px;
  height: 26px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.05;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.feature-grid h3 {
  margin: 24px 0 10px;
  color: var(--cih-ink);
  font-size: 22px;
}

.feature-grid p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.aims-panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.36fr) 1fr;
  gap: 28px;
  max-width: 1180px;
  margin: 22px auto 0;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fcfbff;
}

.aims-panel h3 {
  margin: 0;
  color: var(--cih-heading);
  font-size: 26px;
  line-height: 1.1;
}

.aims-panel ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 22px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.aims-panel li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.55;
}

.aims-panel li::before {
  content: "";
  position: absolute;
  top: 0.7em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--cih-magenta);
}

.categories-band {
  background: var(--paper-soft);
}

.criteria-band {
  background: var(--paper);
}

.category-shell,
.portal-shell {
  max-width: 1100px;
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 18px 55px rgba(80, 32, 128, 0.09);
  overflow: hidden;
}

.category-tabs,
.portal-controls {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
  background: #2d1f3f;
}

.category-tabs button,
.portal-controls button {
  flex: 1;
  min-height: 56px;
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.76);
  background: transparent;
  cursor: pointer;
  font-weight: 800;
}

.category-tabs button:last-child,
.portal-controls button:last-child {
  border-right: 0;
}

.category-tabs button[aria-selected="true"],
.portal-controls button.active {
  color: var(--cih-ink);
  background: var(--cih-lavender);
}

.category-content {
  display: grid;
  grid-template-columns: minmax(260px, 0.85fr) 1.15fr;
  gap: 34px;
  padding: clamp(26px, 4vw, 44px);
}

.category-copy h3 {
  margin: 0 0 12px;
  color: var(--cih-heading);
  font-size: 28px;
}

.category-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.category-list {
  display: grid;
  gap: 12px;
}

.category-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 16px;
  align-items: center;
  min-height: 70px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.category-item span:first-child {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-purple);
  font-size: 12px;
  font-weight: 900;
}

.category-item strong {
  display: block;
}

.category-item small {
  color: var(--muted);
}

.category-item em {
  color: var(--cih-magenta);
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.category-rules {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
  max-width: 1100px;
  margin: 18px auto 0;
}

.category-rules article {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  min-height: 126px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #ffffff, #fbf8ff);
  box-shadow: 0 12px 34px rgba(80, 32, 128, 0.07);
}

.category-rule-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 8px;
  color: var(--paper);
  background: var(--cih-purple);
}

.category-rule-icon svg {
  width: 25px;
  height: 25px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.05;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.category-rules strong {
  display: block;
  margin-bottom: 6px;
  color: var(--cih-ink);
}

.category-rules p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.timeline {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 980px;
  margin: 0 auto;
}

.timeline::before {
  content: "";
  position: absolute;
  top: 26px;
  bottom: 26px;
  left: 47px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
}

.pillar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
  max-width: 1180px;
  margin: 0 auto;
}

.pillar-card {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #ffffff, #fbf8ff);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.pillar-card:hover {
  transform: translateY(-4px);
  border-color: rgba(80, 32, 128, 0.24);
  box-shadow: 0 18px 46px rgba(34, 17, 68, 0.12);
}

.pillar-icon {
  display: inline-grid;
  place-items: center;
  width: 48px;
  height: 48px;
  margin-bottom: 18px;
  border-radius: 8px;
  color: var(--paper);
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.9), rgba(80, 32, 128, 0.95));
}

.pillar-card strong {
  position: absolute;
  top: 24px;
  right: 22px;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
}

.pillar-card h3 {
  margin: 0 0 12px;
  color: var(--cih-ink);
  font-size: 18px;
  line-height: 1.18;
}

.pillar-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.pillar-card ul {
  display: grid;
  gap: 8px;
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}

.pillar-card li {
  position: relative;
  padding-left: 16px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.pillar-card li::before {
  content: "";
  position: absolute;
  top: 0.55em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--award-cyan);
}

.score-benchmark {
  display: grid;
  grid-template-columns: 0.78fr 1.22fr;
  gap: 28px;
  max-width: 1180px;
  margin: 28px auto 0;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fcfbff;
}

.score-benchmark h3 {
  margin: 0 0 12px;
  color: var(--cih-heading);
  font-size: 28px;
  line-height: 1.1;
}

.score-benchmark p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.score-band-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.score-band-list article {
  min-height: 82px;
  padding: 14px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-purple);
}

.score-band-list strong,
.score-band-list span {
  display: block;
}

.score-band-list strong {
  color: var(--cih-lavender);
  font-size: 20px;
}

.score-band-list span {
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.8);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
}

.tier-panel,
.requirements-panel {
  display: grid;
  grid-template-columns: 0.78fr 1.22fr;
  gap: 28px;
  max-width: 1180px;
  margin: 28px auto 0;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper-soft);
}

.tier-panel h3,
.requirements-panel h3 {
  margin: 0 0 12px;
  color: var(--cih-heading);
  font-size: 28px;
  line-height: 1.1;
}

.tier-panel p,
.requirements-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.tier-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.tier-item {
  min-height: 110px;
  padding: 16px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-ink);
}

.tier-item strong {
  display: block;
  color: var(--award-gold);
  font-size: 20px;
}

.tier-item span {
  display: block;
  margin-top: 12px;
  color: rgba(255, 255, 255, 0.76);
  font-size: 13px;
  line-height: 1.3;
}

.tier-item small {
  display: block;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
}

.judging-panel-block,
.judging-criteria-block {
  max-width: 1180px;
  margin: 28px auto 0;
}

.judging-panel-block {
  display: grid;
  grid-template-columns: minmax(220px, 0.36fr) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper-soft);
}

.judging-panel-block h3 {
  margin: 0 0 10px;
  color: var(--cih-heading);
  font-size: 28px;
  line-height: 1.1;
}

.judging-panel-block p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.requirements-panel {
  background: #fcfbff;
}

.requirements-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.requirements-grid article {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px 14px;
  align-content: start;
  overflow: hidden;
  min-height: 190px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.requirements-grid article:hover {
  transform: translateY(-3px);
  border-color: rgba(80, 32, 128, 0.22);
  box-shadow: 0 16px 38px rgba(34, 17, 68, 0.1);
}

.material-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 8px;
  color: var(--paper);
  background: var(--cih-purple);
}

.requirements-grid strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  height: 28px;
  padding: 0 9px;
  align-self: start;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
}

.requirements-grid h4 {
  grid-column: 1 / -1;
  margin: 0 0 10px;
  color: var(--cih-ink);
  font-size: 17px;
}

.requirements-grid p {
  grid-column: 1 / -1;
  font-size: 14px;
}

.document-download-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(220px, 0.5fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-top: 8px;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
}

.document-download-panel h3 {
  margin: 0 0 8px;
  color: var(--cih-heading);
  font-size: 20px;
}

.document-download-panel p {
  font-size: 13px;
  line-height: 1.55;
}

.document-download-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.document-download-grid a {
  display: grid;
  gap: 7px;
  min-height: 104px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 45%),
    #fcfbff;
  text-decoration: none;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.document-download-grid a:hover {
  border-color: rgba(255, 0, 102, 0.24);
  box-shadow: 0 14px 28px rgba(34, 17, 68, 0.1);
  transform: translateY(-2px);
}

.document-download-grid span {
  width: fit-content;
  padding: 4px 7px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-lavender);
  font-size: 10px;
  font-weight: 950;
}

.document-download-grid strong {
  color: var(--cih-heading);
  font-size: 13px;
  line-height: 1.25;
}

.document-download-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.submission-detail-list {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
  margin-top: 4px;
}

.submission-detail-list h4,
.materials-guidance h4 {
  margin: 0;
  color: var(--cih-heading);
  font-size: 18px;
}

.submission-detail-list article,
.materials-guidance article {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
}

.submission-detail-list article span,
.materials-guidance article span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-ink);
  font-size: 11px;
  font-weight: 900;
}

.submission-detail-list article strong,
.materials-guidance article strong {
  display: block;
  color: var(--cih-ink);
  line-height: 1.25;
}

.submission-detail-list ul,
.materials-guidance ul {
  display: grid;
  gap: 6px;
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
}

.submission-detail-list li,
.materials-guidance li {
  position: relative;
  padding-left: 15px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.submission-detail-list li::before,
.materials-guidance li::before {
  content: "";
  position: absolute;
  top: 0.58em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--award-cyan);
}

.entry-kit-download {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(255, 0, 102, 0.26);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 229, 63, 0.36), rgba(255, 255, 255, 0.86) 45%),
    #ffffff;
  box-shadow: 0 14px 34px rgba(34, 17, 68, 0.08);
}

.entry-kit-download p {
  flex: 1 1 260px;
  margin: 0;
  color: var(--cih-heading);
  font-weight: 800;
  line-height: 1.52;
}

.entry-kit-download .button {
  flex: 1 1 100%;
  min-height: 52px;
  padding: 12px 18px;
  white-space: normal;
  text-align: center;
  line-height: 1.35;
}

.nomination-fee-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.28fr);
  gap: 18px;
  margin-top: 10px;
  padding: 22px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 38%),
    #ffffff;
}

.nomination-fee-panel h3 {
  margin: 0 0 8px;
  color: var(--cih-heading);
  font-size: 24px;
}

.nomination-fee-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.nomination-fee-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.nomination-fee-grid article {
  position: relative;
  overflow: hidden;
  min-height: 144px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
}

.nomination-fee-grid article::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 7px;
  background: linear-gradient(90deg, var(--cih-purple), var(--award-cyan), var(--award-gold));
}

.nomination-fee-grid article.early {
  color: var(--paper);
  background: var(--cih-purple);
}

.nomination-fee-grid article.early::before {
  background: var(--award-gold);
}

.nomination-fee-grid small {
  display: block;
  color: var(--cih-heading);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.nomination-fee-grid article.early small,
.nomination-fee-grid article.early p {
  color: rgba(255, 255, 255, 0.82);
}

.nomination-fee-grid strong {
  display: block;
  margin-top: 18px;
  color: var(--cih-heading);
  font-size: 31px;
  line-height: 1;
}

.nomination-fee-grid article.early strong {
  color: var(--award-gold);
}

.timeline article {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 48px minmax(82px, 110px) minmax(0, 1fr);
  gap: 8px 18px;
  align-items: start;
  min-height: 132px;
  padding: 22px 24px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--paper);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.timeline article:hover {
  transform: translateY(-4px);
  border-color: rgba(80, 32, 128, 0.22);
  box-shadow: 0 18px 46px rgba(34, 17, 68, 0.11);
}

.timeline-icon {
  display: inline-grid;
  place-items: center;
  grid-column: 1;
  grid-row: 1 / span 2;
  width: 46px;
  height: 46px;
  margin: 0;
  border-radius: 8px;
  color: var(--paper);
  background: linear-gradient(135deg, var(--cih-purple), var(--cih-magenta));
  vertical-align: middle;
  z-index: 1;
}

.timeline time {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 76px;
  height: 38px;
  padding: 0 12px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-purple);
  font-weight: 900;
  grid-column: 2;
  grid-row: 1;
}

.timeline h3 {
  grid-column: 3;
  grid-row: 1;
  margin: 4px 0 0;
  color: var(--cih-ink);
}

.timeline p {
  grid-column: 3;
  grid-row: 2;
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}

.portal-band {
  background:
    linear-gradient(180deg, rgba(34, 17, 68, 0.96), rgba(80, 32, 128, 0.96)),
    var(--cih-ink);
  color: var(--paper);
}

.portal-page-main {
  min-height: calc(100vh - 84px);
  background:
    linear-gradient(180deg, rgba(238, 234, 250, 0.96) 0 72px, transparent 72px),
    linear-gradient(180deg, rgba(34, 17, 68, 0.96), rgba(80, 32, 128, 0.96)),
    var(--cih-ink);
}

.portal-page-main .portal-band {
  min-height: min(760px, calc(100vh - 84px));
  padding-top: clamp(88px, 12vw, 150px);
}

.portal-page-main .operations-band {
  padding-bottom: clamp(64px, 8vw, 110px);
}

.portal-page-main .backend-login-copy h2 {
  margin: 0 0 8px;
  color: var(--paper);
  font-size: 25px;
  line-height: 1.12;
}

.portal-page-main .portal-shell {
  margin-top: 14px;
}

.portal-page-main .backend-toolbar {
  margin-top: 0;
}

.portal-page-main .portal-band .section-heading h1 {
  color: var(--paper);
}

.portal-band .section-heading h2,
.portal-band .section-heading p {
  color: var(--paper);
}

.portal-band .section-heading p {
  color: rgba(255, 255, 255, 0.72);
}

.backend-login,
.backend-toolbar,
.portal-shell {
  max-width: 1120px;
  margin: 0 auto;
}

.backend-login {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 18px;
  padding: clamp(18px, 3vw, 26px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.13), transparent 38%),
    rgba(255, 255, 255, 0.08);
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.18);
}

.backend-login-mark {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 8px;
  color: var(--award-cyan);
  background: rgba(255, 255, 255, 0.12);
}

.backend-login-mark svg {
  width: 34px;
  height: 34px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.backend-login-copy h3 {
  margin: 0 0 8px;
  color: var(--paper);
  font-size: 25px;
  line-height: 1.12;
}

.backend-login-copy p,
.backend-login-actions p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.5;
}

.backend-role-switch {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.backend-role-switch button {
  min-height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  cursor: pointer;
  font-weight: 900;
}

.backend-role-switch button.active {
  border-color: transparent;
  color: var(--cih-ink);
  background: var(--award-cyan);
}

.backend-login-grid {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.backend-login label {
  display: grid;
  gap: 8px;
  color: rgba(255, 255, 255, 0.84);
  font-size: 12px;
  font-weight: 900;
}

.backend-login input {
  min-height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 6px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.96);
  color: var(--cih-ink);
  font: 800 14px/1.35 Arial, Helvetica, sans-serif;
}

.backend-login-actions {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
}

.backend-login-actions p[data-tone="success"] {
  color: #a8ffe5;
}

.backend-login-actions p[data-tone="alert"] {
  color: #ffd2e4;
}

.backend-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 14px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.1);
}

.backend-toolbar span {
  display: block;
  color: var(--award-cyan);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.backend-toolbar strong {
  display: block;
  margin-top: 4px;
  color: var(--paper);
  line-height: 1.3;
}

.backend-toolbar .button.secondary {
  color: var(--paper);
  border-color: rgba(255, 255, 255, 0.32);
  background: rgba(255, 255, 255, 0.08);
}

.portal-preview {
  padding: 22px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 46%),
    #fbfaff;
  color: var(--text);
}

.portal-landing {
  display: grid;
  gap: 16px;
}

.portal-secure-head {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.portal-lock-icon {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 8px;
  color: var(--award-cyan);
  background: var(--cih-ink);
}

.portal-lock-icon svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.portal-secure-head small {
  display: block;
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.portal-secure-head strong {
  display: block;
  margin-top: 4px;
  color: var(--cih-heading);
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.08;
}

.portal-secure-head p {
  max-width: 760px;
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

.portal-scope-grid,
.portal-task-strip {
  display: grid;
  gap: 10px;
}

.portal-scope-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.portal-scope-grid article {
  position: relative;
  overflow: hidden;
  min-height: 86px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 46%),
    rgba(255, 255, 255, 0.9);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.portal-scope-grid article::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: linear-gradient(180deg, var(--cih-magenta), var(--award-cyan));
}

.portal-scope-grid article:hover,
.portal-task-strip article:hover {
  transform: translateY(-2px);
  border-color: rgba(80, 32, 128, 0.22);
  box-shadow: 0 16px 34px rgba(34, 17, 68, 0.1);
}

.portal-scope-grid span,
.portal-task-strip span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.portal-scope-grid strong {
  display: block;
  margin-top: 8px;
  color: var(--cih-heading);
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.05;
}

.portal-task-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.portal-task-strip article {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 6px;
  min-height: 96px;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.portal-task-strip article::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 0;
  height: 2px;
  border-radius: 99px 99px 0 0;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
  transform: scaleX(0.36);
  transform-origin: left center;
  transition: transform 200ms ease;
}

.portal-task-strip article:hover::after {
  transform: scaleX(1);
}

.portal-task-strip strong {
  color: var(--cih-heading);
  line-height: 1.22;
}

.portal-task-strip em {
  align-self: end;
  justify-self: start;
  padding: 5px 10px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.applicant-action-strip button,
.applicant-action-strip a {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 6px;
  min-height: 96px;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
  color: inherit;
  font: inherit;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.applicant-action-strip button::after,
.applicant-action-strip a::after {
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 0;
  height: 2px;
  border-radius: 99px 99px 0 0;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan), var(--award-gold));
  transform: scaleX(0.36);
  transform-origin: left center;
  transition: transform 200ms ease;
}

.applicant-action-strip button:hover,
.applicant-action-strip a:hover,
.applicant-action-strip button.active {
  transform: translateY(-2px);
  border-color: rgba(80, 32, 128, 0.22);
  box-shadow: 0 16px 34px rgba(34, 17, 68, 0.1);
}

.applicant-action-strip button:hover::after,
.applicant-action-strip a:hover::after,
.applicant-action-strip button.active::after {
  transform: scaleX(1);
}

.applicant-portal-layout {
  display: grid;
  grid-template-columns: minmax(170px, 220px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.applicant-portal-menu,
.applicant-record-list {
  display: grid;
  gap: 8px;
}

.applicant-portal-menu button,
.applicant-record-list button {
  width: 100%;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
  color: var(--cih-heading);
  font: inherit;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
}

.applicant-portal-menu button.active,
.applicant-record-list button.active {
  border-color: rgba(80, 32, 128, 0.32);
  background: var(--cih-soft-lavender);
  box-shadow: inset 3px 0 0 var(--award-cyan);
}

.applicant-portal-content,
.applicant-detail-panel {
  min-width: 0;
}

.applicant-record-browser {
  display: grid;
  grid-template-columns: minmax(210px, 290px) minmax(0, 1fr);
  gap: 14px;
}

.applicant-record-list button {
  display: grid;
  gap: 4px;
}

.applicant-record-list strong {
  font-size: 13px;
}

.applicant-record-list span,
.applicant-record-list small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.applicant-detail-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
}

.applicant-detail-head {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  justify-content: space-between;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.applicant-detail-head small,
.applicant-detail-panel h5 {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.applicant-detail-head h4 {
  margin: 4px 0 0;
  color: var(--cih-heading);
  font-size: 20px;
  line-height: 1.15;
}

.applicant-detail-head > span {
  flex: 0 0 auto;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--cih-soft-lavender);
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.applicant-detail-panel h5 {
  margin: 4px 0 -4px;
}

.applicant-detail-dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.applicant-detail-dl div {
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.12);
  border-radius: 6px;
  background: #fbfaff;
}

.applicant-detail-dl dt {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.applicant-detail-dl dd {
  margin: 4px 0 0;
  color: var(--text);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.applicant-file-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.applicant-file-list span,
.applicant-file-list a,
.applicant-file-list em,
.applicant-empty,
.applicant-account-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.applicant-file-list span,
.applicant-file-list a {
  padding: 7px 9px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 999px;
  background: #fbfaff;
  color: var(--cih-heading);
  text-decoration: none;
  font-weight: 800;
}

.dashboard {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: 374px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--paper);
}

.dashboard aside {
  padding: 22px;
  color: var(--paper);
  background: var(--cih-ink);
}

.dashboard aside strong {
  display: block;
  margin-bottom: 22px;
  font-size: 17px;
}

.side-line {
  display: flex;
  align-items: center;
  min-height: 34px;
  margin: 10px 0;
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.25);
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
}

.dashboard-main {
  padding: 24px;
}

.dashboard-top {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}

.metric {
  min-height: 104px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-soft);
}

.metric small {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.metric strong {
  display: block;
  margin-top: 8px;
  color: var(--cih-heading);
  font-size: 26px;
}

.work-table {
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
}

.work-row {
  display: grid;
  grid-template-columns: 1.1fr 0.8fr 0.6fr;
  gap: 18px;
  align-items: center;
  min-height: 54px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
}

.work-row:last-child {
  border-bottom: 0;
}

.status-pill {
  display: inline-flex;
  justify-content: center;
  min-width: 84px;
  padding: 5px 10px;
  border-radius: 99px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.application-band,
.operations-band,
.media-band {
  padding: clamp(58px, 8vw, 104px) clamp(18px, 5vw, 72px);
}

.application-band {
  background:
    radial-gradient(circle at 12% 16%, rgba(102, 204, 255, 0.16), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f6f2ff 100%);
}

.application-notes {
  display: grid;
  grid-template-columns: 0.34fr 1fr;
  gap: 18px;
  max-width: 1320px;
  margin: -10px auto 18px;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 50px rgba(34, 17, 68, 0.08);
}

.application-notes h3 {
  margin: 0 0 8px;
  color: var(--cih-heading);
  font-size: 22px;
  line-height: 1.1;
}

.application-notes p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.application-note-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.application-note-grid article {
  min-height: 96px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
}

.application-note-grid small {
  display: block;
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.application-note-grid strong {
  display: block;
  margin-top: 8px;
  color: var(--cih-ink);
  font-size: 14px;
  line-height: 1.35;
}

.app-workspace {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr) 290px;
  gap: 18px;
  max-width: 1320px;
  margin: 0 auto;
}

.app-workspace[data-auth-locked="true"] {
  grid-template-columns: minmax(0, 720px);
  justify-content: center;
}

.app-workspace[data-auth-locked="true"] .app-rail,
.app-workspace[data-auth-locked="true"] .application-summary,
.app-workspace[data-auth-locked="true"] .form-step:not([data-step="account"]),
.app-workspace[data-auth-locked="true"] .nominator-authority,
.app-workspace[data-auth-locked="true"] .form-actions {
  display: none;
}

.app-workspace[data-auth-locked="true"] .nomination-form {
  position: relative;
  max-width: 720px;
  overflow: hidden;
}

.app-workspace[data-auth-locked="true"] .nomination-form::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 6px;
  background: linear-gradient(180deg, var(--cih-magenta), var(--award-cyan));
}

.app-rail,
.nomination-form,
.application-summary,
.judge-console,
.admin-console {
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 22px 70px rgba(34, 17, 68, 0.12);
  backdrop-filter: blur(14px);
}

.app-rail,
.application-summary {
  padding: 20px;
}

.workspace-icon,
.console-heading svg {
  display: grid;
  place-items: center;
  color: var(--award-cyan);
}

.workspace-icon {
  width: 58px;
  height: 58px;
  margin-bottom: 18px;
  border-radius: 8px;
  background: var(--cih-ink);
}

.workspace-icon svg,
.console-heading svg {
  width: 34px;
  height: 34px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.app-rail strong {
  display: block;
  color: var(--cih-heading);
  font-size: 18px;
  line-height: 1.2;
}

.app-rail p {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.progress-meter {
  position: relative;
  height: 10px;
  margin: 18px 0 8px;
  overflow: hidden;
  border-radius: 99px;
  background: var(--cih-soft-lavender);
}

.progress-meter span {
  position: relative;
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan));
  transition: width 240ms ease;
}

.progress-meter span::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.55), transparent);
  transform: translateX(-100%);
  animation: progressSheen 2.8s ease-in-out infinite;
}

.step-list {
  position: relative;
  display: grid;
  gap: 8px;
  margin-top: 18px;
}

.step-list button,
.viewer-strip button,
.admin-table button,
.auth-mode button,
.assigned-entry-list button,
.admin-accounts button {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
  color: var(--cih-heading);
  cursor: pointer;
  font-weight: 850;
}

.auth-mode {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin: 0 0 16px;
}

.auth-mode button,
.assigned-entry-list button,
.admin-accounts button {
  min-height: 38px;
  padding: 0 12px;
}

.auth-mode button.active,
.assigned-entry-list button.active,
.admin-accounts button.active {
  border-color: transparent;
  color: var(--paper);
  background: var(--cih-purple);
}

.step-list button {
  position: relative;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 42px;
  padding: 0 12px;
  text-align: left;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
}

.step-list button::before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(83, 35, 127, 0.26);
  border-radius: 50%;
  background: #ffffff;
}

.step-list button::after {
  content: "";
  position: absolute;
  left: 19px;
  top: 50%;
  width: 7px;
  height: 11px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: translateY(-62%) rotate(42deg);
}

.step-list button:hover:not(:disabled) {
  transform: translateX(2px);
  border-color: rgba(80, 32, 128, 0.24);
  box-shadow: 0 10px 24px rgba(34, 17, 68, 0.08);
}

.step-list button.active {
  border-color: transparent;
  color: var(--paper);
  background: var(--cih-purple);
  box-shadow: 0 14px 30px rgba(80, 32, 128, 0.18);
}

.step-list button.active::before {
  border-color: rgba(255, 255, 255, 0.8);
  background: radial-gradient(circle at center, var(--award-cyan) 0 34%, transparent 38%);
}

.step-list button[data-step-state="complete"] {
  border-color: rgba(37, 116, 77, 0.2);
  color: #165a3e;
  background: #f0fff8;
}

.step-list button[data-step-state="complete"]::before {
  border-color: transparent;
  background: linear-gradient(135deg, #1f9f72, var(--award-cyan));
}

.step-list button[data-step-state="complete"]::after {
  border-color: #ffffff;
}

.step-list button[data-step-state="locked"] {
  opacity: 0.68;
  cursor: not-allowed;
}

.step-list button[data-step-state="locked"]::before {
  background: linear-gradient(180deg, #ffffff, var(--cih-soft-lavender));
}

.nomination-form {
  padding: clamp(20px, 3vw, 30px);
}

.form-banner,
.admin-log,
.form-note {
  padding: 12px 14px;
  border-radius: 6px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-weight: 800;
  line-height: 1.4;
}

.form-banner[data-banner-key="formBannerDefault"],
.form-banner[data-banner-key="loginModeMessage"],
.form-banner[data-banner-key="registerModeMessage"],
.form-banner[data-banner-key="applicationLoginRequiredMessage"]:not([data-tone="alert"]) {
  display: none;
}

.form-banner[data-tone="success"],
.form-note[data-tone="success"] {
  color: #0a5a45;
  background: #dcfff4;
}

.form-banner[data-tone="alert"] {
  color: #8a0036;
  background: #ffe5f0;
}

.step-helper {
  display: none;
}

.phone-input-group {
  display: grid;
  grid-template-columns: minmax(120px, 0.38fr) minmax(0, 1fr);
  gap: 8px;
  width: 100%;
}

.early-bird-workspace-note {
  display: grid;
  gap: 8px;
  margin: 12px 0 0;
  padding: 14px 16px;
  border: 1px solid rgba(255, 0, 102, 0.24);
  border-left: 5px solid var(--cih-magenta);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 229, 63, 0.3), rgba(255, 255, 255, 0.92) 58%),
    #ffffff;
  box-shadow: 0 12px 28px rgba(34, 17, 68, 0.08);
}

.early-bird-workspace-note[hidden] {
  display: none;
}

.early-bird-workspace-note strong {
  color: var(--cih-magenta);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0;
}

.early-bird-workspace-note p {
  margin: 0;
  color: var(--cih-heading);
  font-size: 13px;
  font-weight: 850;
  line-height: 1.5;
}

.field-error-card {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(255, 0, 102, 0.28);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 229, 63, 0.32), rgba(255, 229, 63, 0) 58%),
    #fff5fa;
  box-shadow: 0 16px 34px rgba(83, 35, 127, 0.1);
}

.field-error-card strong {
  color: #8a0036;
  font-size: 14px;
  font-weight: 900;
}

.field-error-card p {
  margin: 0;
  color: var(--cih-heading);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.form-step {
  display: none;
  margin: 22px 0 0;
  padding: 0;
  border: 0;
}

.form-step.active {
  display: block;
  animation: liftIn 260ms ease both;
}

.form-step legend {
  margin-bottom: 16px;
  color: var(--cih-heading);
  font-size: 24px;
  font-weight: 900;
}

.form-grid,
.upload-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.nomination-form label,
.enquiry-form label {
  display: grid;
  gap: 8px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
}

.nomination-form input,
.nomination-form select,
.enquiry-form input,
.enquiry-form select,
.enquiry-form textarea {
  min-height: 44px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  background: var(--paper);
  color: var(--text);
  font: 700 14px/1.35 Arial, Helvetica, sans-serif;
}

.nomination-form input:focus,
.nomination-form select:focus,
.enquiry-form input:focus,
.enquiry-form select:focus,
.enquiry-form textarea:focus {
  outline: 3px solid rgba(102, 204, 255, 0.35);
  border-color: var(--award-cyan);
}

.nomination-form label.field-issue input,
.nomination-form label.field-issue select,
.nomination-form label.field-issue textarea {
  border-color: var(--cih-magenta);
  background: #fff7fb;
  box-shadow: 0 0 0 3px rgba(255, 0, 102, 0.12);
}

.nomination-form label.field-focus-pulse input,
.nomination-form label.field-focus-pulse select,
.nomination-form label.field-focus-pulse textarea {
  animation: fieldFocusPulse 900ms ease-in-out 2;
}

.inline-field-error {
  color: #8a0036;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.4;
}

@keyframes fieldFocusPulse {
  0%,
  100% {
    box-shadow: 0 0 0 3px rgba(255, 0, 102, 0.12);
  }

  50% {
    box-shadow: 0 0 0 7px rgba(102, 204, 255, 0.34);
  }
}

.nomination-form input[type="checkbox"],
.nomination-form input[type="radio"] {
  flex: 0 0 auto;
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  accent-color: var(--cih-magenta);
}

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

.password-control button {
  min-height: 44px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: var(--paper);
  cursor: pointer;
  font-weight: 900;
}

.otp-panel {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(160px, 0.42fr) auto;
  gap: 14px;
  align-items: end;
  margin: 16px 0 0;
  padding: 16px;
  border: 1px solid rgba(80, 32, 128, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 42%),
    #fcfbff;
}

.otp-panel strong {
  display: block;
  color: var(--cih-ink);
  font-size: 15px;
}

.otp-panel p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.otp-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.otp-panel small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.otp-panel small[data-tone="success"] {
  color: #25744d;
}

.otp-panel small[data-tone="sent"] {
  color: #ff0000;
  font-weight: 950;
}

.otp-panel small[data-tone="alert"] {
  color: #a72d55;
}

.segmented-control,
.payment-methods {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.segmented-control {
  grid-template-columns: repeat(2, 1fr);
}

.payment-methods {
  grid-template-columns: minmax(220px, 360px);
  margin-top: 16px;
}

.nominator-authority {
  display: grid;
  gap: 14px;
  margin: 16px 0 0;
  padding: 16px;
  border: 1px solid rgba(80, 32, 128, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 42%),
    #fcfbff;
}

.nominator-authority strong {
  display: block;
  color: var(--cih-ink);
  font-size: 15px;
}

.nominator-authority p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.nominator-authority .segmented-control {
  margin-bottom: 0;
}

.eligibility-checklist {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding: 16px;
  border: 1px solid rgba(80, 32, 128, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.06), transparent 40%),
    #fcfbff;
}

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

.contact-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(80, 32, 128, 0.18);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.09), transparent 42%),
    #fcfbff;
}

.contact-panel h4 {
  margin: 0;
  color: var(--cih-heading);
  font-size: 17px;
}

.contact-panel label {
  display: grid;
  gap: 7px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.form-link-note {
  margin: 0 0 16px;
  padding: 13px 14px;
  border-left: 4px solid var(--cih-magenta);
  border-radius: 6px;
  color: var(--cih-heading);
  background: linear-gradient(90deg, rgba(255, 0, 102, 0.08), rgba(102, 204, 255, 0.08));
  font-size: 14px;
  font-weight: 900;
  line-height: 1.45;
}

.form-link-note a {
  color: var(--cih-magenta);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.eligibility-checklist > strong {
  color: var(--cih-ink);
  font-size: 15px;
}

.eligibility-checklist > p {
  margin: -4px 0 4px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.segmented-control label,
.payment-methods label,
.check-row {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.payment-page {
  display: grid;
  gap: 14px;
  margin: 18px 0;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 42%),
    #ffffff;
  box-shadow: 0 16px 42px rgba(34, 17, 68, 0.08);
}

.payment-page[hidden] {
  display: none;
}

.payment-page-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.payment-page-head strong {
  display: block;
  color: var(--cih-heading);
  font-size: 20px;
}

.payment-page-head p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.payment-page-head span,
[data-payment-status] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 99px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
}

.payment-page-head span[data-tone="success"],
[data-payment-status][data-tone="success"] {
  color: #075a42;
  background: #d9fff2;
}

.payment-page-head span[data-tone="pending"],
[data-payment-status][data-tone="pending"] {
  color: #7a4a00;
  background: #fff0c2;
}

.payment-page-details {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.payment-page-details div {
  min-height: 76px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.payment-page-details dt {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.payment-page-details dd {
  margin: 8px 0 0;
  color: var(--cih-heading);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.payment-instruction {
  padding: 13px 14px;
  border-left: 4px solid var(--award-cyan);
  border-radius: 6px;
  color: var(--muted);
  background: #fcfbff;
  font-size: 13px;
  font-weight: 750;
  line-height: 1.55;
}

.payment-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.declaration-panel {
  display: grid;
  gap: 8px;
  margin: 18px 0 12px;
  padding: 16px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  background: linear-gradient(180deg, #ffffff, #fbf8ff);
}

.declaration-panel strong {
  color: var(--cih-heading);
  font-size: 16px;
}

.declaration-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.signature-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 10px;
  margin-top: 6px;
}

.signature-grid label {
  display: grid;
  gap: 6px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.signature-grid input {
  min-width: 0;
}

.declaration-panel small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.upload-grid label {
  min-height: 116px;
  padding: 14px;
  border: 1px dashed rgba(83, 35, 127, 0.28);
  border-radius: 6px;
  background: #fcfbff;
}

.material-status {
  margin-top: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.materials-guidance {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  background: #fcfbff;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.form-actions [data-save-application] {
  margin-left: auto;
  border-color: rgba(83, 35, 127, 0.36);
  font-weight: 900;
}

.account-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.signed-in-panel {
  display: grid;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(102, 204, 255, 0.13), rgba(236, 224, 255, 0.72));
}

.signed-in-panel[hidden] {
  display: none;
}

.signed-in-panel > div:first-child {
  display: grid;
  gap: 4px;
}

.signed-in-panel strong {
  color: var(--cih-heading);
  font-size: 18px;
}

.signed-in-panel p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.signed-in-panel dl {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.signed-in-panel dl div {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.78);
}

.signed-in-panel dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.signed-in-panel dd {
  margin: 4px 0 0;
  color: var(--cih-heading);
  font-size: clamp(15px, 1.2vw, 18px);
  font-weight: 900;
  overflow-wrap: anywhere;
}

.signed-in-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.account-status {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.account-status[data-tone="success"] {
  color: #25744d;
}

.account-status[data-tone="alert"] {
  color: #a72d55;
}

.nomination-form .button.secondary {
  color: var(--cih-heading);
  border-color: var(--line);
  background: var(--paper);
}

.nomination-form [data-reserve-invoice],
.invoice-actions .invoice-button {
  border-color: rgba(83, 35, 127, 0.38);
  background: #f2e8ff;
  color: var(--cih-heading);
  font-weight: 900;
}

.nomination-form .button.secondary:hover {
  background: var(--cih-soft-lavender);
}

.invoice-actions .invoice-button:disabled,
.otp-actions .button:disabled,
.applicant-action-strip button:disabled,
.payment-page-actions .button:disabled,
.form-actions .button:disabled {
  border-color: rgba(83, 35, 127, 0.22);
  background: #eee8f7;
  color: #4d3671;
  opacity: 1;
  cursor: not-allowed;
  box-shadow: none;
}

.application-summary {
  display: grid;
  gap: 12px;
  align-content: start;
}

.application-summary h3 {
  margin: 0 0 4px;
  color: var(--cih-heading);
  font-size: 24px;
}

.summary-card,
.invoice-preview,
.next-action-card {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
}

.next-action-card {
  border-color: rgba(102, 204, 255, 0.34);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.14), rgba(255, 255, 255, 0.94) 60%),
    #ffffff;
}

.submission-snapshot {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(80, 32, 128, 0.18);
  border-radius: 6px;
  background: #fcfbff;
}

.submission-snapshot > span {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.submission-snapshot dl {
  display: grid;
  gap: 9px;
  margin: 0;
}

.submission-snapshot div {
  display: grid;
  gap: 2px;
}

.submission-snapshot dt {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.submission-snapshot dd {
  margin: 0;
  color: var(--cih-ink);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.summary-card small,
.invoice-preview span,
.invoice-preview small,
.next-action-card small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.summary-card strong,
.invoice-preview strong,
.next-action-card strong {
  display: block;
  margin-top: 7px;
  color: var(--cih-heading);
  font-size: 18px;
  line-height: 1.2;
}

.next-action-card p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.invoice-preview strong {
  color: var(--cih-magenta);
  font-size: 28px;
}

.invoice-actions,
.entry-list,
.my-orders-panel,
.notification-panel,
.correction-panel,
.finalist-package {
  display: grid;
  gap: 8px;
}

.my-orders-panel,
.notification-panel,
.correction-panel {
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #ffffff;
}

.my-orders-panel strong,
.notification-panel strong,
.correction-panel strong {
  color: var(--cih-heading);
  font-size: 16px;
}

.my-orders-panel p,
.my-orders-panel small,
.notification-panel p,
.notification-panel small,
.correction-panel p,
.correction-panel small {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.my-orders-panel label,
.correction-panel label {
  display: grid;
  gap: 6px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.my-orders-panel input,
.correction-panel input,
.correction-panel textarea {
  min-height: 38px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  background: var(--paper);
  color: var(--text);
  font: 750 13px/1.35 Arial, Helvetica, sans-serif;
}

.payment-proof-uploader {
  display: grid;
  gap: 9px;
  padding: 12px;
  border: 1px solid rgba(255, 0, 102, 0.24);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.08), rgba(102, 204, 255, 0.09)),
    #ffffff;
}

.payment-proof-uploader .button.primary {
  border-color: transparent;
  color: var(--paper);
  background: var(--cih-magenta);
}

.payment-proof-uploader .button.primary:hover {
  background: #d90059;
}

.correction-panel textarea {
  min-height: 78px;
  resize: vertical;
}

.my-orders-panel small[data-tone="success"],
.notification-panel small[data-tone="success"],
.correction-panel small[data-tone="success"] {
  color: #25744d;
}

.notification-panel button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.correction-panel small[data-tone="alert"] {
  color: #b43d3d;
}

.order-list,
.notification-list,
.correction-list {
  display: grid;
  gap: 8px;
}

.order-list article,
.order-list p,
.notification-list article,
.notification-list p,
.correction-list article,
.correction-list p {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.correction-list article {
  gap: 8px;
}

.notification-list article {
  gap: 7px;
  border-left: 4px solid var(--cih-cyan);
}

.notification-list article[data-tone="success"] {
  border-left-color: #25744d;
}

.notification-list article[data-tone="alert"] {
  border-left-color: #b43d3d;
}

.notification-list article[data-read="true"] {
  opacity: 0.76;
}

.correction-list article > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.notification-list article > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.order-list article strong,
.notification-list article strong,
.correction-list article strong {
  color: var(--cih-magenta);
  font-size: 14px;
}

.order-list article span,
.notification-list article span,
.correction-list article span {
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.finalist-package {
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 46%),
    #ffffff;
}

.finalist-package strong {
  color: var(--cih-heading);
  font-size: 16px;
}

.finalist-package p,
.finalist-package small {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.finalist-package label {
  display: grid;
  gap: 6px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.finalist-package input,
.finalist-package select {
  min-height: 38px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  background: var(--paper);
  color: var(--text);
  font: 750 13px/1.35 Arial, Helvetica, sans-serif;
}

.finalist-package small[data-tone="success"] {
  color: #25744d;
}

.finalist-package small[data-tone="alert"] {
  color: #b43d3d;
}

.finalist-interview {
  display: grid;
  gap: 7px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.finalist-interview strong {
  font-size: 13px;
}

.finalist-interview dl {
  display: grid;
  gap: 5px;
  margin: 0;
}

.finalist-interview dl div {
  display: grid;
  grid-template-columns: 0.78fr 1fr;
  gap: 6px;
}

.finalist-interview dt,
.finalist-interview dd {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 11px;
  line-height: 1.35;
}

.finalist-interview dt {
  color: var(--muted);
  font-weight: 900;
}

.finalist-interview dd,
.finalist-interview a {
  color: var(--cih-heading);
  font-weight: 850;
}

.entry-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: var(--paper);
}

.entry-card > label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 850;
}

.entry-copy {
  display: grid;
  min-width: 0;
  gap: 3px;
}

.entry-card-status {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 2px;
}

.entry-card-status span {
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 11px;
  font-weight: 900;
}

.entry-list em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  line-height: 1.25;
}

.entry-list input {
  accent-color: var(--cih-magenta);
}

.entry-card details {
  display: grid;
  gap: 8px;
}

.entry-card summary {
  width: fit-content;
  color: var(--cih-magenta);
  cursor: pointer;
  font-size: 12px;
  font-weight: 950;
}

.entry-card dl {
  display: grid;
  gap: 7px;
  margin: 8px 0 0;
}

.entry-card dl div {
  display: grid;
  grid-template-columns: 0.82fr 1fr;
  gap: 8px;
  padding: 7px 0;
  border-top: 1px solid rgba(83, 35, 127, 0.1);
}

.entry-card dt,
.entry-card dd {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 11px;
  line-height: 1.35;
}

.entry-card dt {
  color: var(--muted);
  font-weight: 900;
}

.entry-card dd,
.entry-card a {
  color: var(--cih-heading);
  font-weight: 850;
}

.invoice-button {
  width: 100%;
  color: var(--cih-heading);
  border-color: var(--line);
  background: var(--paper);
  font-weight: 900;
}

.order-status {
  display: block;
  min-height: 18px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.4;
}

.order-status[data-tone="success"] {
  color: #25744d;
}

.order-status[data-tone="alert"] {
  color: #a72d55;
}

.operations-band {
  padding-top: clamp(34px, 4.5vw, 58px);
  background:
    linear-gradient(180deg, rgba(34, 17, 68, 0.96), rgba(80, 32, 128, 0.94)),
    var(--cih-ink);
  color: var(--paper);
}

.operations-band .section-heading {
  align-items: center;
  margin-bottom: 22px;
}

.operations-band .section-heading h2 {
  font-size: clamp(30px, 3.5vw, 46px);
  line-height: 1.04;
}

.operations-band .section-heading p {
  font-size: 16px;
  line-height: 1.55;
}

.operations-band .section-heading h2,
.operations-band .section-heading p {
  color: var(--paper);
}

.operations-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 18px;
  max-width: 1200px;
  margin: 0 auto;
}

.judge-console,
.admin-console {
  padding: 24px;
  color: var(--text);
}

.console-heading {
  display: flex;
  align-items: center;
  gap: 14px;
}

.console-heading h3 {
  margin: 0;
  color: var(--cih-heading);
  font-size: 25px;
}

.console-heading p {
  margin: 4px 0 0;
  color: var(--muted);
  font-weight: 750;
}

.viewer-strip {
  display: flex;
  gap: 8px;
  margin: 20px 0;
}

.viewer-strip button {
  min-height: 38px;
  padding: 0 13px;
}

.viewer-strip button.active {
  color: var(--paper);
  background: var(--cih-purple);
}

.judge-meta,
.assigned-entry-list,
.admin-accounts {
  display: grid;
  gap: 8px;
  margin: 0 0 16px;
}

.judge-meta {
  grid-template-columns: repeat(2, 1fr);
}

.judge-meta span,
.review-summary {
  padding: 12px;
  border-radius: 6px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 13px;
  font-weight: 850;
}

.viewer-panel {
  min-height: 112px;
  margin: 0 0 16px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 48%),
    var(--paper);
}

.viewer-panel strong,
.review-summary strong {
  display: block;
  color: var(--cih-heading);
  font-size: 17px;
}

.viewer-panel p,
.review-summary-output {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.5;
}

.score-package-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.72);
}

.score-package-panel small {
  display: inline-flex;
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  color: var(--cih-magenta);
  background: rgba(255, 0, 102, 0.08);
  font-size: 11px;
  font-weight: 950;
}

.score-package-panel p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.score-package-panel p[data-tone="ready"] {
  color: #875500;
}

.score-package-panel p[data-tone="success"] {
  color: #25744d;
}

.score-package-panel button {
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid rgba(83, 35, 127, 0.22);
  color: var(--cih-heading);
  background: #ffffff;
}

.score-package-panel button:not(:disabled) {
  border-color: var(--cih-magenta);
  color: #ffffff;
  background: var(--cih-magenta);
}

.score-package-panel button:disabled {
  color: var(--muted);
  background: #ffffff;
  opacity: 1;
  cursor: not-allowed;
}

.viewer-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.viewer-head small,
.viewer-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: #25744d;
  background: #dcfff4;
  font-size: 11px;
  font-weight: 900;
}

.viewer-head > span {
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
}

.viewer-head a {
  min-height: 34px;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.pdf-reviewer,
.video-reviewer {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.pdf-toolbar {
  display: grid;
  grid-template-columns: auto minmax(90px, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.pdf-toolbar button {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.pdf-toolbar button:disabled {
  opacity: 0.46;
  cursor: not-allowed;
}

.pdf-toolbar i {
  display: block;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--cih-soft-lavender);
}

.pdf-toolbar i span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan));
}

.pdf-sheet {
  position: relative;
  min-height: 220px;
  padding: 22px;
  overflow: hidden;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background:
    linear-gradient(90deg, rgba(83, 35, 127, 0.08) 1px, transparent 1px) 0 0 / 24px 24px,
    #ffffff;
}

.pdf-sheet::after {
  content: "";
  position: absolute;
  right: -40px;
  bottom: -50px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(102, 204, 255, 0.18), transparent 68%);
}

.pdf-sheet small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.pdf-sheet h4 {
  max-width: 460px;
  margin: 18px 0 8px;
  color: var(--cih-heading);
  font-size: 28px;
  line-height: 1.08;
}

.pdf-sheet p {
  max-width: 520px;
  margin: 0;
  color: var(--muted);
  font-weight: 850;
}

.pdf-page-mark {
  position: absolute;
  right: 18px;
  top: 18px;
  color: rgba(83, 35, 127, 0.18);
  font-size: 42px;
  font-weight: 950;
}

.pdf-sheet ul {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 7px;
  max-width: 520px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.pdf-sheet li {
  color: var(--cih-heading);
  font-size: 13px;
  font-weight: 850;
}

.video-reviewer {
  grid-template-columns: minmax(0, 1.2fr) minmax(190px, 0.8fr);
  align-items: stretch;
}

.video-frame {
  display: grid;
  place-items: center;
  min-height: 220px;
  padding: 20px;
  border-radius: 6px;
  color: #ffffff;
  text-align: center;
  background:
    radial-gradient(circle at 72% 20%, rgba(102, 204, 255, 0.28), transparent 30%),
    linear-gradient(135deg, var(--cih-ink), var(--cih-purple));
}

.video-frame svg {
  width: 54px;
  height: 54px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.video-frame span {
  display: block;
  margin-top: 14px;
  font-size: 18px;
  font-weight: 950;
}

.video-reviewer dl {
  display: grid;
  gap: 10px;
  margin: 0;
}

.video-reviewer dl div,
.viewer-weight-summary article,
.viewer-tier-list article {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
}

.video-reviewer dt,
.video-reviewer dd {
  margin: 0;
}

.video-reviewer dt {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.video-reviewer dd {
  margin-top: 5px;
  color: var(--cih-heading);
  font-size: 18px;
  font-weight: 950;
}

.viewer-tier-list,
.viewer-weight-summary {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.viewer-tier-list {
  grid-template-columns: repeat(5, 1fr);
}

.viewer-weight-summary {
  grid-template-columns: repeat(5, 1fr);
}

.viewer-tier-list strong,
.viewer-weight-summary strong {
  display: block;
  color: var(--cih-magenta);
  line-height: 1.2;
}

.viewer-tier-list span,
.viewer-weight-summary span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.25;
}

.viewer-checklist {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.viewer-checklist li {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 46px;
  padding: 9px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: var(--cih-soft-lavender);
}

.viewer-checklist svg {
  width: 21px;
  height: 21px;
  color: var(--cih-magenta);
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.viewer-checklist span {
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.judge-entry-evidence {
  display: grid;
  grid-template-columns: minmax(0, 0.65fr) minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
}

.judge-entry-evidence div {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.judge-entry-evidence strong {
  color: var(--cih-heading);
  font-size: 13px;
}

.judge-entry-evidence p {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.judge-entry-evidence span {
  display: inline-flex;
  padding: 4px 7px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 11px;
  font-weight: 900;
}

.judge-entry-evidence a {
  justify-self: end;
  min-height: 32px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #fcfbff;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.review-score-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.review-score-list li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(83, 35, 127, 0.14);
}

.review-score-list li:first-child {
  border-top: 0;
}

.review-score-list li strong,
.review-score-list li span {
  margin: 0;
  color: var(--cih-heading);
  font-size: 13px;
}

.review-score-list li span {
  color: var(--muted);
  text-align: right;
}

.assigned-entry-list {
  grid-template-columns: repeat(2, 1fr);
}

.assigned-entry-list button {
  display: grid;
  gap: 4px;
  align-content: center;
  text-align: left;
}

.assigned-entry-list button strong,
.assigned-entry-list button small {
  display: block;
  line-height: 1.2;
}

.assigned-entry-list button small {
  color: inherit;
  opacity: 0.68;
  font-size: 11px;
  font-weight: 800;
}

.weighting-panel {
  display: grid;
  gap: 12px;
  margin: 0 0 16px;
  padding: 16px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #ffffff;
}

.weighting-heading {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(220px, 1fr);
  gap: 16px;
  align-items: start;
}

.weighting-heading h4 {
  margin: 0 0 6px;
  color: var(--cih-heading);
  font-size: 18px;
}

.weighting-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.weighting-heading dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.weighting-heading dl div {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 10px;
  align-items: baseline;
  min-height: 30px;
  padding: 8px 10px;
  border-radius: 6px;
  background: var(--cih-soft-lavender);
}

.weighting-heading dt {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.weighting-heading dd {
  margin: 0;
  color: var(--cih-heading);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.25;
}

.weight-bars {
  display: grid;
  gap: 8px;
}

.weight-bars article {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 42px;
  gap: 12px;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.weight-bars span,
.weight-bars strong {
  position: relative;
  z-index: 1;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.weight-bars strong {
  text-align: right;
  color: var(--cih-magenta);
}

.weight-bars i {
  position: absolute;
  left: 0;
  bottom: 0;
  width: var(--weight-width);
  height: 4px;
  background: linear-gradient(90deg, var(--cih-magenta), var(--award-cyan));
}

.score-list {
  display: grid;
  gap: 12px;
}

.score-row {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(120px, 220px) 36px;
  align-items: center;
  gap: 14px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
  color: var(--cih-heading);
  font-weight: 900;
}

.score-row small {
  color: var(--muted);
}

.score-row input {
  accent-color: var(--cih-magenta);
}

.score-total {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin: 18px 0;
  padding: 16px;
  border-radius: 6px;
  background: var(--cih-ink);
  color: var(--paper);
}

.score-total strong {
  color: var(--award-gold);
  font-size: 34px;
}

.score-total small {
  margin-left: auto;
  color: var(--cih-lavender);
  font-weight: 900;
}

.score-lock-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  margin: -6px 0 18px;
  padding: 13px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #ffffff;
}

.score-lock-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.score-lock-panel p[data-tone="locked"] {
  color: #25744d;
}

.score-lock-panel button {
  min-height: 36px;
  padding: 0 13px;
}

.judge-conflict-panel {
  display: grid;
  gap: 10px;
  margin: -6px 0 18px;
  padding: 13px;
  border: 1px solid rgba(157, 35, 77, 0.24);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(157, 35, 77, 0.08), transparent 46%),
    #ffffff;
}

.judge-conflict-panel[data-conflict="true"] {
  border-color: rgba(157, 35, 77, 0.42);
  background:
    linear-gradient(135deg, rgba(157, 35, 77, 0.12), transparent 52%),
    #fffafb;
}

.judge-conflict-panel strong {
  color: var(--cih-heading);
  font-size: 15px;
}

.judge-conflict-panel p,
.judge-conflict-panel small {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.judge-conflict-panel small[data-tone="alert"] {
  color: #9d234d;
}

.judge-conflict-panel label {
  display: grid;
  gap: 6px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.judge-conflict-panel textarea {
  width: 100%;
  min-height: 66px;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  font: inherit;
  font-size: 13px;
  resize: vertical;
}

.judge-conflict-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.judge-conflict-actions button {
  min-height: 36px;
  padding: 0 13px;
}

.score-row input:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.admin-table {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}

.admin-table-rows {
  display: grid;
  gap: 10px;
}

.admin-table-rows > div {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr) minmax(180px, 0.75fr) minmax(160px, 0.7fr) repeat(4, minmax(72px, auto));
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.admin-table-toolbar,
.admin-bulk-bar,
.admin-table-pagination {
  display: grid;
  gap: 10px;
  align-items: end;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
}

.admin-table-toolbar {
  grid-template-columns: minmax(220px, 1.3fr) repeat(3, minmax(150px, 0.7fr));
}

.admin-bulk-bar {
  grid-template-columns: minmax(120px, auto) minmax(160px, 0.8fr) minmax(220px, 1fr) auto;
}

.admin-table-pagination {
  grid-template-columns: minmax(130px, 1fr) auto auto auto auto;
}

.admin-table-toolbar label,
.admin-table-pagination label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-table-toolbar input,
.admin-table-toolbar select,
.admin-bulk-bar select,
.admin-table-pagination select {
  min-height: 36px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 7px 9px;
  color: var(--cih-heading);
  background: #ffffff;
  font: 800 12px/1.2 Arial, Helvetica, sans-serif;
}

.admin-bulk-bar > span,
.admin-table-pagination > span,
.admin-table-pagination > strong {
  align-self: center;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.admin-row-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--cih-heading);
  font-weight: 900;
}

.admin-row-check input {
  width: 16px;
  height: 16px;
  accent-color: var(--cih-magenta);
}

.admin-assignee-summary {
  overflow-wrap: anywhere;
  font-size: 11px;
  line-height: 1.35;
}

.admin-empty-state {
  margin: 0;
  padding: 14px;
  border: 1px dashed rgba(83, 35, 127, 0.2);
  border-radius: 6px;
  color: var(--muted);
  background: #ffffff;
  font-size: 13px;
  font-weight: 850;
}

.admin-table strong {
  color: var(--cih-heading);
}

.admin-table span {
  color: var(--muted);
  font-weight: 750;
}

.admin-entry-main {
  display: grid;
  gap: 3px;
}

.admin-entry-main em,
.admin-entry-main small {
  display: block;
  line-height: 1.25;
}

.admin-entry-main em {
  color: var(--cih-heading);
  font-style: normal;
  font-weight: 900;
}

.admin-entry-main small {
  color: var(--muted);
  font-size: 11px;
}

.operations-band[data-active-role="admin"] .admin-console,
.operations-band[data-active-role="judge"] .judge-console {
  grid-column: 1 / -1;
}

.admin-app-switcher {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0;
}

.admin-app-switcher button {
  display: grid;
  gap: 6px;
  min-height: 86px;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  color: var(--cih-heading);
  background:
    linear-gradient(180deg, #ffffff, #fcfbff);
  cursor: pointer;
  text-align: left;
}

.admin-app-switcher button.active {
  border-color: rgba(236, 0, 140, 0.46);
  background:
    linear-gradient(135deg, rgba(236, 0, 140, 0.08), transparent 42%),
    linear-gradient(180deg, #ffffff, #fbf8ff);
  box-shadow: inset 0 0 0 1px rgba(236, 0, 140, 0.18);
}

.admin-app-switcher span {
  color: var(--cih-heading);
  font-size: 16px;
  font-weight: 950;
  line-height: 1.2;
}

.admin-app-switcher small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}

.admin-console[data-admin-mode="cms"] [data-admin-surface="awards"],
.admin-console[data-admin-mode="awards"] [data-admin-surface="cms"] {
  display: none !important;
}

.admin-table button {
  min-height: 34px;
}

.admin-command-panel {
  display: grid;
  gap: 12px;
  margin: 16px 0;
  padding: 14px;
  border: 1px solid rgba(102, 204, 255, 0.24);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.13), transparent 44%),
    linear-gradient(180deg, #ffffff, #fcfbff);
}

.admin-command-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, 0.28fr) auto;
  gap: 10px;
  align-items: stretch;
}

.admin-command-summary article,
.admin-command-summary a {
  min-width: 0;
  padding: 13px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
}

.admin-command-summary small,
.admin-command-summary p,
.admin-command-summary span {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.admin-command-summary small {
  display: block;
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-command-summary strong {
  display: block;
  margin-top: 7px;
  color: var(--cih-heading);
  font-size: 20px;
  line-height: 1.12;
}

.admin-command-summary p {
  margin-top: 7px;
  font-weight: 750;
}

.admin-command-summary a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 132px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
  text-decoration: none;
}

.admin-workbench-nav {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(94px, 1fr));
  gap: 7px;
}

.admin-workbench-nav button {
  display: grid;
  gap: 4px;
  min-width: 0;
  min-height: 48px;
  padding: 8px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  text-align: left;
}

.admin-workbench-nav span {
  overflow: hidden;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  line-height: 1.15;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.admin-workbench-nav strong {
  color: var(--cih-purple);
  font-size: 16px;
  line-height: 1;
}

.admin-kpis {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  margin: 18px 0 14px;
}

.admin-kpis article {
  min-height: 82px;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #ffffff;
}

.admin-kpis small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-kpis strong {
  display: block;
  margin-top: 8px;
  color: var(--cih-magenta);
  font-size: 24px;
}

.admin-export-panel,
.admin-payment-panel,
.admin-assignment-panel,
.admin-review-panel,
.admin-finalist-panel,
.admin-results-panel,
.admin-cms-panel,
.admin-enquiry-panel,
.admin-users-panel,
.admin-audit {
  display: grid;
  gap: 10px;
  margin: 14px 0;
  padding: 14px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #ffffff;
}

.admin-export-panel > strong,
.admin-payment-panel strong,
.admin-assignment-panel strong,
.admin-review-panel strong,
.admin-finalist-panel strong,
.admin-results-panel strong,
.admin-cms-panel strong,
.admin-enquiry-panel strong,
.admin-users-panel strong,
.admin-audit > strong {
  color: var(--cih-heading);
  font-size: 16px;
}

.admin-cms-panel p,
.admin-users-panel p,
.admin-payment-panel p,
.admin-review-panel p,
.admin-finalist-panel p,
.admin-results-panel p,
.admin-enquiry-panel p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.admin-assignment-panel p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.admin-assignment-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-conflict-strip,
.admin-assignment-board,
.admin-judge-pool {
  grid-column: 1 / -1;
}

.admin-conflict-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-assignment-board,
.admin-judge-pool {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.12);
  border-radius: 6px;
  background: #fbf9ff;
}

.admin-assignment-board-head {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.admin-assignment-board-head strong {
  color: var(--cih-heading);
  font-size: 15px;
}

.admin-assignment-board-head span {
  padding: 0;
  color: var(--muted);
  background: transparent;
  font-size: 12px;
  font-weight: 900;
}

.admin-assignment-focus {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 14px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(102, 204, 255, 0.42);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.14), rgba(255, 221, 82, 0.12)),
    #ffffff;
  box-shadow: inset 0 0 0 1px rgba(102, 204, 255, 0.16);
}

.admin-assignment-focus div {
  display: grid;
  gap: 4px;
}

.admin-assignment-focus p {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.admin-assignment-focus > button {
  min-width: 132px;
}

.admin-payment-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-payment-grid article {
  display: grid;
  gap: 9px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 42%),
    #fcfbff;
}

.admin-payment-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-payment-grid strong {
  font-size: 14px;
  line-height: 1.25;
}

.admin-payment-grid span {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.admin-payment-grid span[data-status-key="paymentConfirmed"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-payment-grid span[data-status-key="paymentBankPending"] {
  color: #875500;
  background: #fff4cc;
}

.admin-payment-grid span[data-status-key="paymentProofUploaded"],
.admin-payment-grid span[data-status-key="paymentWaitingForUpload"] {
  color: #875500;
  background: #fff4cc;
}

.admin-payment-grid span[data-status-key="paymentRejected"] {
  color: #9f1239;
  background: #ffe4ec;
}

.admin-payment-grid dl {
  display: grid;
  gap: 6px;
  margin: 0;
}

.admin-payment-grid dl div {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
}

.admin-payment-grid dt,
.admin-payment-grid dd {
  min-width: 0;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.admin-payment-grid dt {
  color: var(--cih-heading);
  font-weight: 900;
}

.admin-payment-grid button {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-card-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 8px;
}

.admin-evidence-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-evidence-link {
  min-height: 28px;
  padding: 4px 8px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 11px;
  font-weight: 900;
  text-align: left;
  overflow-wrap: anywhere;
}

.admin-evidence-link:hover {
  border-color: rgba(102, 204, 255, 0.62);
  box-shadow: inset 0 0 0 1px rgba(102, 204, 255, 0.24);
}

.admin-evidence-preview {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(102, 204, 255, 0.32);
  border-radius: 6px;
  background: #f7fcff;
}

.admin-evidence-preview[hidden] {
  display: none;
}

.admin-evidence-preview dl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 6px;
  margin: 0;
}

.admin-payment-grid .admin-evidence-preview dl {
  grid-template-columns: 1fr;
}

.admin-evidence-preview dl div {
  min-width: 0;
  padding: 8px;
  border-radius: 5px;
  background: #ffffff;
}

.admin-evidence-preview dt,
.admin-evidence-preview dd,
.admin-evidence-preview p {
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-evidence-preview dt {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-evidence-preview dd,
.admin-evidence-preview p {
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.4;
}

.admin-evidence-open {
  justify-self: start;
  padding: 7px 10px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
}

.admin-review-detail {
  display: grid;
  gap: 10px;
}

.admin-review-detail > p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.admin-review-detail article {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 44%),
    #fcfbff;
}

.admin-review-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.admin-review-head small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-review-head strong {
  display: block;
  margin-top: 4px;
  color: var(--cih-heading);
  font-size: 16px;
  line-height: 1.25;
}

.admin-review-head span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
}

.admin-review-head em {
  display: inline-flex;
  justify-content: center;
  min-width: 128px;
  padding: 7px 10px;
  border-radius: 999px;
  color: #875500;
  background: #fff4cc;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  text-align: center;
}

.admin-review-head em[data-status-key="adminReviewApprovedStatus"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-review-head em[data-status-key="adminReviewReturnedStatus"] {
  color: #875500;
  background: #fff4cc;
}

.admin-review-head em[data-status-key="adminReviewDisqualifiedStatus"] {
  color: #9d234d;
  background: #ffe5f0;
}

.admin-review-detail dl {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.admin-review-detail dl div {
  min-width: 0;
  padding: 10px;
  border-radius: 6px;
  background: #ffffff;
}

.admin-review-detail dt,
.admin-review-detail dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-review-detail dt {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-review-detail dd {
  margin-top: 5px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
}

.admin-review-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-review-actions button {
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-assignment-grid article {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.admin-assignment-grid article.active {
  border-color: rgba(102, 204, 255, 0.42);
  box-shadow: inset 0 0 0 1px rgba(102, 204, 255, 0.26);
}

.admin-assignment-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.admin-assignment-card-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 11px;
}

.admin-assignment-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-assignment-grid strong {
  font-size: 14px;
  line-height: 1.25;
}

.admin-assignment-grid code {
  display: block;
  padding: 7px 8px;
  border: 1px solid rgba(83, 35, 127, 0.12);
  border-radius: 5px;
  color: var(--cih-heading);
  background: #ffffff;
  font-size: 11px;
  font-weight: 850;
  white-space: normal;
  overflow-wrap: anywhere;
}

.admin-assignment-grid span,
.admin-assignment-grid em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
}

.admin-assignment-grid span {
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
}

.admin-assignment-grid span[data-status-key="adminJudgeAvailable"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-conflict-card {
  border-color: rgba(157, 35, 77, 0.24) !important;
  background:
    linear-gradient(135deg, rgba(157, 35, 77, 0.08), transparent 48%),
    #fffafb !important;
}

.admin-conflict-card.is-empty {
  border-color: rgba(83, 35, 127, 0.14) !important;
  background: #ffffff !important;
}

.admin-assignment-grid span[data-status-key="adminJudgeConflict"] {
  color: #9d234d;
  background: #ffe5f0;
}

.admin-assignee-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-assignee-chips button,
.admin-assignee-chips em {
  min-height: 28px;
  padding: 5px 8px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 999px;
  color: var(--cih-heading);
  background: #ffffff;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.admin-assignment-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.admin-assignment-controls select {
  min-height: 34px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 7px 9px;
  color: var(--cih-heading);
  background: #ffffff;
  font: 800 12px/1.2 Arial, Helvetica, sans-serif;
}

.admin-conflict-card dl {
  display: grid;
  gap: 6px;
  margin: 0;
}

.admin-conflict-card dl div {
  display: grid;
  gap: 3px;
}

.admin-conflict-card dt,
.admin-conflict-card dd {
  min-width: 0;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.admin-conflict-card dt {
  color: var(--cih-heading);
  font-weight: 900;
}

.admin-assignment-grid button {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-finalist-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-finalist-grid article {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.06), transparent 44%),
    #fcfbff;
}

.admin-finalist-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-finalist-grid strong {
  font-size: 14px;
  line-height: 1.25;
}

.admin-finalist-grid span {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.admin-finalist-grid span[data-status-key="adminFinalistMaterialsStatus"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-finalist-grid dl {
  display: grid;
  gap: 5px;
  margin: 0;
}

.admin-finalist-grid dl div {
  display: grid;
  grid-template-columns: 0.78fr 1fr;
  gap: 6px;
}

.admin-finalist-grid dt,
.admin-finalist-grid dd {
  margin: 0;
  font-size: 11px;
  line-height: 1.35;
}

.admin-finalist-grid dt {
  color: var(--muted);
  font-weight: 900;
}

.admin-finalist-grid dd {
  min-width: 0;
  color: var(--text);
  font-weight: 850;
  overflow-wrap: anywhere;
}

.admin-finalist-schedule {
  display: grid;
  gap: 7px;
}

.admin-finalist-schedule label {
  display: grid;
  gap: 5px;
}

.admin-finalist-schedule em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-finalist-schedule input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 9px;
  background: #ffffff;
  color: var(--text);
  font: 750 12px/1.35 Arial, Helvetica, sans-serif;
}

.admin-finalist-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.admin-finalist-grid button {
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-results-grid {
  display: grid;
  gap: 10px;
}

.admin-results-grid article {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) minmax(420px, 1.4fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.05), transparent 44%),
    #fcfbff;
}

.admin-results-grid article[data-ready="true"] {
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.12), transparent 44%),
    #ffffff;
}

.admin-result-rank {
  display: grid;
  place-items: center;
  min-height: 54px;
  border-radius: 6px;
  color: var(--paper);
  background: var(--cih-purple);
}

.admin-result-rank small,
.admin-result-rank strong {
  color: inherit;
  line-height: 1;
}

.admin-result-rank small {
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-result-rank strong {
  font-size: 22px;
}

.admin-result-main {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.admin-result-main strong {
  color: var(--cih-heading);
  font-size: 15px;
  line-height: 1.25;
}

.admin-result-main span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
}

.admin-results-grid dl {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.admin-results-grid dl div {
  min-width: 0;
  padding: 9px;
  border-radius: 6px;
  background: #ffffff;
}

.admin-results-grid dt,
.admin-results-grid dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-results-grid dt {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.admin-results-grid dd {
  margin-top: 4px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.admin-results-grid article > span {
  display: inline-flex;
  justify-content: center;
  min-width: 126px;
  padding: 7px 10px;
  border-radius: 999px;
  color: #875500;
  background: #fff4cc;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
  text-align: center;
}

.admin-results-grid article[data-ready="true"] > span {
  color: #25744d;
  background: #dcfff4;
}

.admin-score-breakdown,
.admin-score-empty {
  grid-column: 1 / -1;
}

.admin-score-empty {
  margin: 0;
  padding: 10px;
  border: 1px dashed rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  color: var(--muted);
  background: #ffffff;
  font-size: 12px;
  font-weight: 800;
}

.admin-score-breakdown {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.12);
  border-radius: 6px;
  background: #ffffff;
}

.admin-score-breakdown > strong {
  color: var(--cih-heading);
  font-size: 13px;
}

.admin-score-breakdown article {
  display: grid;
  grid-template-columns: minmax(150px, 0.35fr) minmax(0, 1fr);
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(83, 35, 127, 0.1);
  border-radius: 5px;
  background: #fbf9ff;
}

.admin-score-breakdown article div {
  display: grid;
  gap: 3px;
  align-content: start;
}

.admin-score-breakdown b,
.admin-score-breakdown small,
.admin-score-breakdown span,
.admin-score-breakdown em {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-score-breakdown b {
  color: var(--cih-heading);
  font-size: 12px;
}

.admin-score-breakdown small,
.admin-score-breakdown em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.admin-score-breakdown span {
  color: var(--cih-magenta);
  font-size: 12px;
  font-weight: 900;
}

.admin-score-breakdown ul {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.admin-score-breakdown li {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 7px;
  border-radius: 5px;
  background: #ffffff;
}

.admin-score-breakdown li span {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.25;
}

.admin-score-breakdown li strong {
  color: var(--cih-heading);
  font-size: 14px;
}

.admin-cms-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.admin-cms-grid article {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.1), transparent 44%),
    #fcfbff;
}

.admin-cms-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: stretch;
}

.admin-cms-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.admin-cms-stats article,
.admin-cms-toolbar a {
  min-width: 0;
  padding: 11px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #fcfbff;
}

.admin-cms-stats small {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-cms-stats strong {
  display: block;
  margin-top: 5px;
  color: var(--cih-heading);
  font-size: 20px;
}

.admin-cms-toolbar a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 132px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
  text-decoration: none;
}

.admin-cms-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.admin-cms-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-cms-grid span {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.admin-cms-grid span[data-status-key="adminCmsPublishedStatus"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-cms-record {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.admin-cms-record div,
.admin-cms-preview {
  min-width: 0;
  padding: 9px;
  border-radius: 6px;
  background: #ffffff;
}

.admin-cms-record dt,
.admin-cms-record dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-cms-record dt {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-cms-record dd {
  margin-top: 5px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.3;
}

.admin-cms-preview {
  display: grid;
  gap: 5px;
}

.admin-cms-preview strong {
  color: var(--cih-heading);
  font-size: 15px;
  line-height: 1.25;
}

.admin-cms-preview p,
.admin-cms-preview em {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.4;
}

.admin-cms-preview em {
  color: var(--cih-magenta);
}

.admin-cms-grid label {
  display: grid;
  gap: 5px;
}

.admin-cms-grid label em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.admin-cms-grid input,
.admin-cms-grid textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 9px;
  background: #ffffff;
  color: var(--text);
  font: 750 12px/1.35 Arial, Helvetica, sans-serif;
}

.admin-cms-grid textarea {
  min-height: 76px;
  resize: vertical;
}

.admin-cms-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.admin-cms-grid button,
.admin-cms-grid a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
  text-decoration: none;
}

.admin-cms-copy-library,
.admin-cms-image-library,
.admin-cms-collection-library {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(83, 35, 127, 0.14);
}

.cms-library-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.cms-library-head > span,
.cms-library-head label {
  min-width: 140px;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #fcfbff;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.cms-library-head label {
  display: grid;
  gap: 5px;
  text-align: left;
}

.cms-library-head label em,
.cms-library-controls label em,
.cms-copy-fields em,
.cms-image-grid label em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.cms-library-head select,
.cms-library-controls input,
.cms-copy-fields textarea,
.cms-image-grid input,
.cms-collection-grid textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 9px;
  background: #ffffff;
  color: var(--text);
  font: 750 12px/1.35 Arial, Helvetica, sans-serif;
}

.cms-library-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.cms-library-controls label {
  display: grid;
  gap: 5px;
}

.cms-library-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cms-library-actions button,
.cms-image-grid button,
.cms-collection-grid button {
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.cms-copy-group {
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
  overflow: hidden;
}

.cms-copy-group summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  color: var(--cih-heading);
  cursor: pointer;
  font-size: 13px;
  font-weight: 950;
}

.cms-copy-group summary span {
  color: var(--cih-magenta);
  font-size: 12px;
}

.cms-copy-list {
  display: grid;
  gap: 8px;
  padding: 0 12px 12px;
  max-height: 520px;
  overflow: auto;
}

.cms-copy-list article {
  display: grid;
  grid-template-columns: minmax(150px, 0.28fr) minmax(0, 1fr);
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.cms-copy-list small {
  display: block;
  color: var(--cih-magenta);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.cms-copy-list strong {
  display: block;
  margin-top: 4px;
  color: var(--cih-heading);
  font-size: 13px;
  overflow-wrap: anywhere;
}

.cms-copy-fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.cms-copy-fields label {
  display: grid;
  gap: 5px;
}

.cms-copy-fields textarea {
  min-height: 72px;
  resize: vertical;
}

.cms-empty {
  margin: 0;
  padding: 14px;
  border: 1px dashed var(--line);
  border-radius: 6px;
  color: var(--muted);
  background: #fcfbff;
  font-size: 13px;
  font-weight: 800;
}

.cms-image-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.cms-image-grid article {
  display: grid;
  gap: 9px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.cms-image-grid img {
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 6px;
  object-fit: contain;
  background:
    linear-gradient(45deg, #f4f0fa 25%, transparent 25%),
    linear-gradient(-45deg, #f4f0fa 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #f4f0fa 75%),
    linear-gradient(-45deg, transparent 75%, #f4f0fa 75%),
    #ffffff;
  background-size: 20px 20px;
  background-position: 0 0, 0 10px, 10px -10px, -10px 0;
}

.cms-image-grid small,
.cms-image-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.cms-image-grid strong {
  color: var(--cih-heading);
  font-size: 14px;
  line-height: 1.25;
}

.cms-image-grid label {
  display: grid;
  gap: 5px;
}

.cms-collection-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.cms-collection-grid article {
  display: grid;
  gap: 9px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.cms-collection-grid small {
  color: var(--cih-magenta);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.cms-collection-grid strong {
  color: var(--cih-heading);
  font-size: 14px;
}

.cms-collection-grid textarea {
  min-height: 190px;
  resize: vertical;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 11px;
}

.cms-section-layout {
  display: grid;
  grid-template-columns: minmax(180px, 0.28fr) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.cms-section-nav {
  display: grid;
  gap: 7px;
  position: sticky;
  top: 86px;
}

.cms-section-nav button,
.cms-section-editor-head a,
.cms-section-actions button,
.cms-section-actions a,
.cms-section-collection summary button,
.cms-section-item-controls button,
.cms-section-remove {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
  color: var(--cih-heading);
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.cms-section-nav button {
  display: grid;
  gap: 3px;
  padding: 10px;
  text-align: left;
}

.cms-section-nav button.active {
  border-color: rgba(255, 0, 128, 0.38);
  background: linear-gradient(90deg, rgba(255, 0, 128, 0.08), rgba(68, 194, 255, 0.08));
  box-shadow: inset 3px 0 0 var(--cih-magenta);
}

.cms-section-nav strong,
.cms-section-editor-head strong,
.cms-section-collection strong,
.cms-section-copy-list strong {
  color: var(--cih-heading);
  font-size: 14px;
  line-height: 1.25;
}

.cms-section-nav span,
.cms-section-editor-head small,
.cms-section-editor-head p,
.cms-section-collection small,
.cms-section-collection p,
.cms-section-copy-list small,
.cms-section-item small {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
}

.cms-section-editor {
  display: grid;
  gap: 12px;
}

.cms-section-editor-head,
.cms-section-actions,
.cms-section-item-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.cms-section-editor-head {
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #fcfbff;
}

.cms-section-actions {
  position: sticky;
  bottom: 12px;
  z-index: 24;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 42px rgba(34, 17, 68, 0.16);
  backdrop-filter: blur(10px);
}

.cms-language-workbench {
  display: grid;
  grid-template-columns: minmax(0, 0.34fr) minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: linear-gradient(90deg, rgba(83, 35, 127, 0.06), rgba(68, 194, 255, 0.05));
}

.cms-language-workbench small,
.cms-language-workbench p {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
}

.cms-language-workbench strong {
  display: block;
  margin: 3px 0;
  color: var(--cih-heading);
  font-size: 15px;
}

.cms-language-lanes {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.cms-language-lanes button {
  display: grid;
  gap: 3px;
  min-height: 66px;
  padding: 9px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
  color: var(--cih-heading);
  cursor: pointer;
  text-align: left;
}

.cms-language-lanes button.active {
  border-color: rgba(255, 0, 128, 0.4);
  box-shadow: inset 0 -3px 0 var(--cih-magenta);
}

.cms-language-lanes span {
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.cms-language-lanes strong,
.cms-language-lanes small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.25;
}

.cms-section-editor-head a,
.cms-section-actions button,
.cms-section-actions a {
  min-height: 36px;
  padding: 9px 12px;
  text-decoration: none;
}

.cms-section-save-primary {
  border-color: rgba(255, 0, 102, 0.45) !important;
  background: linear-gradient(90deg, var(--cih-magenta), var(--cih-purple)) !important;
  color: #ffffff !important;
  box-shadow: 0 10px 24px rgba(255, 0, 102, 0.16);
}

.cms-section-panel {
  display: grid;
  gap: 10px;
}

.cms-section-panel h4 {
  margin: 0;
  color: var(--cih-heading);
  font-size: 15px;
}

.cms-section-copy-list,
.cms-section-list {
  display: grid;
  gap: 9px;
}

.cms-section-copy-list article,
.cms-section-item,
.cms-section-collection {
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: #ffffff;
}

.cms-section-copy-list article {
  display: grid;
  grid-template-columns: minmax(145px, 0.22fr) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
}

.cms-copy-fields-matrix {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cms-section-collection {
  overflow: hidden;
}

.cms-section-collection summary {
  display: grid;
  grid-template-columns: minmax(140px, 0.32fr) minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  list-style: none;
}

.cms-section-collection summary::-webkit-details-marker {
  display: none;
}

.cms-section-collection summary button {
  min-height: 32px;
  padding: 7px 10px;
}

.cms-collection-language-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cms-collection-language-chips span {
  padding: 6px 8px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 999px;
  background: #ffffff;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.cms-collection-language-chips span.active {
  border-color: rgba(68, 194, 255, 0.48);
  color: var(--cih-heading);
  background: rgba(68, 194, 255, 0.12);
}

.cms-section-collection > p {
  padding: 0 12px 10px;
}

.cms-section-list {
  padding: 0 12px 12px;
}

.cms-section-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding: 10px;
  background: #fcfbff;
}

.cms-section-item.dragging {
  opacity: 0.55;
  outline: 2px solid rgba(68, 194, 255, 0.55);
}

.cms-section-item label,
.cms-section-judge-fields label,
.cms-section-object-item label,
.cms-friendly-field {
  display: grid;
  gap: 5px;
}

.cms-section-item label em,
.cms-section-judge-fields label em,
.cms-section-object-item label em,
.cms-friendly-field em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.cms-section-item textarea,
.cms-section-item input,
.cms-section-judge-fields textarea,
.cms-section-judge-fields input,
.cms-section-object-item textarea,
.cms-section-object-item input,
.cms-friendly-field textarea,
.cms-friendly-field input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 9px;
  background: #ffffff;
  color: var(--text);
  font: 750 12px/1.35 Arial, Helvetica, sans-serif;
}

.cms-section-item textarea,
.cms-section-object-item textarea,
.cms-friendly-field textarea {
  resize: vertical;
}

.cms-friendly-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.cms-friendly-field:only-child,
.cms-friendly-field textarea,
.cms-friendly-fieldset {
  min-width: 0;
}

.cms-friendly-field small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.cms-friendly-fieldset {
  display: grid;
  grid-column: 1 / -1;
  gap: 8px;
  margin: 0;
  padding: 10px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.72);
}

.cms-friendly-fieldset legend {
  padding: 0 5px;
  color: var(--cih-heading);
  font-size: 11px;
  font-weight: 900;
}

.cms-section-item-controls {
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
}

.cms-section-item-controls span {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 999px;
  background: rgba(83, 35, 127, 0.1);
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.cms-section-item-controls button,
.cms-section-remove {
  min-height: 30px;
  padding: 6px 8px;
}

.cms-drag-handle {
  cursor: grab;
}

.cms-section-judge-item {
  grid-template-columns: auto 72px minmax(0, 1fr) auto;
}

.cms-section-judge-preview {
  width: 72px;
  aspect-ratio: 1;
  overflow: hidden;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: linear-gradient(145deg, rgba(83, 35, 127, 0.08), rgba(68, 194, 255, 0.08));
}

.cms-section-judge-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.cms-section-judge-preview span {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  color: var(--cih-heading);
  font-weight: 900;
}

.cms-section-judge-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.cms-section-object-item {
  grid-template-columns: minmax(180px, 0.24fr) minmax(0, 1fr);
}

.cms-collection-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.cms-collection-card-meta span {
  padding: 5px 7px;
  border: 1px solid rgba(83, 35, 127, 0.12);
  border-radius: 999px;
  background: #ffffff;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.admin-enquiry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.admin-enquiry-grid > p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.admin-enquiry-grid article {
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.06), transparent 44%),
    #fcfbff;
}

.admin-enquiry-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-enquiry-grid strong,
.admin-enquiry-grid a,
.admin-enquiry-grid p,
.admin-enquiry-grid em {
  min-width: 0;
  margin: 0;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.admin-enquiry-grid strong {
  color: var(--cih-heading);
  font-size: 14px;
}

.admin-enquiry-grid a,
.admin-enquiry-grid em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.admin-enquiry-grid p {
  color: var(--cih-heading);
  font-size: 13px;
}

.admin-enquiry-grid span {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--cih-heading);
  background: var(--cih-soft-lavender);
  font-size: 12px;
  font-weight: 900;
}

.admin-enquiry-grid span[data-status-key="adminEnquiryInProgressStatus"] {
  color: #875500;
  background: #fff4cc;
}

.admin-enquiry-grid span[data-status-key="adminEnquiryClosedStatus"] {
  color: #25744d;
  background: #dcfff4;
}

.admin-enquiry-grid div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-enquiry-grid button {
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-users-grid {
  display: grid;
  gap: 10px;
}

.admin-permission-note,
.admin-user-create,
.admin-system-users,
.admin-applicant-users {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.admin-permission-note,
.admin-user-create {
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background: #f8f3ff;
}

.admin-user-create {
  grid-template-columns: repeat(5, minmax(0, 1fr)) auto;
  align-items: end;
}

.admin-user-create > strong {
  grid-column: 1 / -1;
}

.admin-user-create label,
.admin-system-user-fields label,
.admin-system-users article > label {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.admin-user-create span,
.admin-system-user-fields span,
.admin-system-users article > label span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-user-create input,
.admin-user-create select,
.admin-system-user-fields input,
.admin-system-user-fields select,
.admin-system-users article > label input {
  width: 100%;
  min-height: 36px;
  min-width: 0;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  font: inherit;
  font-size: 12px;
  font-weight: 850;
}

.admin-password-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-transform: none;
}

.admin-password-field button {
  min-height: 36px;
  padding: 0 10px;
  white-space: nowrap;
}

.admin-users-subhead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.admin-users-subhead span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.admin-users-grid > p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.admin-users-grid article {
  display: grid;
  gap: 9px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(83, 35, 127, 0.07), transparent 42%),
    #fcfbff;
}

.admin-system-users article {
  grid-template-columns: minmax(120px, 0.9fr) minmax(180px, 1fr) minmax(160px, 1.1fr) minmax(0, 2fr) auto;
  align-items: end;
}

.admin-system-user-fields {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.admin-users-grid small {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.admin-users-grid strong,
.admin-users-grid a {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-users-grid strong {
  color: var(--cih-heading);
  font-size: 14px;
}

.admin-users-grid a {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.admin-users-grid dl {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.admin-users-grid dl div {
  min-width: 0;
  padding: 8px;
  border-radius: 6px;
  background: #ffffff;
}

.admin-users-grid dt,
.admin-users-grid dd {
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-users-grid dt {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-users-grid dd {
  margin-top: 4px;
  color: var(--cih-heading);
  font-size: 12px;
  font-weight: 900;
}

.admin-users-grid button {
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
}

.admin-export-actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.admin-export-actions button {
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #fcfbff;
  font-size: 12px;
  font-weight: 900;
}

.admin-audit ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.admin-audit li {
  display: grid;
  grid-template-columns: minmax(132px, 0.22fr) minmax(190px, 0.28fr) minmax(0, 1fr);
  gap: 8px;
  align-items: baseline;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}

.admin-audit li:first-child {
  border-top: 0;
  padding-top: 0;
}

.admin-audit span,
.admin-audit em,
.admin-audit p {
  min-width: 0;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.admin-audit em {
  color: var(--cih-magenta);
  font-style: normal;
  font-weight: 900;
}

.admin-audit p {
  color: var(--cih-heading);
  font-weight: 800;
}

.admin-accounts {
  grid-template-columns: repeat(3, 1fr);
}

.jury-band {
  background: var(--paper);
}

.jury-grid,
.terms-grid,
.media-grid {
  display: grid;
  max-width: 1200px;
  margin: 0 auto;
  gap: 12px;
}

.jury-grid {
  grid-template-columns: repeat(4, 1fr);
}

.jury-grid article,
.terms-grid article,
.media-grid article {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper);
  padding: 16px;
}

.jury-grid article span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 12px;
  border-radius: 50%;
  color: var(--paper);
  background: linear-gradient(135deg, var(--cih-purple), var(--cih-magenta));
  font-size: 12px;
  font-weight: 900;
}

.jury-grid article img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  margin-bottom: 14px;
  border-radius: 6px;
  object-fit: cover;
  object-position: center top;
  background: #eee9f6;
}

.jury-grid article img[data-judge-image="judge-chow-kenny"],
.jury-grid article img[data-judge-image="judge-wong-romulus"] {
  object-position: center center;
}

.jury-grid article img[data-judge-image="judge-lee-arthur"] {
  object-position: center 22%;
}

.jury-grid article img[data-judge-image="judge-lee-jonathan"] {
  object-position: center 18%;
}

.jury-grid article img[data-judge-image="judge-lo-vanessa"] {
  object-position: center 18%;
}

.jury-grid article img[data-judge-image="judge-mak-filla"] {
  object-position: center 18%;
}

.jury-grid article img[data-judge-image="judge-ng-isaac"] {
  object-position: center 66%;
}

.jury-grid article img[data-judge-image="judge-tse-don"] {
  object-position: center 20%;
}

.jury-grid article img[data-judge-image="judge-yeung-gary"] {
  object-position: center 16%;
}

.jury-grid article strong,
.terms-grid article strong,
.media-grid article strong {
  display: block;
  color: var(--cih-heading);
  line-height: 1.2;
}

.jury-grid article p,
.terms-grid article p,
.media-grid article p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 13px;
}

.terms-band {
  background: #fcfbff;
}

.terms-grid {
  grid-template-columns: 1fr;
}

.terms-grid article small,
.media-grid article span {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--cih-magenta);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.terms-summary-card {
  display: grid;
  gap: 14px;
}

.terms-summary-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.terms-summary-card li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.54;
}

.terms-summary-card li::before {
  content: "";
  position: absolute;
  top: 0.68em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--award-cyan);
}

.terms-summary-card .button {
  width: fit-content;
}

.terms-detail {
  max-width: 1200px;
  margin: 18px auto 0;
  padding-top: 4px;
}

.terms-detail h3 {
  margin: 0 0 12px;
  color: var(--cih-heading);
  font-size: 24px;
}

.terms-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.terms-detail-grid article {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
}

.terms-detail-grid strong {
  display: block;
  color: var(--cih-heading);
  line-height: 1.25;
}

.terms-detail-grid ul {
  display: grid;
  gap: 7px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.terms-detail-grid li {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.terms-page-main {
  padding-top: 96px;
  background: #fcfbff;
}

.terms-page-hero {
  padding: clamp(54px, 8vw, 94px) clamp(18px, 5vw, 64px) clamp(28px, 5vw, 52px);
  background:
    linear-gradient(180deg, rgba(83, 35, 127, 0.08), rgba(83, 35, 127, 0)),
    #f8f5fd;
}

.terms-page-hero .section-heading {
  margin-bottom: 0;
}

.terms-page-hero h1 {
  margin: 0;
  color: var(--cih-heading);
  font-size: clamp(38px, 6vw, 68px);
  line-height: 0.98;
}

.terms-page-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 22px;
}

.terms-page-content {
  padding: clamp(28px, 5vw, 62px) clamp(18px, 5vw, 64px) clamp(58px, 7vw, 92px);
}

.terms-page-document {
  width: min(1120px, 100%);
  margin: 0 auto;
}

.terms-page-document > h2 {
  margin: 0 0 18px;
  color: var(--cih-heading);
  font-size: clamp(26px, 4vw, 40px);
}

.terms-page-grid {
  grid-template-columns: 1fr;
}

.terms-page-grid article {
  padding: clamp(18px, 3vw, 26px);
}

.terms-page-grid strong {
  font-size: 18px;
}

.terms-page-grid li {
  padding-left: 0;
  color: #3f3650;
  font-size: 15px;
  line-height: 1.66;
}

.media-band {
  background:
    radial-gradient(circle at 88% 18%, rgba(255, 0, 102, 0.13), transparent 24%),
    var(--paper);
}

.media-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 1200px;
  margin: -6px auto 18px;
}

.media-controls button {
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-radius: 6px;
  color: var(--cih-heading);
  background: #ffffff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.media-controls button:hover,
.media-controls button.active {
  border-color: rgba(255, 0, 102, 0.36);
  background: var(--cih-soft-lavender);
  transform: translateY(-1px);
}

.media-feature {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr) minmax(240px, 0.65fr);
  gap: 18px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto 14px;
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(255, 0, 102, 0.08), transparent 34%),
    #ffffff;
}

.media-orbit {
  position: relative;
  display: grid;
  place-items: center;
  width: 112px;
  aspect-ratio: 1;
  border-radius: 50%;
  color: #ffffff;
  background: radial-gradient(circle at 28% 22%, var(--award-cyan), var(--cih-purple) 68%);
  box-shadow: 0 18px 42px rgba(34, 17, 68, 0.22);
}

.media-orbit svg {
  width: 46px;
  height: 46px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.media-orbit span {
  position: absolute;
  inset: 9px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 50%;
  animation: orbitPulse 3.8s ease-in-out infinite;
}

.media-orbit span:last-child {
  inset: 20px;
  animation-delay: 900ms;
}

.media-feature-asset {
  width: 132px;
  aspect-ratio: 1;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 6px;
  object-fit: cover;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(34, 17, 68, 0.14);
}

.media-feature small,
.media-grid article small {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  color: #25744d;
  background: #dcfff4;
  font-size: 11px;
  font-weight: 900;
}

.media-feature strong {
  display: block;
  color: var(--cih-heading);
  font-size: 24px;
  line-height: 1.2;
}

.media-feature p {
  max-width: 620px;
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.55;
}

.media-feature dl {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 0;
}

.media-feature dl div {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fcfbff;
}

.media-feature dt,
.media-feature dd {
  margin: 0;
}

.media-feature dt {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.media-feature dd {
  margin-top: 4px;
  color: var(--cih-magenta);
  font-size: 20px;
  font-weight: 950;
}

.media-grid {
  grid-template-columns: repeat(4, 1fr);
}

.media-grid article {
  position: relative;
  min-height: 236px;
  overflow: hidden;
  background:
    radial-gradient(circle at 90% 8%, rgba(102, 204, 255, 0.26), transparent 26%),
    linear-gradient(160deg, rgba(34, 17, 68, 0.96), rgba(80, 32, 128, 0.86)),
    var(--cih-ink);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.media-grid article:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(34, 17, 68, 0.18);
}

.media-card-icon {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  margin-bottom: 16px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 50%;
  color: var(--award-cyan);
  background: rgba(255, 255, 255, 0.08);
}

.media-card-icon svg {
  width: 25px;
  height: 25px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.media-card-asset {
  width: 100%;
  height: 82px;
  margin-bottom: 14px;
  border-radius: 6px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.12);
}

.media-grid article strong,
.media-grid article p {
  color: var(--paper);
}

.media-grid article span {
  color: var(--award-cyan);
}

.media-grid article small {
  margin-top: 14px;
  margin-bottom: 0;
  color: var(--cih-heading);
  background: rgba(255, 255, 255, 0.9);
}

.sponsor-band {
  background: var(--paper);
}

.faq-band {
  background: var(--paper-soft);
}

.faq-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  max-width: 980px;
  margin: 0 auto;
}

.faq-item {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 24px rgba(34, 17, 68, 0.04);
}

.faq-item summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  min-height: 60px;
  padding: 18px 22px;
  color: var(--cih-ink);
  cursor: pointer;
  list-style: none;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "";
  width: 9px;
  height: 9px;
  border-right: 2px solid var(--cih-heading);
  border-bottom: 2px solid var(--cih-heading);
  transform: rotate(45deg);
  transition: transform 160ms ease;
}

.faq-item[open] summary::after {
  transform: rotate(225deg);
}

.faq-item summary span {
  display: inline-grid;
  place-items: center;
  min-width: 42px;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--paper);
  background: linear-gradient(135deg, var(--cih-purple), var(--cih-magenta));
  font-size: 12px;
  font-weight: 950;
}

.faq-item summary strong {
  color: var(--cih-ink);
  font-size: 18px;
  line-height: 1.26;
}

.faq-item p {
  margin: 0;
  padding: 0 22px 22px 76px;
  color: var(--muted);
  line-height: 1.6;
}

.sponsor-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  max-width: 1080px;
  margin: 0 auto;
}

.sponsor-grid article {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 116px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.08), transparent 42%),
    #fcfbff;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.sponsor-grid article:hover {
  border-color: rgba(255, 0, 102, 0.28);
  box-shadow: 0 14px 28px rgba(34, 17, 68, 0.12);
  transform: translateY(-2px);
}

.sponsor-mark {
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  color: #ffffff;
  background: linear-gradient(135deg, var(--cih-purple), var(--cih-magenta));
  font-size: 18px;
  font-weight: 950;
}

.sponsor-logo {
  width: 62px;
  height: 62px;
  padding: 8px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  object-fit: contain;
  background: #ffffff;
}

.sponsor-grid small {
  display: block;
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 900;
}

.sponsor-grid strong {
  display: block;
  margin-top: 3px;
  color: var(--cih-heading);
  line-height: 1.25;
}

.sponsor-grid span {
  display: inline-flex;
  width: fit-content;
  margin-top: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--muted);
  background: #ffffff;
  font-size: 11px;
  font-weight: 900;
}

.sponsor-grid article[data-published="true"] span {
  color: #25744d;
  background: #dcfff4;
}

.contact-band {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  overflow: hidden;
  color: var(--cih-heading);
  background:
    linear-gradient(135deg, rgba(102, 204, 255, 0.14), transparent 42%),
    linear-gradient(180deg, #ffffff 0%, #f7f4fb 100%);
}

.contact-band::before {
  content: "";
  position: absolute;
  inset: 0;
  border-top: 1px solid rgba(83, 35, 127, 0.12);
  border-bottom: 1px solid rgba(83, 35, 127, 0.12);
  pointer-events: none;
}

.contact-band > div,
.enquiry-form {
  position: relative;
  z-index: 1;
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.contact-band h2 {
  margin: 0 0 12px;
  color: var(--cih-heading);
  font-size: clamp(28px, 4vw, 44px);
}

.contact-band p {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.contact-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  max-width: 760px;
  margin-top: 20px;
}

.contact-detail-grid article {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(83, 35, 127, 0.14);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.74);
}

.contact-detail-grid article:last-child {
  grid-column: 1 / -1;
}

.contact-detail-grid span {
  color: var(--cih-magenta);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.contact-detail-grid strong {
  color: var(--cih-heading);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.contact-detail-grid a {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: rgba(102, 204, 255, 0.75);
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}

.contact-detail-grid a:hover {
  color: var(--cih-purple);
  text-decoration-color: var(--cih-magenta);
}

.site-footer {
  display: flex;
  justify-content: center;
  padding: 22px clamp(18px, 4vw, 56px);
  border-top: 1px solid rgba(83, 35, 127, 0.12);
  background: #ffffff;
  color: var(--muted);
  text-align: center;
}

.site-footer small {
  font-size: 12px;
  line-height: 1.5;
}

.enquiry-form {
  display: grid;
  gap: 12px;
  width: min(100%, 460px);
  padding: 18px;
  border: 1px solid rgba(83, 35, 127, 0.16);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(34, 17, 68, 0.12);
}

.enquiry-form label {
  color: var(--cih-heading);
}

.enquiry-form textarea {
  resize: vertical;
}

.contact-band .button.secondary {
  color: var(--cih-heading);
  border-color: rgba(83, 35, 127, 0.2);
  background: #ffffff;
}

.revealable {
  opacity: 0.98;
  transform: translateY(8px);
  transition: opacity 360ms ease, transform 360ms ease, box-shadow 360ms ease;
}

.revealable.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes liftIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes stageDrift {
  from {
    transform: scale(1.02) translate3d(0, 0, 0);
  }
  to {
    transform: scale(1.07) translate3d(-1.4%, -0.8%, 0);
  }
}

@keyframes awardBeam {
  from {
    transform: translateX(-18%) rotate(-2deg);
  }
  to {
    transform: translateX(12%) rotate(2deg);
  }
}

@keyframes awardFloat {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-6px);
  }
}

@keyframes meterSweep {
  from {
    transform: scaleX(0.3);
  }
  to {
    transform: scaleX(1);
  }
}

@keyframes progressSheen {
  0%, 28% {
    transform: translateX(-110%);
  }
  74%, 100% {
    transform: translateX(110%);
  }
}

@keyframes panelSweep {
  0%, 38% {
    left: -35%;
  }
  72%, 100% {
    left: 108%;
  }
}

@keyframes orbitPulse {
  0%, 100% {
    opacity: 0.5;
    transform: scale(0.92);
  }
  50% {
    opacity: 1;
    transform: scale(1.08);
  }
}

@media (max-width: 1180px) {
  .site-header {
    grid-template-columns: 1fr auto auto;
  }

  .menu-toggle {
    display: block;
  }

  .main-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    display: none;
    padding: 12px 18px 18px;
    background: #2b1a4b;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .main-nav.open {
    display: grid;
  }

  .nav-group {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 40px;
  }

  .main-nav a {
    padding: 14px 10px;
  }

  .nav-disclosure {
    width: 40px;
    height: 46px;
    justify-self: end;
  }

  .submenu,
  .nav-group:hover .submenu,
  .nav-group:focus-within .submenu {
    position: static;
    grid-column: 1 / -1;
    display: none;
    min-width: 0;
    margin: -2px 0 6px 12px;
    padding: 6px;
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: none;
    opacity: 1;
    transform: none;
    visibility: visible;
    pointer-events: auto;
  }

  .nav-group.open .submenu {
    display: grid;
  }

  .applicant-portal-layout,
  .applicant-record-browser {
    grid-template-columns: 1fr;
  }

  .applicant-portal-menu {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .submenu a,
  .submenu a.active {
    color: rgba(255, 255, 255, 0.86);
    background: transparent;
  }

  .submenu a:hover {
    color: var(--paper);
    background: rgba(255, 255, 255, 0.1);
  }

  .submenu a.active {
    color: var(--paper);
    background: transparent;
    box-shadow: none;
  }

  .hero-inner,
  .category-content,
  .section-heading,
  .aims-panel,
  .score-benchmark,
  .application-notes,
  .dashboard,
  .app-workspace,
  .operations-grid,
  .judging-panel-block,
  .otp-panel,
  .contact-panels,
  .media-feature {
    grid-template-columns: 1fr;
  }

  .deadline-panel {
    max-width: 520px;
  }

  .signal-strip,
  .announcement-board,
  .feature-grid,
  .category-rules,
  .sponsor-grid,
  .pillar-grid,
  .jury-grid,
  .terms-grid,
  .media-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .payment-methods {
    grid-template-columns: repeat(2, 1fr);
  }

  .backend-login-grid {
    grid-template-columns: 1fr;
  }

  .assigned-entry-list,
  .admin-accounts {
    grid-template-columns: repeat(2, 1fr);
  }

  .dashboard aside {
    display: none;
  }

  .tier-panel,
  .requirements-panel,
  .document-download-panel {
    grid-template-columns: 1fr;
  }

  .tier-list,
  .requirements-grid,
  .document-download-grid,
  .application-note-grid,
  .portal-scope-grid,
  .portal-task-strip,
  .payment-page-details,
  .admin-command-summary,
  .admin-workbench-nav,
  .admin-kpis,
  .admin-cms-stats,
  .admin-export-actions,
  .admin-cms-record,
  .admin-cms-actions,
  .cms-library-head,
  .cms-library-controls,
  .cms-copy-list article,
  .cms-copy-fields,
  .cms-language-workbench,
  .cms-section-copy-list article,
  .cms-section-collection summary,
  .cms-section-layout,
  .cms-section-judge-item,
  .cms-section-judge-fields,
  .admin-table-toolbar,
  .admin-bulk-bar,
  .admin-table-pagination,
  .admin-table-rows > div,
  .admin-conflict-strip,
  .admin-assignment-board,
  .admin-judge-pool,
  .cms-section-object-item,
  .cms-image-grid,
  .cms-collection-grid,
  .admin-review-detail dl,
  .admin-results-grid dl,
  .viewer-tier-list,
  .viewer-weight-summary,
  .score-band-list {
    grid-template-columns: repeat(2, 1fr);
  }

  .terms-detail-grid {
    grid-template-columns: 1fr;
  }

  .timeline,
  .nomination-fee-panel {
    grid-template-columns: 1fr;
  }

  .cms-section-nav {
    position: static;
  }

  .media-feature dl {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1320px) and (min-width: 961px) {
  .hero-inner {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
    gap: 42px;
    padding: 32px 0 30px;
  }

  .award-logo {
    width: min(240px, 44vw);
    max-height: none;
    margin-bottom: 16px;
  }

  .hero-copy h1 {
    max-width: 680px;
    font-size: 48px;
  }

  .hero-lede {
    max-width: 600px;
    margin-top: 18px;
    font-size: 19px;
    line-height: 1.38;
  }

  .hero-actions {
    margin-top: 24px;
  }

  .deadline-panel {
    padding: 22px;
  }

  .countdown span {
    min-height: 70px;
  }

  .countdown strong {
    font-size: 29px;
  }

  .fee-list div {
    padding: 10px 0;
  }
}

@media (max-width: 1320px) and (min-width: 1181px) {
  .site-header {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px 16px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .brand {
    grid-column: 1;
  }

  .language-switcher {
    grid-column: 2;
  }

  .main-nav {
    grid-column: 1 / -1;
    justify-content: flex-start;
    width: 100%;
  }
}

@media (max-width: 640px) {
  html {
    scroll-padding-top: 154px;
  }

  section,
  [id] {
    scroll-margin-top: 154px;
  }

  .site-header {
    grid-template-columns: 1fr auto;
    gap: 12px;
    padding: 10px 18px 12px;
  }

  .language-switcher {
    grid-column: 1 / -1;
    width: 100%;
  }

  .brand {
    gap: 12px;
  }

  .brand img {
    width: 44px;
    height: 54px;
  }

  .brand strong {
    font-size: clamp(13px, 3.4vw, 16px);
    white-space: normal;
  }

  .brand small {
    display: none;
  }

  .main-nav {
    max-height: calc(100vh - 130px);
    overflow-y: auto;
  }

  .main-nav.open {
    animation: liftIn 180ms ease both;
  }

  .hero-section {
    min-height: auto;
  }

  .hero-inner {
    width: min(100% - 32px, 1180px);
    gap: 18px;
    padding: 24px 0 22px;
  }

  .hero-copy h1 {
    font-size: 31px;
    line-height: 1.02;
  }

  .award-logo {
    width: min(190px, 56vw);
    max-height: none;
    margin-bottom: 14px;
  }

  .hero-lede {
    margin-top: 14px;
    font-size: 15px;
    line-height: 1.42;
  }

  .hero-actions {
    margin-top: 18px;
  }

  .hero-actions .button,
  .form-actions .button,
  .account-actions .button,
  .signed-in-actions .button,
  .otp-actions .button,
  .payment-page-actions .button,
  .contact-actions .button {
    width: 100%;
  }

  .form-actions [data-save-application] {
    margin-left: 0;
  }

  .applicant-portal-menu,
  .signed-in-panel dl,
  .applicant-detail-dl {
    grid-template-columns: 1fr;
  }

  .applicant-detail-head {
    display: grid;
  }

  .button {
    min-height: 42px;
    padding: 0 15px;
    font-size: 13px;
  }

  .deadline-panel {
    gap: 13px;
    padding: 14px;
  }

  .countdown span {
    min-height: 58px;
  }

  .countdown strong {
    font-size: 22px;
  }

  .panel-label,
  .countdown small,
  .fee-list dt {
    font-size: 10px;
  }

  .fee-list div {
    padding: 8px 0;
  }

  .fee-list dd {
    font-size: 17px;
  }

  .timeline {
    gap: 12px;
  }

  .timeline::before {
    left: 42px;
  }

  .timeline article {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 8px 14px;
    min-height: 0;
    padding: 18px;
  }

  .timeline-icon {
    width: 42px;
    height: 42px;
  }

  .timeline time,
  .timeline h3 {
    grid-column: 2;
  }

  .timeline h3 {
    grid-row: 2;
    margin-top: 0;
  }

  .timeline p {
    grid-column: 1 / -1;
    grid-row: 3;
  }

  .nomination-fee-panel {
    padding: 16px;
  }

  .nomination-fee-grid {
    grid-template-columns: 1fr;
  }

  .entry-kit-download {
    align-items: stretch;
  }

  .signal-strip,
  .announcement-board,
  .feature-grid,
  .category-rules,
  .aims-panel ul,
  .timeline,
  .application-note-grid,
  .sponsor-grid,
  .dashboard-top,
  .pillar-grid,
  .tier-list,
  .requirements-grid,
  .document-download-grid,
  .score-band-list,
  .faq-list,
  .form-grid,
  .upload-grid,
  .signature-grid,
  .payment-methods,
  .payment-page-head,
  .payment-page-details,
  .auth-mode,
  .backend-login,
  .backend-role-switch,
  .backend-login-grid,
  .portal-secure-head,
  .portal-scope-grid,
  .portal-task-strip,
  .assigned-entry-list,
  .admin-accounts,
  .admin-app-switcher,
  .admin-command-summary,
  .admin-workbench-nav,
  .admin-kpis,
  .admin-review-detail dl,
  .admin-payment-grid,
  .admin-assignment-grid,
  .admin-table-toolbar,
  .admin-bulk-bar,
  .admin-table-pagination,
  .admin-table-rows > div,
  .admin-conflict-strip,
  .admin-assignment-board,
  .admin-judge-pool,
  .admin-finalist-grid,
  .admin-results-grid,
  .admin-results-grid dl,
  .admin-cms-toolbar,
  .admin-cms-stats,
  .admin-cms-record,
  .admin-cms-actions,
  .admin-cms-grid,
  .cms-library-head,
  .cms-library-controls,
  .cms-copy-list article,
  .cms-copy-fields,
  .cms-language-workbench,
  .cms-language-lanes,
  .cms-section-copy-list article,
  .cms-section-collection summary,
  .cms-section-layout,
  .cms-section-judge-item,
  .cms-section-judge-fields,
  .cms-section-object-item,
  .cms-image-grid,
  .cms-collection-grid,
  .admin-enquiry-grid,
  .admin-users-grid dl,
  .admin-export-actions,
  .admin-audit li,
  .judge-meta,
  .jury-grid,
  .terms-grid,
  .terms-detail-grid,
  .media-grid {
    grid-template-columns: 1fr;
  }

  .media-controls {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  .media-feature {
    padding: 14px;
  }

  .media-orbit,
  .media-feature-asset {
    width: 82px;
  }

  .media-feature strong {
    font-size: 20px;
  }

  .media-feature dl {
    grid-template-columns: 1fr;
  }

  .cms-section-editor-head,
  .cms-section-actions,
  .cms-section-item-controls,
  .cms-section-collection summary {
    align-items: stretch;
    flex-direction: column;
  }

  .sponsor-grid article {
    grid-template-columns: 58px minmax(0, 1fr);
  }

  .sponsor-mark,
  .sponsor-logo {
    width: 52px;
    height: 52px;
  }

  .sponsor-mark {
    font-size: 15px;
  }

  .backend-login-mark {
    width: 50px;
    height: 50px;
  }

  .portal-preview {
    padding: 16px;
  }

  .portal-lock-icon {
    width: 46px;
    height: 46px;
  }

  .backend-toolbar {
    display: grid;
  }

  .submission-detail-list article,
  .materials-guidance article,
  .weighting-heading,
  .weighting-heading dl div,
  .viewer-head,
  .video-reviewer,
  .viewer-checklist,
  .viewer-tier-list,
  .viewer-weight-summary,
  .review-score-list li {
    grid-template-columns: 1fr;
  }

  .score-package-panel {
    grid-template-columns: 1fr;
  }

  .pdf-toolbar {
    grid-template-columns: 1fr;
  }

  .pdf-sheet {
    min-height: 190px;
    padding: 18px;
  }

  .pdf-sheet h4 {
    font-size: 23px;
  }

  .pdf-page-mark {
    position: static;
    margin-top: 14px;
    font-size: 28px;
  }

  .review-score-list li span {
    text-align: left;
  }

  .pillar-card {
    min-height: auto;
  }

  .signal-strip div {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .category-tabs,
  .portal-controls {
    display: grid;
    grid-template-columns: 1fr;
  }

  .category-tabs button,
  .portal-controls button {
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .work-row,
  .category-item,
  .score-row,
  .score-lock-panel,
  .judge-conflict-panel,
  .admin-review-head,
  .admin-table div,
  .admin-results-grid article {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .contact-band {
    display: grid;
  }

  .contact-detail-grid {
    grid-template-columns: 1fr;
  }

  .enquiry-form {
    width: 100%;
    padding: 14px;
  }

  .contact-actions {
    justify-content: flex-start;
  }

  .section-heading {
    gap: 12px;
    margin-bottom: 22px;
  }

  .section-heading h1,
  .section-heading h2 {
    font-size: 30px;
    line-height: 1.06;
  }

  .section-heading p {
    font-size: 15px;
    line-height: 1.55;
  }

  .announcement-controls {
    display: flex;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: thin;
  }

  .announcement-controls button {
    flex: 0 0 auto;
    min-width: 118px;
    padding: 0 14px;
    white-space: nowrap;
  }

  .category-shell,
  .portal-shell,
  .backend-login,
  .nomination-form,
  .application-summary,
  .app-rail,
  .judge-console,
  .admin-console {
    box-shadow: 0 16px 44px rgba(34, 17, 68, 0.12);
  }

  .nomination-form input,
  .nomination-form select,
  .enquiry-form input,
  .enquiry-form select,
  .enquiry-form textarea,
  .backend-login input {
    font-size: 16px;
  }

  .segmented-control label,
  .payment-methods label,
  .check-row,
  .entry-list label {
    align-items: flex-start;
  }
}

.toast-stack {
  position: fixed;
  z-index: 90;
  right: clamp(14px, 2vw, 28px);
  bottom: clamp(14px, 2vw, 28px);
  display: grid;
  gap: 10px;
  width: min(360px, calc(100vw - 28px));
  pointer-events: none;
}

.toast-stack article {
  display: grid;
  gap: 5px;
  padding: 13px 14px;
  border: 1px solid rgba(83, 35, 127, 0.18);
  border-left: 4px solid var(--award-cyan);
  border-radius: 6px;
  color: var(--cih-heading);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 18px 44px rgba(34, 17, 68, 0.18);
  pointer-events: auto;
  animation: liftIn 180ms ease both;
}

.toast-stack article[data-tone="success"] {
  border-left-color: #1f9f72;
}

.toast-stack article[data-tone="alert"] {
  border-left-color: var(--cih-magenta);
}

.toast-stack strong {
  font-size: 13px;
  font-weight: 900;
}

.toast-stack p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.toast-stack button {
  justify-self: start;
  min-height: 30px;
  padding: 0;
  border: 0;
  color: var(--cih-heading);
  background: transparent;
  font-size: 12px;
  font-weight: 900;
  text-decoration: underline;
  cursor: pointer;
}

.status-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(34, 17, 68, 0.36);
  backdrop-filter: blur(3px);
}

.status-modal[hidden] {
  display: none;
}

.status-modal article {
  display: grid;
  gap: 16px;
  width: min(560px, calc(100vw - 40px));
  padding: clamp(28px, 4vw, 42px);
  border: 1px solid rgba(83, 35, 127, 0.2);
  border-top: 7px solid #1f9f72;
  border-radius: 8px;
  color: var(--cih-heading);
  background: #ffffff;
  box-shadow: 0 30px 90px rgba(34, 17, 68, 0.34);
  animation: liftIn 180ms ease both;
}

.status-modal article[data-tone="alert"] {
  border-top-color: var(--cih-magenta);
}

.status-modal strong {
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 950;
  line-height: 1.1;
}

.status-modal p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.5vw, 19px);
  font-weight: 850;
  line-height: 1.55;
}

.status-modal .button {
  justify-self: start;
}

@media (max-width: 900px) {
  .admin-evidence-preview dl,
  .admin-score-breakdown article,
  .admin-score-breakdown ul,
  .judge-entry-evidence,
  .admin-audit li {
    grid-template-columns: 1fr;
  }

  .judge-entry-evidence a {
    justify-self: start;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }

  .revealable {
    opacity: 1;
    transform: none;
  }
}
