/**
 * جایزه نوآوری تراز — Poster Design System
 *
 * Palette: deep navy · oil blue · cyan glow · cream
 * Matched to the award poster / taraz-balance visual
 */

:root {
    /* Poster navy surfaces */
    --navy:           #061018;
    --navy-light:     #0a1828;
    --navy-mid:       #0f2236;
    --navy-deep:      #040c14;

    /* Oil / petrol blues */
    --oil:            #1a3348;
    --oil-light:      #2a4a62;
    --oil-muted:      #3d5f78;

    /* Poster glow accent (cyan) */
    --cyan:           #28b8d8;
    --cyan-bright:    #3dceec;
    --cyan-soft:      #1a8fa8;
    --cyan-glow:      rgba(40, 184, 216, 0.14);
    --cyan-dim:       rgba(40, 184, 216, 0.08);

    /* Text — warm cream from poster */
    --cream:          #f4f0e8;
    --cream-soft:     rgba(244, 240, 232, 0.88);
    --cream-muted:    rgba(244, 240, 232, 0.55);

    /* Secondary blue-gray + prize gold */
    --slate:          #5a7288;
    --slate-light:    #7a94a8;
    --poster-gold:    #c9a84c;

    /* Semantic aliases (used across components) */
    --ink:            var(--navy);
    --ink-raised:     var(--navy-light);
    --ink-section:    var(--navy-mid);
    --ink-deep:       var(--navy-deep);
    --parchment:      var(--cream);
    --parchment-soft: var(--cream-soft);
    --parchment-muted: var(--cream-muted);
    --petrol:         var(--oil);

    /* Accent tokens (bronze names kept for compatibility → cyan) */
    --bronze:         var(--cyan-soft);
    --bronze-light:   var(--cyan);
    --bronze-pale:    var(--cyan-glow);
    --gold:           var(--poster-gold);
    --navy-footer:    var(--navy-deep);

    /* Header — dark navy band like poster */
    --header-bg:      var(--navy-light);
    --header-text:    var(--cream);
    --header-muted:   rgba(244, 240, 232, 0.62);
    --header-border:  rgba(40, 184, 216, 0.16);

    /* UI borders */
    --border:         rgba(244, 240, 232, 0.07);
    --border-strong:  rgba(244, 240, 232, 0.12);
    --border-bronze:  rgba(40, 184, 216, 0.28);
    --border-accent:  var(--border-bronze);

    --header-h:       4.25rem;
    --max-w:          72rem;
    --max-w-narrow:   44rem;
    --radius:         20px;

    /* Light surfaces (homepage) */
    --surface:        #ffffff;
    --surface-alt:    #f0f3f6;
    --text-dark:      #061018;
    --text-body:      #2a4054;
    --text-muted-dk:  #5a7288;

    /* ── Typography scale (Pelak / Persian — rem-based) ── */
    --font-sans:      'Pelak', Tahoma, Arial, sans-serif;

    --text-xs:        0.75rem;     /* 12px — labels, captions */
    --text-sm:        0.875rem;    /* 14px — secondary UI, meta */
    --text-base:      1rem;        /* 16px — body */
    --text-md:        1.125rem;    /* 18px — lead, large body */
    --text-lg:        1.25rem;     /* 20px — h3, card titles */
    --text-xl:        1.5rem;      /* 24px — h2 mobile */
    --text-2xl:       1.875rem;    /* 30px — h2 desktop */
    --text-3xl:       2.25rem;     /* 36px — h1 mobile */
    --text-4xl:       3rem;        /* 48px — h1 desktop */

    --leading-none:   1.1;
    --leading-tight:  1.25;
    --leading-snug:   1.375;
    --leading-normal: 1.6;
    --leading-relaxed: 1.7;

    --tracking-tight:  -0.02em;
    --tracking-normal: 0;
    --tracking-wide:   0.04em;
    --tracking-wider:  0.08em;
    --tracking-widest: 0.12em;
}

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

/* 20px radius on interactive surfaces & cards */
.btn-header-cta,
.header-menu-btn,
.site-menu-close,
.tag,
.prize-chip,
.prize-rank,
.track-card,
.accordion-wrap,
.support-item,
.partner-cell,
.footer-social-link,
.form-input,
.form-select,
.form-textarea,
.alert-error,
.alert-success,
.timeline-body,
.member-card,
.stat-card,
.newsletter-flash {
    border-radius: var(--radius);
}

html {
    scroll-behavior: smooth;
    font-size: 100%; /* 16px root — do not scale down for Pelak */
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: 400;
    line-height: var(--leading-normal);
    color: var(--parchment);
    background: var(--ink);
    background-image:
        radial-gradient(ellipse 80% 50% at 50% -10%, rgba(40, 184, 216, 0.07), transparent 55%),
        radial-gradient(ellipse 50% 40% at 100% 100%, rgba(26, 51, 72, 0.35), transparent),
        radial-gradient(ellipse 40% 30% at 0% 80%, rgba(15, 34, 54, 0.25), transparent);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
.hidden { display: none !important; }

/* Typography utilities */
.text-bright       { color: var(--parchment); }
.text-body         { color: var(--parchment-soft); }
.text-muted        { color: var(--parchment-muted); }
.text-accent       { color: var(--cyan); }
.text-accent-alt   { color: var(--oil-muted); }
.text-gold-bright  { color: var(--poster-gold); }
.text-cyan-bright  { color: var(--cyan-bright); }

.section-eyebrow {
    display: block;
    margin-bottom: 0.75rem;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--bronze);
}

.section-title {
    margin: 0 0 1rem;
    font-size: clamp(var(--text-xl), 2.5vw, var(--text-2xl));
    font-weight: 600;
    line-height: var(--leading-tight);
    color: var(--parchment);
    letter-spacing: var(--tracking-tight);
}

.section-head--center .section-title::after {
    content: '';
    display: block;
    width: 2.75rem;
    height: 1px;
    margin: 1.125rem auto 0;
    background: var(--bronze);
    opacity: 0.65;
}

.section-desc {
    margin: 0 auto;
    max-width: 36rem;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--parchment-muted);
}

.section-head { margin-bottom: 3.5rem; }
.section-head--center { text-align: center; }

.section {
    padding: 5.5rem 1.25rem;
    border-top: 1px solid var(--border);
}

.section-inner { max-width: var(--max-w); margin: 0 auto; }
.section-inner--narrow { max-width: var(--max-w-narrow); }
.section--alt { background: var(--ink-section); }

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    height: var(--header-h);
    background: var(--header-bg);
    border-bottom: 1px solid var(--header-border);
    overflow: hidden;
}

.header-inner {
    max-width: var(--max-w);
    height: 100%;
    margin: 0 auto;
    padding: 0 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: nowrap;
}

.header-brand { flex-shrink: 0; }

.header-logo { height: 2.125rem; width: auto; max-width: 10.5rem; object-fit: contain; }

.header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

.header-nav {
    display: none;
    align-items: center;
    gap: 1.5rem;
    margin-right: auto;
    margin-left: 1rem;
    font-size: var(--text-base);
    font-weight: 500;
    line-height: var(--leading-snug);
    color: var(--header-muted);
    white-space: nowrap;
}

.header-nav a {
    color: var(--header-muted);
    transition: color 0.2s;
}

.header-nav a:hover { color: var(--header-text); }

.btn-header-cta {
    display: none;
    padding: 0.5rem 1.125rem;
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--navy-deep);
    background: var(--cyan);
    border: 1px solid var(--cyan);
    border-radius: var(--radius);
    transition: background 0.2s, border-color 0.2s;
}

.btn-header-cta:hover {
    background: var(--cyan-bright);
    border-color: var(--cyan-bright);
}

.btn-header-cta--block {
    display: inline-block;
    text-align: center;
    margin-top: 0.5rem;
    color: var(--navy-deep);
}

.header-menu-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    background: none;
    border: 1px solid var(--header-border);
    border-radius: var(--radius);
    cursor: pointer;
    flex-shrink: 0;
}

