/* static-page--about */
body.static-page--about {
    --primary: #b86a32;
    --primary-hover: #995221;
    --primary-rgb: 184, 106, 50;
    --accent-blue: #1d5d68;
    --accent-blue-hover: #14464f;
    --accent-blue-rgb: 29, 93, 104;
    --text-main: #16202b;
    --text-muted: #5f6c79;
    --border: rgba(126, 144, 162, 0.24);
    --bg-body: #edf2f2;
    --bg-card: rgba(255, 255, 255, 0.94);
    --bg-soft: rgba(247, 249, 248, 0.96);
    --shadow-sm: 0 18px 38px -34px rgba(40, 57, 76, 0.24);
    --shadow-md: 0 28px 72px -48px rgba(40, 57, 76, 0.2);
    background-color: var(--bg-body);
    background-image:
        radial-gradient(circle at top left, rgba(184, 106, 50, 0.14) 0%, rgba(184, 106, 50, 0) 30%),
        radial-gradient(circle at right 12%, rgba(29, 93, 104, 0.12) 0%, rgba(29, 93, 104, 0) 26%),
        linear-gradient(180deg, #f7faf9 0%, #edf2f2 52%, #f8fbfb 100%);
}
body.static-page--about header {
    top: 0;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(126, 144, 162, 0.22);
    box-shadow: 0 18px 38px -28px rgba(40, 57, 76, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.8);
}
body.static-page--about nav,
body.static-page--about .logo,
body.static-page--about .header-user-pill,
body.static-page--about .site-language-switch summary,
body.static-page--about .theme-toggle,
body.static-page--about .btn-outline,
body.static-page--about footer h4,
body.static-page--about footer a:hover {
    color: var(--text-main);
}
body.static-page--about .site-language-switch summary,
body.static-page--about .site-language-menu,
body.static-page--about .theme-toggle,
body.static-page--about .btn-outline,
body.static-page--about .header-user-pill,
body.static-page--about .hamburger-btn {
    background: rgba(255, 255, 255, 0.9);
    border-color: rgba(126, 144, 162, 0.22);
}
body.static-page--about .theme-toggle:hover,
body.static-page--about .btn-outline:hover,
body.static-page--about .hamburger-btn:hover {
    color: var(--primary);
    border-color: rgba(184, 106, 50, 0.28);
}
body.static-page--about .site-language-option:hover,
body.static-page--about .site-language-option.is-active {
    background: rgba(184, 106, 50, 0.1);
    color: var(--primary);
}
body.static-page--about .btn-primary {
    background: linear-gradient(180deg, #ca7e47 0%, #995221 100%);
    box-shadow: 0 18px 38px -24px rgba(184, 106, 50, 0.42);
}
body.static-page--about footer {
    border-top-color: rgba(126, 144, 162, 0.16);
}
body.static-page--about footer p,
body.static-page--about footer li,
body.static-page--about footer a,
body.static-page--about .footer-bottom {
    color: #5f6c79;
}

.about-shell,
.about-hero,
.feature-lab-shell,
.feature-lab-hero,
.feature-section,
.feature-tool-grid,
.feature-detail-grid,
.feature-workflow-track,
.feature-lab-cta,
.feature-lab-stat-grid,
.feature-lab-bench-grid {
    min-width: 0;
}

/* about page layout */
.about-story-grid,
.about-flow-track,
.about-principles-grid,
.about-audience-grid,
.about-cta-actions,
.about-stat-grid {
    min-width: 0;
}
.about-shell {
    position: relative;
    margin: 30px 0 42px;
    padding: 34px;
    overflow: hidden;
    border-radius: 40px;
    border: 1px solid rgba(126, 144, 162, 0.18);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(247, 249, 248, 0.94) 100%);
    box-shadow: 0 32px 72px -50px rgba(40, 57, 76, 0.24);
}
.about-shell::before {
    content: '';
    position: absolute;
    inset: -14% auto auto -10%;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(184, 106, 50, 0.16) 0%, rgba(184, 106, 50, 0) 72%);
    filter: blur(36px);
    pointer-events: none;
}
.about-shell::after {
    content: '';
    position: absolute;
    inset: 18px;
    border-radius: 28px;
    border: 1px solid rgba(29, 93, 104, 0.08);
    pointer-events: none;
}