.header-menu-btn span {
    display: block;
    width: 16px;
    height: 1.5px;
    margin: 0 auto;
    background: var(--header-text);
    opacity: 0.75;
}

/* Full-site menu overlay */
.site-menu-panel {
    position: fixed;
    inset: 0;
    z-index: 300;
}

.site-menu-panel[hidden] { display: none !important; }

.site-menu-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(4, 12, 20, 0.82);
    backdrop-filter: blur(4px);
}

.site-menu-drawer {
    position: absolute;
    top: 0;
    right: 0;
    width: min(100%, 36rem);
    height: 100%;
    overflow-y: auto;
    background: var(--navy-light);
    border-left: 1px solid var(--header-border);
    padding: 1.25rem 1.5rem 2rem;
    box-shadow: -8px 0 40px rgba(0, 0, 0, 0.35);
}

.site-menu-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    margin-bottom: 1.25rem;
    margin-right: auto;
    padding: 0;
    font-size: 1.125rem;
    color: var(--header-text);
    background: none;
    border: 1px solid var(--header-border);
    cursor: pointer;
}

.site-menu-grid {
    display: grid;
    gap: 1.75rem;
}

@media (min-width: 640px) {
    .site-menu-grid { grid-template-columns: 1fr 1fr; }
}

.site-menu-col-title {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--header-text);
}

.site-menu-col-title:hover { color: var(--cyan); }

.site-menu-col-desc {
    margin: 0 0 0.75rem;
    font-size: 0.75rem;
    line-height: 1.6;
    color: var(--header-muted);
}

.site-menu-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-menu-links li { margin-bottom: 0.35rem; }

.site-menu-links a {
    font-size: 0.8125rem;
    color: var(--header-muted);
    transition: color 0.2s;
}

.site-menu-links a:hover { color: var(--cyan); }

.site-menu-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--header-border);
}

body.menu-open { overflow: hidden; }

main { padding-top: var(--header-h); }

@media (min-width: 900px) {
    .header-nav { display: flex; }
    .btn-header-cta { display: inline-flex; align-items: center; }
}

@media (max-width: 899px) {
    .header-nav { display: none !important; }
    .btn-header-cta { display: none; }
}

/* ── Hero ───────────────────────────────────────────────────────────────── */
.hero {
    min-height: calc(92vh - var(--header-h));
    display: flex;
    align-items: center;
    padding: 3rem 1.25rem 4rem;
    overflow: hidden;
}

.hero-shell {
    width: 100%;
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    gap: 2.5rem;
    align-items: center;
}

@media (min-width: 900px) {
    .hero-shell {
        grid-template-columns: 1fr 1.15fr;
        gap: 3rem;
    }
}

.hero-content {
    text-align: center;
}

@media (min-width: 900px) {
    .hero-content { text-align: right; }
}

.hero-visual {
    position: relative;
    order: -1;
}

@media (min-width: 900px) {
    .hero-visual { order: 0; }
}

.hero-image-frame {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid rgba(40, 184, 216, 0.2);
    background: #000;
    box-shadow:
        0 0 60px rgba(40, 184, 216, 0.15),
        0 24px 64px rgba(0, 0, 0, 0.55);
}

.hero-image-frame::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 40%, rgba(40, 184, 216, 0.12), transparent 65%);
    pointer-events: none;
    z-index: 1;
}

.hero-balance-img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: cover;
    filter: drop-shadow(0 0 24px rgba(40, 184, 216, 0.18));
}

.hero-title {
    margin: 0 0 1rem;
    font-size: clamp(1.875rem, 4.5vw, 2.75rem);
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: -0.02em;
}

.hero-subtitle {
    margin: 0 0 1.5rem;
    font-size: clamp(1.0625rem, 2vw, 1.25rem);
    font-weight: 300;
    color: var(--parchment-soft);
}

.hero-lead { margin: 0 0 1.25rem; font-size: 0.9375rem; color: var(--parchment-muted); line-height: 1.85; }

.focus-areas {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.35rem 0.5rem;
    margin-bottom: 1.75rem;
    font-size: 0.8125rem;
    color: var(--parchment-muted);
}

@media (min-width: 900px) {
    .focus-areas { justify-content: flex-start; }
}

.focus-areas .sep { opacity: 0.22; color: var(--bronze); }
.hero-note { margin: 0 0 2rem; font-size: 0.875rem; color: var(--parchment-muted); line-height: 1.8; }

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 1.75rem;
}

@media (min-width: 900px) {
    .hero-actions { justify-content: flex-start; }
}

.deadline-box {
    display: inline-block;
    padding: 0.625rem 1.25rem;
    font-size: 0.75rem;
    letter-spacing: 0.02em;
    color: var(--parchment-soft);
    border: 1px solid var(--border-bronze);
    background: var(--bronze-pale);
    border-radius: var(--radius);
}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn-primary, .btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 9rem;
    padding: 0.8125rem 1.75rem;
    font-family: inherit;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: var(--leading-snug);
    cursor: pointer;
    border: 1px solid transparent;
    border-radius: var(--radius);
    transition: all 0.2s ease;
}

.btn-primary {
    color: var(--navy-deep);
    background: var(--cyan);
    border-color: var(--cyan);
}

.btn-primary:hover {
    background: var(--cyan-bright);
    border-color: var(--cyan-bright);
}

.btn-secondary {
    color: var(--parchment-soft);
    background: transparent;
    border-color: var(--border-strong);
}

.btn-secondary:hover {
    border-color: var(--border-bronze);
    color: var(--parchment);
}

/* ── Cards ──────────────────────────────────────────────────────────────── */
.card-grid { display: grid; gap: 1.25rem; }

@media (min-width: 768px) {
    .card-grid--2 { grid-template-columns: 1fr 1fr; }
    .card-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

.panel {
    background: linear-gradient(165deg, var(--navy-light) 0%, rgba(6, 16, 24, 0.92) 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    transition: border-color 0.25s ease;
}

.panel:hover { border-color: var(--border-bronze); }
.panel-pad { padding: 2rem 1.75rem; }

@media (min-width: 768px) { .panel-pad { padding: 2.25rem 2rem; } }

.card-label {
    display: inline-block;
    margin-bottom: 1rem;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-wider);
    color: var(--bronze);
}

.card-title {
    margin: 0 0 0.75rem;
    font-size: var(--text-lg);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--parchment);
}

.card-text {
    margin: 0 0 1.5rem;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--parchment-muted);
}

.tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.5rem; }

.tag {
    padding: 0.3rem 0.7rem;
    font-size: var(--text-sm);
    line-height: var(--leading-snug);
    color: var(--parchment-muted);
    background: rgba(236, 232, 223, 0.03);
    border: 1px solid var(--border);
}

.icon-line {
    display: inline-flex;
    width: 1.25rem;
    color: var(--bronze);
    font-size: 0.8125rem;
    opacity: 0.8;
    margin-left: 0.35rem;
}

.icon-card {
    margin-bottom: 1.25rem;
    font-size: 1rem;
    color: var(--bronze);
    opacity: 0.65;
}

/* ── Prizes ─────────────────────────────────────────────────────────────── */
.prize-strip { padding-top: 1.25rem; border-top: 1px solid var(--border); }
.prize-strip-label { margin: 0 0 0.75rem; font-size: 0.6875rem; letter-spacing: 0.1em; color: var(--parchment-muted); }
.prize-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }

.prize-chip {
    padding: 0.4rem 0.75rem;
    font-size: 0.8125rem;
    color: var(--parchment-soft);
    background: var(--bronze-pale);
    border: 1px solid var(--border-bronze);
}

.prize-list { list-style: none; margin: 0; padding: 0; }

.prize-list li {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.875rem;
    color: var(--parchment-muted);
}

.prize-list li:last-child { border-bottom: none; }

.prize-rank {
    flex-shrink: 0;
    width: 1.625rem; height: 1.625rem;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.6875rem;
    color: var(--slate-light);
    border: 1px solid rgba(110, 120, 130, 0.35);
}

.prize-rank--gold {
    color: var(--poster-gold);
    border-color: rgba(201, 168, 76, 0.45);
    background: rgba(201, 168, 76, 0.1);
}

/* ── Accordion ──────────────────────────────────────────────────────────── */
.accordion-wrap {
    border: 1px solid var(--border);
    background: rgba(6, 16, 24, 0.65);
}

.accordion-item { border-bottom: 1px solid var(--border); }
.accordion-item:last-child { border-bottom: none; }

.accordion-trigger {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    font-family: inherit;
    font-size: 0.9375rem;
    text-align: right;
    color: var(--parchment);
    background: none;
    border: none;
    cursor: pointer;
    transition: background 0.2s;
}

.accordion-trigger:hover { background: var(--cyan-dim); }
.accordion-trigger[aria-expanded="true"] { background: rgba(40, 184, 216, 0.1); }
.accordion-trigger[aria-expanded="true"] .accordion-chevron { transform: rotate(180deg); }

.accordion-chevron {
    flex-shrink: 0;
    width: 1rem; height: 1rem;
    margin-right: auto;
    color: var(--parchment-muted);
    transition: transform 0.25s;
}

.accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.accordion-content.open { max-height: 520px; }

.accordion-body { margin: 0; padding: 0 1.5rem 1.25rem 3.25rem; list-style: none; }

.accordion-body li {
    position: relative;
    padding: 0.35rem 0 0.35rem 1rem;
    font-size: 0.875rem;
    line-height: 1.75;
    color: var(--parchment-muted);
}

.accordion-body li::before {
    content: '';
    position: absolute;
    right: 0; top: 0.85rem;
    width: 3px; height: 3px;
    border-radius: 50%;
    background: var(--bronze);
    opacity: 0.55;
}

.accordion-link {
    margin: 0;
    padding: 0 1.5rem 1.25rem 3.25rem;
    font-size: 0.8125rem;
}

.accordion-link a { color: var(--bronze-light); }

/* ── Support ────────────────────────────────────────────────────────────── */
.support-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
}

@media (min-width: 768px) {
    .support-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
}

.support-item {
    padding: 1.25rem 1rem;
    text-align: center;
    font-size: 0.8125rem;
    color: var(--parchment-muted);
    background: rgba(6, 16, 24, 0.7);
    border: 1px solid var(--border);
    transition: border-color 0.2s, color 0.2s;
}

.support-item i {
    display: block;
    margin-bottom: 0.625rem;
    font-size: 0.9375rem;
    color: var(--bronze);
    opacity: 0.6;
}

.support-item:hover {
    border-color: var(--border-bronze);
    color: var(--parchment-soft);
}

/* ── Committees ─────────────────────────────────────────────────────────── */
.member-grid { display: grid; gap: 0.875rem; }

@media (min-width: 640px) { .member-grid { grid-template-columns: 1fr 1fr; } }

.member-card {
    padding: 1.25rem 1.5rem;
    border-right: 2px solid var(--bronze);
    background: rgba(6, 16, 24, 0.65);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    border-left: 1px solid var(--border);
}

.member-name {
    margin: 0 0 0.25rem;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--parchment);
}

.member-role {
    margin: 0 0 0.35rem;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--bronze-light);
}

.member-org {
    margin: 0;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

/* ── Timeline ───────────────────────────────────────────────────────────── */
.timeline { position: relative; padding-right: 2.75rem; }

.timeline::before {
    content: '';
    position: absolute;
    top: 0.5rem; bottom: 0.5rem;
    right: 0.6875rem;
    width: 1px;
    background: linear-gradient(180deg, var(--cyan-soft), rgba(40, 184, 216, 0.06));
    opacity: 0.45;
}

.timeline-step { position: relative; padding-bottom: 2rem; }
.timeline-step:last-child { padding-bottom: 0; }

.timeline-dot {
    position: absolute;
    right: -2.75rem; top: 0.15rem;
    width: 1.375rem; height: 1.375rem;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.5rem;
    color: var(--bronze-light);
    background: var(--ink);
    border: 1px solid var(--border-bronze);
    border-radius: 50%;
    z-index: 1;
}

.timeline-body {
    padding: 0.875rem 1.125rem;
    background: rgba(6, 16, 24, 0.55);
    border: 1px solid var(--border);
}

.timeline-label {
    display: block;
    margin-bottom: 0.25rem;
    font-size: 0.6875rem;
    letter-spacing: 0.08em;
    color: var(--bronze);
}

.timeline-text { margin: 0; font-size: 0.875rem; font-weight: 500; color: var(--parchment); }

/* ── CTA ────────────────────────────────────────────────────────────────── */
.cta-band { text-align: center; padding: 5rem 1.25rem; }

.cta-band p {
    max-width: 32rem;
    margin: 0 auto 2rem;
    font-size: 1rem;
    line-height: 1.85;
    color: var(--parchment-muted);
}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer {
    background: var(--ink-deep);
    border-top: 1px solid var(--border);
}

.footer-inner { max-width: var(--max-w); margin: 0 auto; padding: 3.5rem 1.25rem 2rem; }

.footer-grid { display: grid; gap: 2.5rem; margin-bottom: 3rem; }

@media (min-width: 768px) { .footer-grid { grid-template-columns: 1.2fr 1fr 1fr 1fr; } }

.footer-brand-logo {
    height: 2rem; width: auto; max-width: 10rem;
    margin-bottom: 1rem;
    object-fit: contain;
    filter: brightness(0) invert(1);
    opacity: 0.85;
}

.footer-tagline {
    margin: 0 0 0.5rem;
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--parchment-soft);
}

.footer-note {
    margin: 0;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.footer-heading {
    margin: 0 0 1rem;
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-wide);
    color: var(--bronze-light);
}

.footer-links, .footer-meta { list-style: none; margin: 0; padding: 0; }
.footer-links li { margin-bottom: 0.5rem; }

.footer-links a {
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
    transition: color 0.2s;
}

.footer-links a:hover { color: var(--bronze-light); }

.footer-meta li { margin-bottom: 0.75rem; font-size: var(--text-sm); line-height: var(--leading-normal); }
.footer-meta span { display: block; margin-bottom: 0.15rem; font-size: var(--text-xs); color: var(--parchment-muted); }
.footer-meta strong { font-weight: 400; color: var(--parchment-soft); }

.footer-partners { padding-top: 2.5rem; border-top: 1px solid var(--border); }

.footer-partners-label {
    margin: 0 0 2rem;
    text-align: center;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--parchment-muted);
}

.partner-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }

@media (min-width: 640px) { .partner-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px) { .partner-grid { grid-template-columns: repeat(5, 1fr); } }

.partner-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 7rem;
    padding: 1.25rem 0.75rem;
    text-align: center;
    background: rgba(236, 232, 223, 0.02);
    border: 1px solid var(--border);
}

.partner-logo {
    max-height: 2.75rem;
    max-width: 7.5rem;
    width: auto;
    height: auto;
    object-fit: contain;
    opacity: 0.88;
    transition: opacity 0.2s;
}

.partner-logo:hover { opacity: 1; }
.partner-logo--innovation { max-height: 2.25rem; max-width: 9rem; }

.partner-name {
    font-size: var(--text-xs);
    line-height: var(--leading-snug);
    color: var(--parchment-muted);
}

.partner-role {
    font-size: var(--text-xs);
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-wide);
    color: rgba(236, 232, 223, 0.38);
}

.logo-fallback {
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.footer-bottom {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
    font-size: 0.6875rem;
    color: rgba(236, 232, 223, 0.42);
    text-align: center;
}

@media (min-width: 768px) {
    .footer-bottom { flex-direction: row; justify-content: space-between; text-align: right; }
}

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    font-family: inherit;
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--parchment);
    background: rgba(6, 16, 24, 0.65);
    border: 1px solid var(--border-strong);
    transition: border-color 0.2s;
}

.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: var(--border-bronze);
}