.about-kicker,
.about-panel-label,
.about-card-kicker,
.about-audience-role,
.about-cta-aside-label {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.about-kicker {
    background: rgba(15, 23, 42, 0.05);
    color: #64748b;
}
.about-eyebrow,
.about-section-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(184, 106, 50, 0.1);
    color: var(--primary);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.about-hero,
.about-cta-band {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.14fr) minmax(320px, 0.86fr);
    gap: 22px;
    align-items: start;
}
.about-hero {
    margin-bottom: 24px;
}
.about-hero-copy,
.about-cta-copy,
.about-cta-aside {
    display: grid;
    gap: 16px;
}
.about-hero-copy h1,
.about-section-head h2,
.about-story-card h3,
.about-flow-card h3,
.about-principle-card h3,
.about-audience-card h3,
.about-cta-band h2 {
    margin: 0;
    font-family: 'Fraunces', Georgia, serif;
    color: var(--text-main);
    letter-spacing: -0.04em;
}
.about-hero-copy h1 {
    max-width: 860px;
    font-size: clamp(32px, 4vw, 56px);
    line-height: 1.0;
}
.about-hero-intro,
.about-section-head p,
.about-story-card p,
.about-flow-card p,
.about-principle-card p,
.about-audience-card p,
.about-cta-band p,
.about-stat-card span {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.8;
}
.about-hero-points,
.about-cta-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.about-hero-point {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(22, 32, 43, 0.04);
    border: 1px solid rgba(126, 144, 162, 0.14);
    color: #2d3b49;
    font-size: 14px;
    font-weight: 600;
}

.about-hero-panel,
.about-story-card,
.about-flow-card,
.about-principle-card,
.about-audience-card {
    position: relative;
    border: 1px solid rgba(126, 144, 162, 0.16);
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 24px 54px -40px rgba(40, 57, 76, 0.2);
    backdrop-filter: blur(18px);
}
.about-hero-panel {
    display: grid;
    gap: 18px;
    padding: 28px;
    border-radius: 30px;
    background: linear-gradient(180deg, #182532 0%, #213241 100%);
    border-color: rgba(29, 93, 104, 0.16);
    box-shadow: 0 30px 68px -46px rgba(24, 37, 50, 0.58);
}
.about-panel-label {
    background: rgba(255, 255, 255, 0.08);
    color: #cfd8e4;
}
.about-panel-text {
    margin: 0;
    color: #e7edf5;
    font-size: 17px;
    line-height: 1.85;
}
.about-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.about-stat-card {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.06);
}
.about-stat-card strong {
    color: #ffffff;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.04em;
}
.about-stat-card span {
    color: #b8c4d1;
    font-size: 13px;
    line-height: 1.6;
}

.about-section-head {
    display: grid;
    gap: 12px;
    max-width: 760px;
    margin-bottom: 22px;
}
.about-section-head--tight {
    max-width: 720px;
}
.about-section-head h2,
.about-cta-band h2 {
    font-size: clamp(30px, 4vw, 44px);
    line-height: 1.08;
}

.about-story-section,
.about-flow-section,
.about-principles-section,
.about-audience-section {
    position: relative;
    z-index: 1;
    margin-bottom: 24px;
}
.about-story-grid,
.about-principles-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.about-story-card,
.about-principle-card,
.about-audience-card {
    display: grid;
    gap: 14px;
    padding: 26px;
    border-radius: 28px;
}
.about-story-card::before {
    content: '';
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 4px;
    border-radius: 28px 28px 0 0;
    background: rgba(126, 144, 162, 0.28);
}
.about-story-card--slate::before {
    background: linear-gradient(90deg, rgba(22, 32, 43, 0.88) 0%, rgba(95, 108, 121, 0.24) 100%);
}
.about-story-card--teal::before {
    background: linear-gradient(90deg, rgba(29, 93, 104, 0.92) 0%, rgba(29, 93, 104, 0.2) 100%);
}
.about-story-card--amber::before {
    background: linear-gradient(90deg, rgba(184, 106, 50, 0.94) 0%, rgba(184, 106, 50, 0.22) 100%);
}
.about-card-kicker {
    background: rgba(22, 32, 43, 0.05);
    color: #5c6978;
}

.about-point-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}
.about-point-list li {
    position: relative;
    padding-left: 18px;
    color: #31404d;
    line-height: 1.7;
}
.about-point-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 11px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(184, 106, 50, 0.86);
    box-shadow: 0 0 0 4px rgba(184, 106, 50, 0.12);
}
.about-point-list--compact {
    gap: 8px;
}

.about-flow-track {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}
.about-flow-card {
    display: grid;
    gap: 12px;
    padding: 24px;
    border-radius: 24px;
}
.about-flow-track .about-flow-card:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 32px;
    right: -16px;
    width: 16px;
    height: 2px;
    background: linear-gradient(90deg, rgba(29, 93, 104, 0.48) 0%, rgba(29, 93, 104, 0.08) 100%);
}
.about-flow-index {
    color: #7a8796;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.about-principles-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.about-principle-icon {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: rgba(29, 93, 104, 0.1);
    color: var(--accent-blue);
}