.form-label {
    display: block;
    margin-bottom: 0.5rem;
    font-size: var(--text-base);
    font-weight: 500;
    line-height: var(--leading-snug);
    color: var(--parchment-soft);
}
.form-label .required, .required { color: var(--bronze-light); }
.form-section { padding: 2rem 0; border-bottom: 1px solid var(--border); }

.track-card {
    position: relative;
    cursor: pointer;
    padding: 1.5rem;
    border: 1px solid var(--border);
    background: rgba(6, 16, 24, 0.55);
    transition: border-color 0.2s, background 0.2s;
}

.track-card.selected {
    border-color: var(--border-bronze);
    background: var(--bronze-pale);
}

.track-card input { position: absolute; opacity: 0; pointer-events: none; }

.alert-error {
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    font-size: 0.875rem;
    color: #7ec8dc;
    background: rgba(40, 184, 216, 0.08);
    border: 1px solid rgba(40, 184, 216, 0.22);
}

.alert-error-list {
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 0.875rem;
    color: var(--parchment-soft);
}

.alert-error-list li + li { margin-top: 0.25rem; }

.alert-success {
    padding: 1rem 1.25rem;
    font-size: 0.875rem;
    color: #8a9a82;
    background: rgba(110, 120, 110, 0.1);
    border: 1px solid rgba(110, 120, 110, 0.22);
}

.hp-field { position: absolute; left: -9999px; opacity: 0; height: 0; width: 0; overflow: hidden; }
.form-checkbox { accent-color: var(--cyan); }

.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23ece8df' opacity='0.45'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: left 0.75rem center;
    background-size: 1rem;
    padding-left: 2.5rem;
}

.page-wrap { max-width: var(--max-w-narrow); margin: 0 auto; padding: 3rem 1.25rem 4rem; }
.page-title {
    margin: 0 0 0.75rem;
    font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
    font-weight: 600;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--parchment);
}

.page-lead {
    margin: 0;
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
    color: var(--parchment-muted);
}

.form-grid { display: grid; gap: 1.25rem; }
@media (min-width: 768px) { .form-grid--2 { grid-template-columns: 1fr 1fr; } }
.form-grid .span-full { grid-column: 1 / -1; }

/* ── Admin ────────────────────────────────────────────────────────────────── */
.admin-page { min-height: 100vh; }

.admin-center {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
}

.admin-header {
    border-bottom: 1px solid var(--border);
    background: var(--ink-raised);
}

.admin-header-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 1rem 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.admin-header-inner a { font-size: 0.8125rem; color: var(--parchment-muted); }
.admin-header-inner a:hover { color: var(--bronze-light); }

.admin-main { max-width: var(--max-w); margin: 0 auto; padding: 2rem 1.25rem; }

.admin-table { width: 100%; border-collapse: collapse; }

.admin-table th, .admin-table td {
    padding: 0.75rem 1rem;
    text-align: right;
    border-bottom: 1px solid var(--border);
    font-size: 0.8125rem;
}

.admin-table th { color: var(--parchment-muted); font-weight: 400; }

.admin-link { color: var(--bronze-light); font-size: 0.8125rem; }
.admin-link:hover { text-decoration: underline; }

.admin-filters { padding: 1.25rem; margin-bottom: 2rem; }

.admin-login-title { text-align: center; margin-bottom: 2.5rem; }
.admin-login-title p:first-child { font-size: 1.125rem; font-weight: 500; margin: 0; }
.admin-login-title p:last-child { font-size: 0.75rem; color: var(--parchment-muted); margin: 0.35rem 0 0; }

.admin-form-wrap { width: 100%; max-width: 22rem; }

.btn-primary.w-full { width: 100%; }

.form-section-title {
    margin: 0 0 1.5rem;
    font-size: var(--text-lg);
    font-weight: 700;
    line-height: var(--leading-snug);
    color: var(--parchment);
}

.form-hint {
    margin: 0.5rem 0 0;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.form-stack { display: flex; flex-direction: column; gap: 1.25rem; }

.form-check-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--parchment-soft);
    cursor: pointer;
}

.form-check-label--start { align-items: flex-start; }

.form-check-row { display: flex; gap: 1.5rem; margin-top: 0.5rem; }

.form-label-hint { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--parchment-muted); }

.admin-header-title { margin: 0; font-weight: 500; }
.admin-header-sub { margin: 0.15rem 0 0; font-size: 0.75rem; color: var(--parchment-muted); }
.admin-header-actions { display: flex; align-items: center; gap: 1rem; font-size: 0.8125rem; }

.admin-count { margin: 0 0 1rem; font-size: 0.75rem; color: var(--parchment-muted); }

.admin-filter-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .admin-filter-grid { grid-template-columns: repeat(6, 1fr); }
    .admin-filter-grid .span-2 { grid-column: span 2; }
}

.admin-filter-actions { margin-top: 1rem; display: flex; gap: 0.75rem; }

.admin-table-wrap { overflow-x: auto; }

.admin-table tbody tr:hover { background: rgba(236, 232, 223, 0.02); }

.admin-table .cell-muted { color: var(--parchment-muted); }
.admin-table .cell-truncate { max-width: 12rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.admin-table .cell-nowrap { white-space: nowrap; }
.admin-table .cell-empty { text-align: center; color: var(--parchment-muted); padding: 2rem 1rem; }

.admin-main--narrow { max-width: var(--max-w-narrow); }
.admin-header-inner--narrow { max-width: var(--max-w-narrow); }

.admin-detail-title { margin: 0 0 1rem; font-size: 1.125rem; font-weight: 500; }
.admin-detail-meta { margin: 0 0 1.5rem; font-size: 0.75rem; color: var(--parchment-muted); }

.admin-detail-row {
    display: grid;
    gap: 0.35rem 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
}

@media (min-width: 768px) {
    .admin-detail-row { grid-template-columns: 1fr 2fr; }
}

.admin-detail-row dt { margin: 0; font-size: 0.75rem; color: var(--parchment-muted); }
.admin-detail-row dd { margin: 0; font-size: 0.875rem; color: var(--parchment-soft); }

.admin-file-block {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

.admin-status-form .form-grid--2 { align-items: end; }

/* ── Inner pages ─────────────────────────────────────────────────────────── */
.page-hero {
    padding: 4.5rem 1.25rem 3.5rem;
    text-align: center;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 100%);
}

.page-hero-inner { max-width: 40rem; margin: 0 auto; }

.page-hero-title {
    margin: 0;
    font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
    font-weight: 600;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--parchment);
}

.page-hero-lead {
    margin: 1.25rem auto 0;
    max-width: 32rem;
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
    color: var(--parchment-muted);
}

.lead-paragraph {
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
}

.prose h2 {
    margin: 2rem 0 0.75rem;
    font-size: var(--text-lg);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--parchment);
}

.prose h2:first-child { margin-top: 0; }

.content-list { margin: 0; padding: 0; list-style: none; }

.content-list li {
    position: relative;
    padding: 0.65rem 0 0.65rem 1.25rem;
    border-bottom: 1px solid var(--border);
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--parchment-soft);
}

.content-list li::before {
    content: '';
    position: absolute;
    right: 0;
    top: 1.1rem;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--bronze);
}

.content-list--checks li::before {
    content: '\f00c';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    width: auto;
    height: auto;
    background: none;
    color: var(--bronze-light);
    font-size: 0.75rem;
    top: 0.85rem;
}

.process-list { margin: 0; padding: 0; list-style: none; counter-reset: step; }

.process-list li {
    counter-increment: step;
    position: relative;
    padding: 1rem 0 1rem 2.5rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.9375rem;
    color: var(--parchment-soft);
}

.process-list li::before {
    content: counter(step);
    position: absolute;
    right: 0;
    top: 0.9rem;
    width: 1.75rem;
    height: 1.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--bronze-light);
    border: 1px solid var(--border-bronze);
    border-radius: 50%;
}

.stat-grid { display: grid; gap: 1rem; margin-top: 2.5rem; }

@media (min-width: 640px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .stat-grid { grid-template-columns: repeat(4, 1fr); } }

.stat-card { text-align: center; }

.stat-value {
    margin: 0 0 0.35rem;
    font-size: var(--text-xl);
    font-weight: 700;
    line-height: var(--leading-tight);
    color: var(--bronze-light);
}

.stat-value span {
    font-size: var(--text-sm);
    font-weight: 400;
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.stat-desc {
    margin: 0;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.topic-card-link {
    display: block;
    color: inherit;
    transition: border-color 0.25s, transform 0.2s;
}

.topic-card-link:hover { border-color: var(--border-bronze); transform: translateY(-2px); }

.topic-card-more {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8125rem;
    color: var(--bronze-light);
}

.topic-card-more i { font-size: 0.7rem; }

.legal-content .prose p { margin-bottom: 1rem; }

.footer-newsletter {
    background: var(--ink-raised);
    border-bottom: 1px solid var(--border);
}

.footer-newsletter-inner {
    display: grid;
    gap: 1.5rem;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
}

@media (min-width: 768px) {
    .footer-newsletter-inner {
        grid-template-columns: 1fr 1.2fr;
        align-items: center;
    }
}

.newsletter-title {
    margin: 0 0 0.5rem;
    font-size: var(--text-lg);
    font-weight: 700;
    line-height: var(--leading-snug);
    color: var(--parchment);
}

.newsletter-desc {
    margin: 0;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--parchment-muted);
}

.newsletter-note {
    margin: 0.65rem 0 0;
    font-size: var(--text-xs);
    line-height: var(--leading-normal);
    color: var(--parchment-muted);
}

.newsletter-note a { color: var(--bronze-light); }
.newsletter-flash { margin-bottom: 1rem; }

.newsletter-fields { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.newsletter-fields .form-input { flex: 1; min-width: 12rem; }

.footer-grid--wide {
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .footer-grid--wide { grid-template-columns: 1.4fr repeat(3, 1fr); }
}

@media (min-width: 1100px) {
    .footer-grid--wide { grid-template-columns: 1.5fr repeat(4, 1fr); }
}

.footer-social { display: flex; gap: 0.65rem; margin-top: 1.25rem; }

.footer-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    font-size: 0.875rem;
    color: var(--parchment-muted);
    border: 1px solid var(--border);
    transition: color 0.2s, border-color 0.2s;
}

.footer-social-link:hover { color: var(--bronze-light); border-color: var(--border-bronze); }

.footer-bottom {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 2rem;
    border-top: 1px solid var(--border);
    font-size: 0.75rem;
    color: var(--parchment-muted);
}

.footer-legal { display: flex; flex-wrap: wrap; gap: 1rem; }
.footer-legal a { color: var(--parchment-muted); }
.footer-legal a:hover { color: var(--bronze-light); }

.partner-grid--sponsors { max-width: 28rem; margin: 0 auto; }
.partner-cell--large { padding: 1.5rem; }

/* ═══════════════════════════════════════════════════════════════════════════
   Public layout — all public pages (page-public)
   ═══════════════════════════════════════════════════════════════════════════ */

.page-public {
    color: var(--text-body);
    background: var(--surface-alt);
    background-image: none;
    --header-h: 4.75rem;
    font-size: var(--text-base);
    line-height: var(--leading-normal);
}

.page-public .site-header {
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(6, 16, 24, 0.07);
    box-shadow: 0 1px 12px rgba(6, 16, 24, 0.04);
    overflow: visible;
}

.page-public .header-inner {
    max-width: var(--max-w);
    padding: 0 1.25rem;
}

@media (min-width: 768px) {
    .page-public .header-inner { padding: 0 1.5rem; }
}

.page-public .header-brand {
    display: flex;
    align-items: center;
    padding: 0.35rem 0;
}

.page-public .header-logo {
    height: 2.625rem;
    width: auto;
    max-width: none;
    min-width: 8rem;
    object-fit: contain;
    filter: none;
}

@media (min-width: 900px) {
    .page-public .header-logo {
        height: 3.125rem;
        min-width: 10rem;
    }
}

.page-public .header-nav {
    display: none;
    gap: 1.75rem;
    margin-right: auto;
    margin-left: 1.5rem;
    font-size: var(--text-base);
    font-weight: 500;
    line-height: var(--leading-snug);
}

.page-public .header-nav a {
    color: var(--text-body);
    transition: color 0.2s;
}

.page-public .header-nav a:hover { color: var(--cyan-soft); }

@media (min-width: 900px) {
    .page-public .header-nav { display: flex; }
}

.page-public .btn-header-cta {
    display: none;
    padding: 0.5625rem 1.25rem;
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--navy-deep);
    background: var(--cyan);
    border-color: var(--cyan);
    border-radius: 999px;
}

.page-public .btn-header-cta:hover {
    background: var(--cyan-bright);
    border-color: var(--cyan-bright);
}

@media (min-width: 900px) {
    .page-public .btn-header-cta { display: inline-flex; align-items: center; }
}

.page-public .header-menu-btn {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--surface-alt);
    border: 1px solid rgba(6, 16, 24, 0.08);
    box-shadow: none;
}

.page-public .header-menu-btn span {
    background: var(--text-dark);
    opacity: 0.85;
}

@media (min-width: 900px) {
    .page-public .header-menu-btn { display: none; }
}

.page-public main { padding-top: var(--header-h); }

.page-home main { padding-top: 0; }

/* Inner page hero */
.inner-hero {
    padding: 2.5rem 1.25rem 2rem;
    background: var(--surface-alt);
}

@media (min-width: 768px) {
    .inner-hero { padding: 3rem 1.5rem 2.5rem; }
}

.inner-hero-inner { text-align: center; }

.inner-hero-eyebrow {
    display: block;
    margin-bottom: 0.75rem;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--cyan-soft);
}

.inner-hero-title {
    margin: 0;
    font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
    font-weight: 700;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--text-dark);
}

.inner-hero-lead {
    margin: 1rem auto 0;
    max-width: 36rem;
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
    color: var(--text-muted-dk);
}

.inner-cta-text {
    margin: 0 auto 1.75rem;
    max-width: 32rem;
    text-align: center;
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
    color: rgba(244, 240, 232, 0.88);
}

.inner-cta { padding-top: 3.5rem; padding-bottom: 3.5rem; }

/* Sections — light theme */
.page-public .section {
    padding: 4rem 1.25rem;
    border-top: none;
    background: transparent;
}

.page-public .section--alt { background: var(--surface); }

.page-public .section-eyebrow { color: var(--cyan-soft); }

.page-public .section-title {
    color: var(--text-dark);
    font-weight: 700;
    line-height: var(--leading-tight);
}

.page-public .section-head--center .section-title::after {
    background: var(--cyan);
}

.page-public .section-desc { color: var(--text-muted-dk); }

.page-public .text-body { color: var(--text-body); }
.page-public .text-muted { color: var(--text-muted-dk); }
.page-public .text-bright { color: var(--text-dark); }

.page-public .lead-paragraph {
    font-size: 1.125rem;
    line-height: 1.85;
    color: var(--text-body);
}

.page-public .lead-paragraph {
    font-size: var(--text-md);
    line-height: var(--leading-relaxed);
}

.page-public .prose h2 {
    color: var(--text-dark);
    font-size: var(--text-lg);
    font-weight: 600;
    line-height: var(--leading-snug);
}

.page-public .prose p {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
}