.about-audience-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}
.about-audience-role {
    background: rgba(184, 106, 50, 0.1);
    color: var(--primary);
}

.about-cta-band {
    padding: 30px;
    border-radius: 34px;
    background: linear-gradient(180deg, #122030 0%, #182637 100%);
    border: 1px solid rgba(29, 93, 104, 0.18);
    box-shadow: 0 30px 70px -46px rgba(18, 32, 48, 0.68);
}
.about-cta-band h2,
.about-cta-band p,
.about-cta-aside-label,
.about-cta-aside .about-point-list li {
    color: #edf2f7;
}
.about-cta-band .about-section-kicker {
    background: rgba(184, 106, 50, 0.14);
    color: #ebb184;
}
.about-cta-band .btn-outline {
    color: #edf2f7;
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.12);
}
.about-cta-band .btn-outline:hover {
    color: #ffffff;
    border-color: rgba(184, 106, 50, 0.32);
}
.about-cta-aside {
    padding: 22px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}
.about-cta-aside-label {
    background: rgba(255, 255, 255, 0.08);
}
.about-cta-aside p {
    color: #c7d2de;
}
.about-cta-aside .about-point-list li {
    color: #edf2f7;
}
.about-cta-aside .about-point-list li::before {
    background: rgba(235, 177, 132, 0.92);
    box-shadow: 0 0 0 4px rgba(235, 177, 132, 0.12);
}