.page-public .prose a {
    color: var(--cyan-soft);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.page-public .prose a:hover { color: var(--cyan); }

.page-public .content-list li {
    color: var(--text-body);
    border-bottom-color: rgba(6, 16, 24, 0.08);
}

.page-public .content-list li::before { background: var(--cyan); }

.page-public .content-list--checks li::before { color: var(--cyan); }

.page-public .process-list li {
    color: var(--text-body);
    border-bottom-color: rgba(6, 16, 24, 0.08);
}

.page-public .process-list li::before {
    color: var(--cyan);
    border-color: rgba(40, 184, 216, 0.35);
}

/* Cards & panels */
.page-public .panel {
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    box-shadow: 0 2px 12px rgba(6, 16, 24, 0.04);
}

.page-public .section--alt .panel { background: var(--surface-alt); }

.page-public .panel:hover {
    border-color: rgba(40, 184, 216, 0.35);
    box-shadow: 0 8px 28px rgba(6, 16, 24, 0.08);
}

.page-public .card-title { color: var(--text-dark); font-weight: 600; }
.page-public .card-text { color: var(--text-muted-dk); }
.page-public .card-label { color: var(--cyan-soft); }
.page-public .icon-card,
.page-public .icon-line { color: var(--cyan); opacity: 1; }

.page-public .tag {
    color: var(--text-muted-dk);
    background: var(--surface-alt);
    border-color: rgba(6, 16, 24, 0.1);
}

.page-public .topic-card-more { color: var(--cyan-soft); }

.page-public .member-card {
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-right: 3px solid var(--cyan);
}

.page-public .section--alt .member-card { background: var(--surface-alt); }

.page-public .member-name { color: var(--text-dark); }
.page-public .member-role { color: var(--cyan-soft); }
.page-public .member-org,
.page-public .member-affiliation { color: var(--text-muted-dk); }

.page-public .stat-value { color: var(--text-dark); }
.page-public .stat-value span { color: var(--text-muted-dk); }
.page-public .stat-desc { color: var(--text-muted-dk); }

.page-public .prize-list li { color: var(--text-body); border-bottom-color: rgba(6, 16, 24, 0.08); }
.page-public .prize-chip {
    color: var(--text-body);
    background: rgba(40, 184, 216, 0.08);
    border-color: rgba(40, 184, 216, 0.25);
}

.page-public .accordion-wrap {
    background: var(--surface);
    border-color: rgba(6, 16, 24, 0.08);
}

.page-public .accordion-trigger {
    color: var(--text-dark);
}

.page-public .accordion-trigger:hover { background: rgba(40, 184, 216, 0.06); }
.page-public .accordion-trigger[aria-expanded="true"] { background: rgba(40, 184, 216, 0.08); }
.page-public .accordion-body li { color: var(--text-body); }
.page-public .accordion-chevron { color: var(--text-muted-dk); }

.page-public .support-item {
    background: var(--surface);
    border-color: rgba(6, 16, 24, 0.08);
    color: var(--text-body);
}

.page-public .timeline-body {
    background: var(--surface);
    border-color: rgba(6, 16, 24, 0.08);
}

.page-public .timeline-text { color: var(--text-dark); }
.page-public .timeline-dot {
    background: var(--surface-alt);
    color: var(--cyan);
}

.page-public .deadline-box {
    color: var(--text-body);
    background: rgba(40, 184, 216, 0.08);
    border-color: rgba(40, 184, 216, 0.25);
}

.page-public .btn-secondary {
    color: var(--text-body);
    border-color: rgba(6, 16, 24, 0.18);
}

.page-public .btn-secondary:hover {
    border-color: rgba(40, 184, 216, 0.45);
    color: var(--text-dark);
}

.page-public .cta-band p { color: var(--text-muted-dk); }

/* Forms (apply, newsletter) */
.page-public .page-wrap { padding-top: 2rem; }

.page-public .page-title {
    color: var(--text-dark);
    font-weight: 600;
}

.page-public .page-lead { color: var(--text-muted-dk); }

.page-public .form-label { color: var(--text-body); }

.page-public .form-input,
.page-public .form-select,
.page-public .form-textarea {
    color: var(--text-dark);
    background: var(--surface);
    border-color: rgba(6, 16, 24, 0.12);
}

.page-public .form-input:focus,
.page-public .form-select:focus,
.page-public .form-textarea:focus {
    border-color: rgba(40, 184, 216, 0.5);
}

.page-public .form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%235a7288'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
}

.page-public .form-section { border-bottom-color: rgba(6, 16, 24, 0.08); }

.page-public .form-section-title { color: var(--text-dark); }

.page-public .form-hint,
.page-public .form-label-hint { color: var(--text-muted-dk); }

.page-public .form-check-label { color: var(--text-body); }

.page-public .track-card {
    background: var(--surface);
    border-color: rgba(6, 16, 24, 0.1);
}

.page-public .track-card.selected {
    border-color: rgba(40, 184, 216, 0.45);
    background: rgba(40, 184, 216, 0.06);
}

.page-public .alert-error {
    color: #1a6b7a;
    background: rgba(40, 184, 216, 0.1);
    border-color: rgba(40, 184, 216, 0.25);
}

.page-public .alert-success {
    color: #3d6b4a;
    background: rgba(80, 140, 90, 0.1);
    border-color: rgba(80, 140, 90, 0.25);
}

.page-public .alert-error-list { color: var(--text-body); }

/* Footer — shared light newsletter + dark base */
.page-public .site-footer {
    background: var(--navy-deep);
    border-top: none;
}

.page-public .footer-newsletter {
    background: var(--surface);
    border-bottom: 1px solid rgba(6, 16, 24, 0.08);
}

.page-public .footer-newsletter .newsletter-title { color: var(--text-dark); }
.page-public .footer-newsletter .newsletter-desc { color: var(--text-muted-dk); }
.page-public .footer-newsletter .newsletter-note { color: var(--text-muted-dk); }
.page-public .footer-newsletter .newsletter-note a { color: var(--cyan-soft); }

.page-public .footer-newsletter .form-input {
    color: var(--text-dark);
    background: var(--surface-alt);
    border-color: rgba(6, 16, 24, 0.12);
}

.page-public .footer-newsletter .btn-primary {
    color: var(--navy-deep);
    background: var(--cyan);
    border-color: var(--cyan);
}

.page-public .partner-cell {
    background: rgba(244, 240, 232, 0.04);
    border-color: rgba(244, 240, 232, 0.08);
}

.page-public .partner-logo { filter: brightness(0) invert(1); opacity: 0.85; }

.page-home .footer-partners { display: none; }

/* Hero card */
.hero-xp {
    padding: 0.75rem 1rem 0;
}

.page-home .hero-xp {
    padding-top: calc(var(--header-h) + 0.5rem);
}

@media (min-width: 768px) {
    .hero-xp { padding: 1rem 1.5rem 0; }
    .page-home .hero-xp { padding-top: calc(var(--header-h) + 0.75rem); }
}

.hero-xp-card {
    position: relative;
    min-height: min(88vh, 52rem);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--navy-deep);
}

.hero-xp-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.hero-xp-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(4, 12, 20, 0.35) 0%, rgba(6, 16, 24, 0.72) 100%),
        radial-gradient(ellipse 60% 50% at 50% 40%, rgba(40, 184, 216, 0.12), transparent);
}

.hero-xp-content {
    position: relative;
    z-index: 2;
    max-width: 42rem;
    padding: 6rem 1.5rem 4rem;
    text-align: center;
}

.hero-xp-title {
    margin: 0 0 1.25rem;
    font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
    font-weight: 700;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--cream);
}

.hero-xp-lead {
    margin: 0 auto 2rem;
    max-width: 34rem;
    font-size: clamp(var(--text-base), 2vw, var(--text-md));
    line-height: var(--leading-relaxed);
    color: rgba(244, 240, 232, 0.88);
}

.btn-hero-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2.25rem;
    font-family: inherit;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--cyan);
    background: var(--surface);
    border: none;
    border-radius: 999px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}

.btn-hero-pill:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 28px rgba(0, 0, 0, 0.2);
    background: var(--cream);
}

.btn-hero-pill--sm {
    padding: 0.75rem 1.75rem;
    font-size: var(--text-sm);
}

/* XP blocks */
.xp-block {
    padding: 4.5rem 1.25rem;
}

@media (min-width: 768px) {
    .xp-block { padding: 5.5rem 1.5rem; }
}

.xp-block--alt { background: var(--surface); }
.xp-block--mission { padding-top: 3.5rem; padding-bottom: 3.5rem; }

.xp-inner {
    max-width: var(--max-w);
    margin: 0 auto;
}

.xp-inner--narrow { max-width: 40rem; }

.xp-mission-text {
    margin: 0;
    max-width: 52rem;
    font-size: clamp(var(--text-lg), 2.5vw, var(--text-2xl));
    font-weight: 400;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-tight);
    color: var(--text-dark);
}

.xp-mission-text strong {
    font-weight: 700;
    color: var(--text-dark);
}

.xp-link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 1.5rem;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--cyan-soft);
    transition: color 0.2s;
}

.xp-link-arrow::after {
    content: '\2190';
    font-size: var(--text-md);
}

.xp-link-arrow:hover { color: var(--cyan); }

.xp-section-head { margin-bottom: 2.5rem; }
.xp-section-head--center { text-align: center; }

.xp-section-title {
    margin: 0 0 0.75rem;
    font-size: clamp(var(--text-xl), 2.5vw, var(--text-2xl));
    font-weight: 700;
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--text-dark);
}

.xp-section-title--center { text-align: center; }

.xp-section-desc {
    margin: 0;
    max-width: 36rem;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-muted-dk);
}

.xp-section-head--center .xp-section-desc { margin-right: auto; margin-left: auto; }
.xp-section-desc--center { text-align: center; margin-right: auto; margin-left: auto; }

/* Impact carousel */
.impact-scroll-wrap {
    margin: 0 -1.25rem;
    padding: 0 1.25rem;
    overflow: hidden;
}

.impact-scroll {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding: 1.25rem;
    padding-bottom: 0.5rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

.impact-scroll::-webkit-scrollbar { height: 4px; }
.impact-scroll::-webkit-scrollbar-thumb { background: rgba(6, 16, 24, 0.15); border-radius: 4px; }

.impact-card {
    flex: 0 0 min(85vw, 18rem);
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.5rem;
    min-height: 14rem;
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-radius: var(--radius);
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.impact-card:hover {
    border-color: rgba(40, 184, 216, 0.35);
    box-shadow: 0 8px 32px rgba(6, 16, 24, 0.08);
    transform: translateY(-2px);
}

.impact-card-cat {
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--text-muted-dk);
}

.impact-card-title {
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--text-body);
}

.impact-card-stat {
    margin-top: auto;
    font-size: clamp(var(--text-lg), 3vw, var(--text-xl));
    font-weight: 700;
    line-height: var(--leading-tight);
    color: var(--text-dark);
}

.impact-card-stat em {
    display: block;
    margin-top: 0.15rem;
    font-style: normal;
    font-size: var(--text-xs);
    font-weight: 400;
    line-height: var(--leading-snug);
    color: var(--text-muted-dk);
}

.impact-card-link {
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--cyan-soft);
}

/* Competition cards */
.competition-grid {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .competition-grid { grid-template-columns: 1fr 1fr; }
}

.competition-card {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    padding: 2rem;
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-radius: var(--radius);
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.xp-block:not(.xp-block--alt) .competition-card { background: var(--surface-alt); }

.competition-card:hover {
    border-color: rgba(40, 184, 216, 0.4);
    box-shadow: 0 12px 40px rgba(6, 16, 24, 0.08);
    transform: translateY(-3px);
}

.competition-label {
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--cyan-soft);
}

.competition-title {
    margin: 0;
    font-size: var(--text-lg);
    font-weight: 700;
    line-height: var(--leading-snug);
    color: var(--text-dark);
}

.competition-desc {
    margin: 0;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-muted-dk);
}

.competition-prize {
    margin-top: 0.5rem;
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--text-dark);
}

.competition-cta {
    margin-top: auto;
    padding-top: 1rem;
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--cyan);
}

/* Focus grid */
.focus-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .focus-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 900px) {
    .focus-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1100px) {
    .focus-grid { grid-template-columns: repeat(5, 1fr); }
}

.focus-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.75rem 1.25rem;
    text-align: center;
    background: var(--surface-alt);
    border: 1px solid rgba(6, 16, 24, 0.06);
    border-radius: var(--radius);
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}

.focus-card:hover {
    border-color: rgba(40, 184, 216, 0.35);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(6, 16, 24, 0.06);
}

.focus-card-icon {
    font-size: 1.5rem;
    color: var(--cyan);
}

.focus-card-title {
    margin: 0;
    font-size: var(--text-base);
    font-weight: 700;
    line-height: var(--leading-snug);
    color: var(--text-dark);
}

.focus-card-desc {
    margin: 0;
    font-size: var(--text-sm);
    line-height: var(--leading-normal);
    color: var(--text-muted-dk);
}

/* Feature banner */
.feature-banner {
    position: relative;
    padding: 3rem 2rem;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--navy);
}

.feature-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        url('/assets/images/taraz-balance.png') center / cover no-repeat,
        linear-gradient(135deg, rgba(6, 16, 24, 0.92), rgba(15, 34, 54, 0.88));
    background-blend-mode: overlay;
    opacity: 0.45;
}

.feature-banner-content {
    position: relative;
    z-index: 1;
    max-width: 36rem;
}

.feature-banner-tag {
    display: inline-block;
    margin-bottom: 0.75rem;
    font-size: var(--text-xs);
    font-weight: 600;
    line-height: var(--leading-snug);
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--cyan);
}

.feature-banner-title {
    margin: 0 0 0.75rem;
    font-size: clamp(var(--text-lg), 3vw, var(--text-2xl));
    font-weight: 700;
    line-height: var(--leading-tight);
    color: var(--cream);
}

.feature-banner-desc {
    margin: 0 0 1.5rem;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: rgba(244, 240, 232, 0.78);
}

/* Prize panels */
.prize-grid-xp {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .prize-grid-xp { grid-template-columns: 1fr 1fr; }
}

.prize-panel-xp {
    padding: 2rem;
    background: var(--surface-alt);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-radius: var(--radius);
}

.xp-block--alt .prize-panel-xp { background: var(--surface); }

.prize-panel-xp h3 {
    margin: 0 0 1.25rem;
    font-size: var(--text-lg);
    font-weight: 700;
    line-height: var(--leading-snug);
    color: var(--text-dark);
}

.prize-panel-xp ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.prize-panel-xp li {
    padding: 0.65rem 0;
    border-bottom: 1px solid rgba(6, 16, 24, 0.06);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--text-body);
}

.prize-panel-xp li:last-child { border-bottom: none; }

.prize-panel-xp strong {
    font-weight: 600;
    color: var(--cyan-soft);
}

/* Support pills */
.support-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem;
}

.support-pill {
    padding: 0.625rem 1.25rem;
    font-size: var(--text-sm);
    font-weight: 500;
    line-height: var(--leading-snug);
    color: var(--text-body);
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.1);
    border-radius: 999px;
}

.xp-block:not(.xp-block--alt) .support-pill { background: var(--surface-alt); }

/* Get involved */
.xp-block--involve {
    background: var(--navy);
    color: var(--cream);
}

.xp-block--involve .xp-section-title,
.xp-block--involve .xp-section-desc { color: var(--cream); }

.xp-block--involve .xp-section-desc { opacity: 0.78; }

.involve-pills {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 2rem;
}

.involve-pill {
    padding: 0.8125rem 1.75rem;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--cream);
    background: transparent;
    border: 1px solid rgba(244, 240, 232, 0.35);
    border-radius: 999px;
    transition: background 0.2s, border-color 0.2s;
}

.involve-pill:hover {
    background: rgba(244, 240, 232, 0.08);
    border-color: rgba(244, 240, 232, 0.55);
}

.involve-pill--primary {
    color: var(--navy-deep);
    background: var(--cream);
    border-color: var(--cream);
}

.involve-pill--primary:hover {
    background: var(--surface);
    border-color: var(--surface);
}

/* Process row */
.process-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 2rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.process-row li {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    font-size: var(--text-base);
    font-weight: 500;
    line-height: var(--leading-snug);
    color: var(--text-body);
}