body.static-page--about.dark-mode {
    --primary: #ebb184;
    --primary-hover: #f3caab;
    --primary-rgb: 235, 177, 132;
    --accent-blue: #8cc3ca;
    --accent-blue-hover: #b7dce1;
    --accent-blue-rgb: 140, 195, 202;
    --text-main: #edf2f7;
    --text-muted: #a9b6c4;
    --border: rgba(98, 120, 146, 0.26);
    --bg-body: #0b1220;
    --bg-card: rgba(15, 23, 42, 0.9);
    --bg-soft: rgba(15, 23, 42, 0.96);
    --shadow-sm: 0 18px 40px -34px rgba(2, 8, 23, 0.94);
    --shadow-md: 0 28px 70px -48px rgba(2, 8, 23, 0.98);
    background-image:
        radial-gradient(circle at top left, rgba(235, 177, 132, 0.16) 0%, rgba(235, 177, 132, 0) 32%),
        radial-gradient(circle at right 12%, rgba(140, 195, 202, 0.14) 0%, rgba(140, 195, 202, 0) 30%),
        linear-gradient(180deg, #060b14 0%, #0b1220 52%, #101826 100%);
}
body.static-page--about.dark-mode header {
    background: rgba(8, 15, 28, 0.82);
    border-color: rgba(98, 120, 146, 0.28);
    box-shadow: 0 22px 50px -42px rgba(2, 8, 23, 0.98), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
body.static-page--about.dark-mode nav,
body.static-page--about.dark-mode .logo,
body.static-page--about.dark-mode .header-user-pill,
body.static-page--about.dark-mode .site-language-switch summary,
body.static-page--about.dark-mode .theme-toggle,
body.static-page--about.dark-mode .btn-outline,
body.static-page--about.dark-mode footer h4,
body.static-page--about.dark-mode footer a:hover {
    color: #edf2f7;
}
body.static-page--about.dark-mode .site-language-switch summary,
body.static-page--about.dark-mode .site-language-menu,
body.static-page--about.dark-mode .theme-toggle,
body.static-page--about.dark-mode .btn-outline,
body.static-page--about.dark-mode .header-user-pill,
body.static-page--about.dark-mode .hamburger-btn {
    background: rgba(15, 23, 42, 0.82);
    border-color: rgba(98, 120, 146, 0.28);
}
body.static-page--about.dark-mode .site-language-option {
    color: #dbe5f2;
}
body.static-page--about.dark-mode .site-language-option:hover,
body.static-page--about.dark-mode .site-language-option.is-active {
    background: rgba(235, 177, 132, 0.12);
    color: #f3caab;
}
body.static-page--about.dark-mode .theme-toggle:hover,
body.static-page--about.dark-mode .btn-outline:hover,
body.static-page--about.dark-mode .hamburger-btn:hover {
    border-color: rgba(235, 177, 132, 0.28);
    color: #f3caab;
}
body.static-page--about.dark-mode footer p,
body.static-page--about.dark-mode footer li,
body.static-page--about.dark-mode footer a,
body.static-page--about.dark-mode .footer-bottom {
    color: #9aa8ba;
}
body.static-page--about.dark-mode .about-shell {
    background: linear-gradient(180deg, rgba(8, 15, 28, 0.96) 0%, rgba(10, 18, 32, 0.94) 100%);
    border-color: rgba(98, 120, 146, 0.24);
    box-shadow: 0 34px 80px -52px rgba(2, 8, 23, 0.98);
}
body.static-page--about.dark-mode .about-shell::before {
    background: radial-gradient(circle, rgba(235, 177, 132, 0.18) 0%, rgba(235, 177, 132, 0) 72%);
}
body.static-page--about.dark-mode .about-shell::after {
    border-color: rgba(140, 195, 202, 0.1);
}
body.static-page--about.dark-mode .about-kicker {
    background: rgba(170, 182, 196, 0.08);
    color: #c8d3de;
}
body.static-page--about.dark-mode .about-eyebrow,
body.static-page--about.dark-mode .about-section-kicker,
body.static-page--about.dark-mode .about-audience-role {
    background: rgba(235, 177, 132, 0.12);
    color: #f3caab;
}
body.static-page--about.dark-mode .about-card-kicker,
body.static-page--about.dark-mode .about-cta-aside-label,
body.static-page--about.dark-mode .about-panel-label {
    background: rgba(255, 255, 255, 0.08);
    color: #c8d3de;
}
body.static-page--about.dark-mode .about-hero-copy h1,
body.static-page--about.dark-mode .about-section-head h2,
body.static-page--about.dark-mode .about-story-card h3,
body.static-page--about.dark-mode .about-flow-card h3,
body.static-page--about.dark-mode .about-principle-card h3,
body.static-page--about.dark-mode .about-audience-card h3,
body.static-page--about.dark-mode .about-cta-band h2 {
    color: #f8fafc;
}
body.static-page--about.dark-mode .about-hero-intro,
body.static-page--about.dark-mode .about-section-head p,
body.static-page--about.dark-mode .about-story-card p,
body.static-page--about.dark-mode .about-flow-card p,
body.static-page--about.dark-mode .about-principle-card p,
body.static-page--about.dark-mode .about-audience-card p,
body.static-page--about.dark-mode .about-stat-card span {
    color: #a9b6c4;
}
body.static-page--about.dark-mode .about-hero-point,
body.static-page--about.dark-mode .about-story-card,
body.static-page--about.dark-mode .about-flow-card,
body.static-page--about.dark-mode .about-principle-card,
body.static-page--about.dark-mode .about-audience-card {
    background: rgba(15, 23, 42, 0.8);
    border-color: rgba(98, 120, 146, 0.26);
    box-shadow: 0 24px 54px -40px rgba(2, 8, 23, 0.98);
}
body.static-page--about.dark-mode .about-hero-point,
body.static-page--about.dark-mode .about-point-list li {
    color: #d7e0ea;
}
body.static-page--about.dark-mode .about-hero-panel {
    background: linear-gradient(180deg, rgba(19, 31, 43, 0.96) 0%, rgba(15, 23, 42, 0.98) 100%);
    border-color: rgba(140, 195, 202, 0.18);
    box-shadow: 0 30px 68px -46px rgba(2, 8, 23, 0.98);
}
body.static-page--about.dark-mode .about-panel-text,
body.static-page--about.dark-mode .about-stat-card strong,
body.static-page--about.dark-mode .about-cta-band p,
body.static-page--about.dark-mode .about-cta-aside .about-point-list li {
    color: #edf2f7;
}
body.static-page--about.dark-mode .about-stat-card,
body.static-page--about.dark-mode .about-cta-aside {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.06);
}
body.static-page--about.dark-mode .about-principle-icon {
    background: rgba(140, 195, 202, 0.12);
    color: #b7dce1;
}
body.static-page--about.dark-mode .about-point-list li::before {
    background: rgba(235, 177, 132, 0.9);
    box-shadow: 0 0 0 4px rgba(235, 177, 132, 0.12);
}

@media (max-width: 1180px) {
    .about-story-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-principles-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 960px) {
    .about-shell {
        padding: 26px;
    }

    .about-hero,
    .about-cta-band,
    .about-story-grid,
    .about-audience-grid {
        grid-template-columns: 1fr;
    }

    .about-flow-track {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .about-flow-track .about-flow-card::after {
        display: none;
    }
}

@media (max-width: 720px) {
    .about-shell {
        padding: 22px 18px;
        border-radius: 28px;
    }

    .about-shell::after {
        inset: 12px;
        border-radius: 18px;
    }

    .about-stat-grid,
    .about-flow-track,
    .about-principles-grid {
        grid-template-columns: 1fr;
    }

    .about-story-card,
    .about-flow-card,
    .about-principle-card,
    .about-audience-card,
    .about-hero-panel,
    .about-cta-band {
        padding: 22px;
        border-radius: 22px;
    }

    .about-hero-point,
    .about-cta-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .about-cta-actions {
        display: grid;
    }
}