.process-num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    font-size: var(--text-sm);
    font-weight: 700;
    line-height: 1;
    color: var(--cyan);
    background: rgba(40, 184, 216, 0.1);
    border-radius: 50%;
}

/* Partner strip */
.partner-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 2rem 3rem;
}

.partner-strip-item {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.85;
    transition: opacity 0.2s;
}

.partner-strip-item:hover { opacity: 1; }

.partner-strip .partner-logo {
    max-height: 3.5rem;
    max-width: 9rem;
    filter: none;
    opacity: 1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Visual elements — icons, SVG decorations
   ═══════════════════════════════════════════════════════════════════════════ */

/* Icon badges */
.icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 50%;
    background: rgba(40, 184, 216, 0.12);
    color: var(--cyan-soft);
    line-height: 1;
}

.icon-badge--sm { width: 2.25rem; height: 2.25rem; font-size: 0.875rem; }
.icon-badge--md { width: 2.75rem; height: 2.75rem; font-size: 1.0625rem; }
.icon-badge--lg { width: 3.25rem; height: 3.25rem; font-size: 1.25rem; }
.icon-badge--xl { width: 4rem; height: 4rem; font-size: 1.5rem; }

.icon-badge--soft {
    background: rgba(40, 184, 216, 0.08);
    border: 1px solid rgba(40, 184, 216, 0.18);
}

.icon-badge--light {
    background: rgba(255, 255, 255, 0.95);
    color: var(--cyan);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.icon-badge--cyan { background: var(--cyan); color: var(--navy-deep); }

.section-head-visual {
    display: flex;
    justify-content: center;
    margin-bottom: 1.25rem;
}

.section-head-visual--light .icon-badge { background: rgba(244, 240, 232, 0.12); color: var(--cream); border: 1px solid rgba(244, 240, 232, 0.2); }

/* Nav icons */
.nav-icon {
    margin-left: 0.35rem;
    font-size: 0.8125rem;
    opacity: 0.65;
}

.header-nav a:hover .nav-icon { opacity: 1; color: var(--cyan-soft); }

.btn-header-cta i,
.btn-primary i,
.btn-secondary i,
.btn-hero-pill i {
    margin-left: 0.4rem;
}

/* SVG decorations */
.svg-deco {
    pointer-events: none;
    color: var(--cyan);
}

.svg-deco--grid {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0.4;
    z-index: 1;
}

.svg-deco--ring {
    position: absolute;
    width: 12rem;
    height: 12rem;
    opacity: 0.35;
}

.svg-deco--wave {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 4rem;
    color: var(--cyan);
}

/* Hero visuals */
.hero-xp-deco {
    position: absolute;
    top: 1.5rem;
    left: 1.5rem;
    z-index: 2;
    opacity: 0.55;
}

.hero-xp-svg {
    width: 7rem;
    height: 7rem;
    filter: drop-shadow(0 0 20px rgba(40, 184, 216, 0.35));
}

.hero-xp-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 1.25rem;
    padding: 0.35rem 0.85rem 0.35rem 0.35rem;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--cream);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 999px;
    backdrop-filter: blur(6px);
}

.hero-xp-badge .icon-badge--sm { width: 1.75rem; height: 1.75rem; font-size: 0.75rem; }

/* Mission block */
.xp-block--mission {
    position: relative;
    overflow: hidden;
}

.xp-inner--mission {
    display: grid;
    gap: 2rem;
    align-items: center;
}

@media (min-width: 768px) {
    .xp-inner--mission { grid-template-columns: auto 1fr; gap: 3rem; }
}

.mission-visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 8rem;
}

.mission-visual .svg-deco--ring {
    position: absolute;
    width: 10rem;
    height: 10rem;
}

.mission-copy { position: relative; z-index: 1; }

/* Section action links */
.section-action-link {
    margin: -1.5rem 0 2rem;
}

.section-action-link--center { text-align: center; }

.xp-link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.xp-link-arrow::after { content: none; }

.xp-link-arrow i { font-size: 0.8125rem; }

/* Impact cards with icons */
.impact-card .icon-badge { margin-bottom: 0.25rem; }

.impact-card-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

/* Competition cards */
.competition-card .icon-badge { margin-bottom: 0.5rem; }

.competition-prize i { margin-left: 0.35rem; color: var(--cyan-soft); }

.competition-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

/* Focus cards */
.focus-card-icon-wrap { display: flex; justify-content: center; }

.focus-card-more {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: auto;
    padding-top: 0.75rem;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--cyan-soft);
}

/* Feature banner icon */
.feature-banner {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
}

.feature-banner-icon { flex-shrink: 0; }

.feature-banner-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.feature-banner-tag i { font-size: 0.75rem; }

@media (max-width: 639px) {
    .feature-banner { flex-direction: column; align-items: center; text-align: center; }
    .feature-banner-content { text-align: center; }
}

/* Prize panels with medals */
.prize-panel-head {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 1.25rem;
}

.prize-panel-head h3 { margin: 0; }

.prize-list-icons {
    margin: 0;
    padding: 0;
    list-style: none;
}

.prize-list-icons li {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(6, 16, 24, 0.06);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--text-body);
}

.prize-list-icons li:last-child { border-bottom: none; }

.prize-medal {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
    font-size: 0.875rem;
    color: var(--text-muted-dk);
    background: var(--surface-alt);
    border-radius: 50%;
}

.prize-medal--gold { color: var(--poster-gold); background: rgba(201, 168, 76, 0.12); }

/* Support grid with icons */
.support-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
    .support-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 900px) {
    .support-grid { grid-template-columns: repeat(6, 1fr); }
}

.support-chip {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    padding: 1.25rem 0.75rem;
    text-align: center;
    font-size: var(--text-sm);
    font-weight: 500;
    line-height: var(--leading-snug);
    color: var(--text-body);
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-radius: var(--radius);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.xp-block:not(.xp-block--alt) .support-chip { background: var(--surface-alt); }

.support-chip:hover {
    border-color: rgba(40, 184, 216, 0.35);
    box-shadow: 0 6px 20px rgba(6, 16, 24, 0.06);
}

/* Involve pills with icons */
.involve-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* Process timeline */
.process-timeline {
    display: grid;
    gap: 1rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

@media (min-width: 768px) {
    .process-timeline { grid-template-columns: repeat(5, 1fr); }
}

.process-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
    padding: 1.5rem 1rem;
    text-align: center;
    background: var(--surface);
    border: 1px solid rgba(6, 16, 24, 0.08);
    border-radius: var(--radius);
    position: relative;
}

.xp-block--alt .process-step { background: var(--surface-alt); }

.process-step-num {
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: var(--tracking-wider);
    color: var(--cyan-soft);
    text-transform: uppercase;
}

.process-step-label {
    font-size: var(--text-sm);
    font-weight: 600;
    line-height: var(--leading-snug);
    color: var(--text-body);
}

/* Inner page hero visual */
.inner-hero {
    position: relative;
    overflow: hidden;
}

.inner-hero .svg-deco--grid {
    opacity: 0.25;
    color: var(--cyan-soft);
}

.inner-hero-visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 5rem;
    margin-bottom: 1.25rem;
}

.inner-hero-visual .svg-deco--ring {
    width: 7rem;
    height: 7rem;
}

.inner-hero-visual .icon-badge {
    position: relative;
    z-index: 1;
}

.inner-hero-eyebrow i {
    margin-left: 0.35rem;
    font-size: 0.5rem;
    vertical-align: middle;
}

/* Member cards */
.member-card-visual {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem;
}

.member-role i,
.member-affiliation i {
    margin-left: 0.35rem;
    font-size: 0.75rem;
    opacity: 0.65;
}

.page-public .stat-card {
    text-align: center;
}

.page-public .stat-card .icon-badge {
    margin: 0 auto 1rem;
}

.page-public .topic-card-link .icon-badge {
    margin-bottom: 1rem;
}

.page-public .section-head-visual .icon-badge {
    margin: 0 auto;
}

