/* Public dashboard styles extracted from templates/public.html */

    .landing-hero-shell,
    .landing-story-card,
    .landing-points-card,
    .landing-participation-card {
        position: relative;
        overflow: hidden;
        border-radius: 1.5rem;
        border: 1px solid rgba(16, 40, 63, 0.08);
        background: linear-gradient(180deg, rgba(255, 250, 244, 0.96), rgba(255, 246, 238, 0.88));
        box-shadow: 0 22px 44px rgba(15, 32, 49, 0.08);
    }

    .landing-hero-shell {
        margin-bottom: 1.5rem;
        padding: 1.6rem;
        background:
            radial-gradient(circle at top right, rgba(255, 196, 13, 0.24), transparent 24%),
            linear-gradient(140deg, #10283f 0%, #11263d 50%, #0d625b 100%);
        border-color: rgba(255, 255, 255, 0.1);
        box-shadow: 0 28px 48px rgba(15, 32, 49, 0.2);
    }

    .landing-hero-grid {
        display: grid;
        grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
        gap: 1.5rem;
        align-items: center;
    }

    .landing-hero-copy {
        max-width: 60rem;
    }

    .landing-hero-brand {
        display: inline-flex;
        align-items: center;
        gap: 0.65rem;
        margin-bottom: 0.75rem;
        padding: 0;
        border-radius: 0.35rem;
        background: transparent;
        border: 0;
        backdrop-filter: none;
    }

    .landing-hero-logo {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 0 0 auto;
    }

    .landing-hero-logo img {
        display: block;
        width: clamp(86px, 10vw, 138px);
        height: auto;
        object-fit: contain;
        filter: drop-shadow(0 10px 24px rgba(6, 25, 18, 0.26));
    }

    .landing-hero-brand-copy {
        display: grid;
        gap: 0.12rem;
    }

    .landing-hero-brand-copy span {
        font-size: 0.72rem;
        font-weight: 700;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: rgba(241, 255, 245, 0.72);
    }

    .landing-hero-brand-copy strong {
        font-family: "Poppins", "Space Grotesk", sans-serif;
        font-size: 1rem;
        line-height: 1.1;
        color: #ffffff;
    }

    .landing-hero-copy h1 {
        margin: 0.35rem 0 0.9rem;
        font-family: "Poppins", "Space Grotesk", sans-serif;
        font-size: clamp(1.8rem, 3.1vw, 3.1rem);
        line-height: 1.08;
        letter-spacing: -0.03em;
        color: #fff;
        text-align: left;
        text-wrap: normal;
    }

    .landing-hero-copy .hero-subtitle {
        text-align: left;
        max-width: 46rem;
    }

    .landing-hero-badge,
    .landing-hero-impact-kicker,
    .landing-highlight-label,
    .landing-mini-title,
    .landing-story-meta {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        font-size: 0.78rem;
        font-weight: 800;
        letter-spacing: 0.12em;
        text-transform: uppercase;
    }

    .landing-hero-badge {
        padding: 0.42rem 0.8rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.12);
        color: rgba(255, 255, 255, 0.88);
    }

    .landing-hero-impact {
        display: grid;
        gap: 0.45rem;
        margin: 1.25rem 0 1.5rem;
        padding: 1rem 1.1rem;
        border-radius: 1.1rem;
        background: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.12);
        backdrop-filter: blur(10px);
    }

    .landing-hero-impact-kicker {
        color: rgba(255, 255, 255, 0.76);
    }

    .landing-hero-impact-main {
        display: flex;
        align-items: baseline;
        gap: 0.45rem;
        color: #fff;
    }

    .landing-hero-impact-main strong {
        font-family: "Space Grotesk", monospace;
        font-size: clamp(2rem, 3.2vw, 3rem);
        line-height: 1;
        letter-spacing: -0.06em;
    }

    .landing-hero-impact-main span,
    .landing-hero-impact p {
        color: rgba(240, 248, 255, 0.82);
    }

    .landing-hero-impact p {
        margin: 0;
        line-height: 1.6;
    }

    .landing-hero-visual {
        position: relative;
        min-height: 300px;
        border-radius: 1.4rem;
        overflow: hidden;
        background: linear-gradient(160deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
        border: 1px solid rgba(255, 255, 255, 0.12);
    }

    .landing-hero-carousel,
    .landing-hero-slides {
        position: relative;
        width: 100%;
        height: 100%;
    }

    .landing-hero-slide {
        position: absolute;
        inset: 0;
        opacity: 0;
        transform: scale(1.02);
        transition: opacity 0.55s ease, transform 0.75s ease;
    }

    .landing-hero-slide.is-active {
        opacity: 1;
        transform: scale(1);
    }

    .landing-hero-carousel-dots {
        position: absolute;
        left: 50%;
        bottom: 1rem;
        z-index: 2;
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
        padding: 0.45rem 0.6rem;
        border-radius: 999px;
        background: rgba(9, 31, 22, 0.32);
        backdrop-filter: blur(10px);
        transform: translateX(-50%);
    }

    .landing-hero-dot {
        width: 0.72rem;
        height: 0.72rem;
        border: none;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.42);
        cursor: pointer;
        transition: transform 0.2s ease, background-color 0.2s ease;
    }

    .landing-hero-dot.is-active {
        background: #ffffff;
        transform: scale(1.08);
    }

    .landing-hero-image,
    .landing-story-photo,
    .landing-gallery-photo {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    .landing-hero-placeholder,
    .landing-story-photo-placeholder,
    .landing-gallery-photo-placeholder {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        gap: 0.6rem;
        min-height: 100%;
        padding: 1.2rem;
        text-align: center;
        background:
            radial-gradient(circle at top left, rgba(255, 196, 13, 0.3), transparent 28%),
            linear-gradient(145deg, rgba(11, 122, 117, 0.7), rgba(16, 40, 63, 0.88));
        color: #fff;
    }

    .landing-hero-placeholder strong,
    .landing-gallery-photo-placeholder span,
    .landing-story-photo-placeholder span {
        width: 100%;
        font-family: "Poppins", sans-serif;
        font-size: 1.2rem;
    }

    .landing-hero-placeholder p {
        margin: 0;
        color: rgba(255, 255, 255, 0.82);
        line-height: 1.6;
    }

    .landing-hero-placeholder-chip {
        padding: 0.4rem 0.7rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.14);
        font-size: 0.76rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .landing-ods-section {
        position: relative;
        overflow: hidden;
        border-radius: 1.5rem;
        border: 1px solid rgba(19, 71, 46, 0.1);
        background:
            radial-gradient(circle at top right, rgba(185, 216, 111, 0.12), transparent 28%),
            linear-gradient(180deg, rgba(250, 254, 249, 0.98), rgba(241, 248, 239, 0.94));
        box-shadow: 0 18px 34px rgba(26, 72, 46, 0.08);
    }

    .landing-ods-body {
        display: grid;
        gap: 0.95rem;
        margin-top: 1rem;
        padding: 1rem;
        border-radius: 1.2rem;
        border: 1px solid rgba(19, 71, 46, 0.08);
        background: rgba(255, 255, 255, 0.56);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
    }

    .landing-ods-stage {
        display: grid;
        grid-template-columns: minmax(0, 1.2fr) auto;
        align-items: start;
        gap: 0.9rem 1.2rem;
        margin-bottom: 0.2rem;
    }

    .landing-ods-copy {
        max-width: 42rem;
    }

    .landing-ods-copy .landing-section-copy {
        margin-bottom: 0;
    }

    .landing-ods-mosaic {
        display: grid;
        grid-template-columns: repeat(3, 3.25rem);
        grid-auto-rows: 3.25rem;
        gap: 0.5rem;
        justify-content: start;
        align-content: start;
        min-width: 0;
        padding: 0;
    }

    .landing-ods-mosaic-tile {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 3.25rem;
        height: 3.25rem;
        border-radius: 0.9rem;
        background: rgba(255, 255, 255, 0.92);
        box-shadow: 0 14px 30px rgba(26, 72, 46, 0.1);
        overflow: hidden;
        transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .landing-ods-mosaic-tile img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    .landing-ods-mosaic-tile:hover {
        transform: translateY(-2px) scale(1.02);
        box-shadow: 0 18px 34px rgba(26, 72, 46, 0.14);
    }

    .landing-ods-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.85rem;
        margin-top: 1rem;
    }

    .landing-ods-card {
        position: relative;
        display: grid;
        gap: 0.7rem;
        min-height: 100%;
        padding: 1.05rem;
        border-radius: 1.05rem;
        border: 1px solid rgba(19, 71, 46, 0.08);
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(247, 251, 245, 0.88));
        box-shadow: 0 14px 28px rgba(26, 72, 46, 0.07);
        overflow: hidden;
    }

    .landing-ods-card::before {
        content: "";
        position: absolute;
        inset: 0 auto auto 0;
        width: 100%;
        height: 6px;
        background: var(--ods-accent, #4f9b63);
    }

    .landing-ods-card::after {
        content: "";
        position: absolute;
        right: -28px;
        top: -28px;
        width: 110px;
        height: 110px;
        border-radius: 50%;
        background: color-mix(in srgb, var(--ods-accent, #4f9b63) 14%, transparent);
        pointer-events: none;
    }

    .landing-ods-head {
        display: grid;
        gap: 0.45rem;
        position: relative;
        z-index: 1;
    }

    .landing-ods-topline {
        display: flex;
        align-items: center;
        gap: 0.55rem;
        flex-wrap: wrap;
    }

    .landing-ods-icon {
        width: 2.65rem;
        height: 2.65rem;
        flex: 0 0 2.65rem;
        border-radius: 0.8rem;
        object-fit: cover;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 12px 24px color-mix(in srgb, var(--ods-accent, #4f9b63) 24%, transparent);
    }

    .landing-ods-number {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: fit-content;
        min-width: 4rem;
        padding: 0.38rem 0.68rem;
        border-radius: 999px;
        background: var(--ods-accent, #4f9b63);
        color: #fff;
        font-size: 0.72rem;
        font-weight: 800;
        letter-spacing: 0.1em;
        text-transform: uppercase;
        box-shadow: 0 10px 22px color-mix(in srgb, var(--ods-accent, #4f9b63) 28%, transparent);
    }

    .landing-ods-head strong {
        font-family: "Poppins", "Space Grotesk", sans-serif;
        font-size: 0.96rem;
        line-height: 1.18;
        color: #102033;
    }

    .landing-ods-card p {
        position: relative;
        z-index: 1;
        margin: 0;
        font-size: 0.93rem;
        line-height: 1.55;
        color: #5e6b7e;
    }

    .landing-ods-card.ods-4 { --ods-accent: #c5192d; }
    .landing-ods-card.ods-6 { --ods-accent: #26bde2; }
    .landing-ods-card.ods-8 { --ods-accent: #8f1838; }
    .landing-ods-card.ods-10 { --ods-accent: #dd1367; }
    .landing-ods-card.ods-11 { --ods-accent: #f59d23; }
    .landing-ods-card.ods-12 { --ods-accent: #bf8b2e; }
    .landing-ods-card.ods-13 { --ods-accent: #3f7e44; }
    .landing-ods-card.ods-14 { --ods-accent: #0a97d9; }
    .landing-ods-card.ods-17 { --ods-accent: #19486a; }

    .landing-utility-row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        flex-wrap: wrap;
        margin-top: 0;
    }

    .public-actions-hero {
        align-items: center;
    }

    .public-actions-hero .badge-tempo-real {
        min-height: 48px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .landing-dashboard-toolbar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.9rem;
        flex-wrap: wrap;
        margin-top: 1rem;
    }

    .landing-utility-actions {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        flex-wrap: wrap;
    }

    .landing-scroll-link {
        color: rgba(255, 255, 255, 0.92);
        font-weight: 700;
        text-decoration: none;
    }

    .btn-public-refresh {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 44px;
        padding: 0.72rem 1rem;
        border-radius: 999px;
        border: 1px solid rgba(19, 71, 46, 0.16);
        background: rgba(255, 255, 255, 0.72);
        color: #124e34;
        font-weight: 700;
        font-size: 0.95rem;
        cursor: pointer;
        box-shadow: 0 12px 24px rgba(23, 90, 55, 0.12);
        transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
    }

    .btn-public-refresh:hover,
    .btn-public-refresh:focus-visible {
        transform: translateY(-1px);
        box-shadow: 0 16px 28px rgba(23, 90, 55, 0.16);
        outline: none;
    }

    .btn-public-refresh[disabled] {
        opacity: 0.72;
        cursor: wait;
    }

    .landing-section {
        margin-bottom: 1.3rem;
    }

    .landing-section-copy {
        margin: 0 0 1rem;
        color: #5e6b7e;
        line-height: 1.62;
        max-width: 72ch;
    }

    .landing-highlight-grid,
    .landing-gallery-grid,
    .landing-stories-grid,
    .landing-participation-grid,
    .landing-two-column,
    .landing-visual-grid {
        display: grid;
        gap: 1rem;
    }

    .landing-highlight-grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }

    .landing-highlight-card {
        padding: 1rem;
        border-radius: 1.2rem;
        border: 1px solid rgba(16, 40, 63, 0.08);
        background: rgba(255, 255, 255, 0.72);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
    }

    .landing-highlight-card strong {
        display: block;
        margin: 0.4rem 0 0.35rem;
        font-family: "Space Grotesk", monospace;
        font-size: clamp(1.55rem, 2.5vw, 2.1rem);
        letter-spacing: -0.05em;
        color: #102033;
    }

    .landing-highlight-card p {
        margin: 0;
        color: #5e6b7e;
        line-height: 1.55;
    }

    .landing-highlight-icon {
        display: inline-flex;
        width: 2.2rem;
        height: 2.2rem;
        align-items: center;
        justify-content: center;
        border-radius: 0.85rem;
        background: rgba(11, 122, 117, 0.1);
        color: #0d625b;
        font-size: 1.1rem;
    }

    .landing-visual-grid,
    .landing-two-column,
    .landing-participation-grid {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        align-items: stretch;
    }

    .landing-story-card,
    .landing-points-card,
    .landing-participation-card {
        display: grid;
        align-content: start;
        padding: 1.2rem;
        height: 100%;
    }

    .landing-point-list,
    .landing-faq-list,
    .landing-bullet-list {
        display: grid;
        gap: 0.8rem;
        align-items: stretch;
    }

    .landing-faq-list,
    .landing-bullet-list {
        grid-auto-rows: 1fr;
    }

    .landing-point-item,
    .landing-faq-item,
    .landing-bullet-item,
    .landing-explainer-card,
    .landing-club-card,
    .landing-daily-chart-card,
    .landing-participation-column {
        padding: 0.95rem 1rem;
        border-radius: 1rem;
        background: rgba(255, 255, 255, 0.72);
        border: 1px solid rgba(16, 40, 63, 0.08);
    }

    .landing-faq-item,
    .landing-bullet-item {
        min-height: 84px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .landing-participation-column {
        display: grid;
        align-content: start;
        gap: 0.8rem;
        height: 100%;
    }

    .landing-point-item strong,
    .landing-faq-item strong,
    .landing-gallery-copy strong,
    .landing-story-item h3 {
        color: #102033;
    }

    .landing-point-item p,
    .landing-faq-item p,
    .landing-explainer-card p,
    .landing-gallery-copy p,
    .landing-story-item p,
    .landing-club-card p,
    .landing-points-card > p {
        margin: 0.35rem 0 0;
        color: #5e6b7e;
        line-height: 1.65;
    }

    .landing-daily-chart-card {
        min-height: 0;
        display: grid;
        gap: 0.85rem;
    }

    .landing-chart-meta {
        margin: -0.2rem 0 0;
        font-size: 0.88rem;
        color: #5e6b7e;
    }

    .landing-daily-chart-frame {
        position: relative;
        height: 320px;
        min-height: 320px;
    }

    .landing-daily-chart-frame canvas {
        display: block;
        width: 100% !important;
        height: 100% !important;
        max-width: 100% !important;
        max-height: 100% !important;
    }

    .landing-stories-grid {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
        margin-top: 1rem;
        align-items: stretch;
    }

    .landing-story-item {
        display: grid;
        align-content: start;
        gap: 0.75rem;
        padding: 1rem;
        border-radius: 1.15rem;
        background: rgba(255, 255, 255, 0.72);
        border: 1px solid rgba(16, 40, 63, 0.08);
        height: 100%;
    }

    .landing-story-photo-wrap {
        aspect-ratio: 4 / 3;
        border-radius: 1rem;
        overflow: hidden;
    }

    .landing-story-meta {
        color: #0d625b;
    }

    .landing-gallery-grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
        align-items: stretch;
    }

    .landing-gallery-item {
        display: grid;
        align-content: start;
        overflow: hidden;
        border-radius: 1.15rem;
        background: rgba(255, 255, 255, 0.72);
        border: 1px solid rgba(16, 40, 63, 0.08);
        height: 100%;
    }

    .landing-gallery-photo {
        aspect-ratio: 4 / 3;
    }

    .landing-gallery-copy {
        padding: 0.95rem 1rem 1.05rem;
    }

    .landing-participation-cta {
        margin-top: 1rem;
        display: flex;
        justify-content: flex-start;
    }

    .footer-grid.landing-footer-grid {
        margin-bottom: 1rem !important;
    }

    @media (max-width: 960px) {
        .landing-hero-grid,
        .landing-visual-grid,
        .landing-two-column,
        .landing-participation-grid {
            grid-template-columns: 1fr;
        }

        .landing-hero-shell,
        .landing-story-card,
        .landing-points-card,
        .landing-participation-card {
            padding: 1.15rem;
        }

        .landing-hero-brand {
            width: 100%;
            justify-content: flex-start;
        }

        .landing-hero-visual {
            min-height: 280px;
        }

        .landing-utility-row,
        .landing-dashboard-toolbar,
        .landing-participation-cta {
            align-items: stretch;
        }

        .landing-utility-actions {
            width: 100%;
        }
    }

    @media (max-width: 640px) {
        .landing-highlight-grid,
        .landing-gallery-grid,
        .landing-stories-grid {
            grid-template-columns: 1fr;
        }

        .landing-ods-stage {
            grid-template-columns: 1fr;
            justify-items: start;
        }

        .landing-ods-mosaic {
            min-width: 0;
            margin: 0 auto;
            grid-template-columns: repeat(3, minmax(3rem, 3.1rem));
            grid-auto-rows: minmax(3rem, 3.1rem);
            gap: 0.45rem;
        }

        .landing-ods-mosaic-tile {
            width: 3.1rem;
            height: 3.1rem;
            border-radius: 0.9rem;
        }

        .landing-ods-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .landing-hero-copy h1 {
            font-size: clamp(1.65rem, 8vw, 2.35rem);
            line-height: 1.12;
        }

        .btn-public-refresh {
            width: 100%;
        }

        .landing-daily-chart-frame {
            height: 260px;
            min-height: 260px;
        }
    }

    .public-kpi-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 1.5rem;
        margin: 2rem 0;
        align-items: stretch;
    }

    .public-actions {
        display: flex;
        gap: 0.75rem;
        flex-wrap: wrap;
    }

    .btn-public-calc {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0.75rem 1.15rem;
        border-radius: 999px;
        text-decoration: none;
        font-weight: 700;
        letter-spacing: 0.01em;
        border: 1px solid rgba(255, 255, 255, 0.25);
        color: #fff;
        background: linear-gradient(135deg, #0b7a75 0%, #17a39a 100%);
        box-shadow: 0 8px 20px rgba(11, 122, 117, 0.28);
        transition: transform .2s ease, box-shadow .2s ease;
    }

    .btn-public-calc:hover {
        transform: translateY(-1px);
        box-shadow: 0 12px 24px rgba(11, 122, 117, 0.32);
    }

    .edu-simulator {
        background: linear-gradient(145deg, #0f172a 0%, #0b3b4c 45%, #166534 100%);
        border-radius: 1rem;
        margin: 0.5rem 0 2.25rem;
        padding: 1.5rem;
        color: #fff;
        border: 1px solid rgba(255, 255, 255, 0.14);
        box-shadow: 0 16px 30px rgba(15, 23, 42, 0.35);
    }

    .edu-simulator-header h3 {
        margin: 0 0 0.5rem;
        font-size: clamp(1.2rem, 3vw, 1.8rem);
        line-height: 1.2;
    }

    .edu-eyebrow {
        margin: 0 0 0.45rem;
        font-size: 0.8rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: rgba(186, 230, 253, 0.95);
    }

    .edu-description {
        margin: 0;
        color: rgba(240, 253, 244, 0.92);
        max-width: 820px;
    }

    .edu-simulator-grid {
        margin-top: 1.25rem;
        display: grid;
        grid-template-columns: 1.2fr 1fr;
        gap: 1rem;
    }

    .edu-inputs {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    .edu-field {
        display: flex;
        flex-direction: column;
        gap: 0.4rem;
        background: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.2);
        border-radius: 0.75rem;
        padding: 0.75rem;
    }

    .edu-field span {
        font-size: 0.85rem;
        font-weight: 600;
        color: rgba(255, 255, 255, 0.9);
    }

    .edu-field input {
        width: 100%;
        border: 1px solid rgba(255, 255, 255, 0.28);
        border-radius: 0.55rem;
        background: rgba(2, 6, 23, 0.35);
        color: #fff;
        padding: 0.6rem 0.7rem;
        font-size: 1rem;
    }

    .edu-field input:focus {
        outline: 2px solid rgba(125, 211, 252, 0.45);
        outline-offset: 2px;
    }

    .edu-results {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    .edu-result-card {
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.2);
        border-radius: 0.75rem;
        padding: 0.85rem;
    }

    .edu-result-card p {
        margin: 0 0 0.45rem;
        font-size: 0.82rem;
        font-weight: 600;
        color: rgba(226, 232, 240, 0.94);
    }

    .edu-result-card strong {
        font-size: clamp(1rem, 2.4vw, 1.45rem);
        line-height: 1.15;
    }

    .edu-simulator-note {
        grid-column: 1 / -1;
        margin-top: 0.2rem;
        font-size: 0.82rem;
        color: rgba(226, 232, 240, 0.9);
    }

    .stats-sub {
        font-size: 0.8125rem;
        color: var(--olinda-muted);
        margin-top: 0.25rem;
        font-weight: 600;
    }

    .eventos-consolidacao-msg {
        font-size: 0.9375rem;
        line-height: 1.5;
        color: var(--olinda-muted);
        background: var(--gray-50);
        border: 1px dashed var(--olinda-border);
        border-radius: 0.75rem;
        padding: 1rem;
        margin: 1.25rem 0;
    }

    .impacto-card {
        background: var(--olinda-white);
        border-radius: 1rem;
        padding: 2rem;
        box-shadow: var(--shadow-soft);
        transition: all 0.3s ease;
        border: 2px solid var(--olinda-border);
        text-align: center;
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        min-height: 280px;
    }

    .impacto-card-link {
        text-decoration: none;
        color: inherit;
        display: block;
        width: 100%;
        text-align: left;
        background: none;
        border: none;
        padding: 0;
        cursor: pointer;
        height: 100%;
    }

    .impacto-card:hover {
        box-shadow: var(--shadow-hover);
        transform: translateY(-2px);
    }

    .impacto-card.blue {
        border-color: var(--olinda-blue);
        background: linear-gradient(135deg, var(--olinda-blue) 0%, var(--olinda-blue-dark) 100%);
        color: white;
    }

    .impacto-card.green {
        border-color: var(--olinda-green);
        background: linear-gradient(135deg, var(--olinda-green) 0%, var(--olinda-green-dark) 100%);
        color: white;
    }

    .impacto-card.orange {
        border-color: var(--olinda-orange);
        background: linear-gradient(135deg, var(--olinda-orange) 0%, var(--olinda-orange-dark) 100%);
        color: white;
    }

    .impacto-card.cyan {
        border-color: var(--carnaval-cyan);
        background: linear-gradient(135deg, var(--carnaval-cyan) 0%, var(--carnaval-blue) 100%);
        color: white;
    }

    .impacto-card.purple {
        border-color: var(--carnaval-purple);
        background: linear-gradient(135deg, var(--carnaval-purple) 0%, var(--carnaval-pink) 100%);
        color: white;
    }

    .impacto-icon {
        font-size: 3rem;
        margin-bottom: 1rem;
        display: block;
    }

    .impacto-label {
        font-size: 0.875rem;
        opacity: 0.9;
        margin-bottom: 0.75rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .impacto-value {
        font-size: 2.5rem;
        font-weight: 800;
        margin-bottom: 0.5rem;
        line-height: 1.2;
    }

    .impacto-unit {
        font-size: 1.25rem;
        opacity: 0.9;
        font-weight: 600;
    }

    .impacto-secondary {
        font-size: 1rem;
        opacity: 0.8;
        margin-top: 0.5rem;
    }

    .impacto-modal-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.55);
        display: none;
        align-items: center;
        justify-content: center;
        z-index: 2000;
        padding: 1.5rem;
    }

    .impacto-modal {
        background: #fff;
        border-radius: 1rem;
        max-width: 600px;
        width: 100%;
        padding: 2rem;
        box-shadow: var(--shadow-lg);
        position: relative;
        max-height: 85vh;
        overflow-y: auto;
    }

    .impacto-modal h4 {
        font-size: 1.25rem;
        font-weight: 800;
        margin-bottom: 0.75rem;
    }

    .impacto-modal p {
        font-size: 1rem;
        color: var(--olinda-text);
        line-height: 1.7;
        margin-bottom: 1rem;
        text-align: justify;
    }
    
    .impacto-modal p:last-child {
        margin-bottom: 0;
    }
    
    .impacto-modal p strong {
        color: var(--olinda-blue);
        font-weight: 700;
    }

    .impacto-modal-close {
        position: absolute;
        top: 0.75rem;
        right: 0.75rem;
        background: transparent;
        border: none;
        font-size: 1.25rem;
        cursor: pointer;
        color: var(--olinda-muted);
    }

    @media (max-width: 768px) {
        .public-actions {
            width: 100%;
        }

        .public-actions .btn-primary,
        .public-actions .btn-public-calc {
            flex: 1 1 100%;
            text-align: center;
        }

        .edu-simulator {
            padding: 1rem;
        }

        .edu-simulator-grid {
            grid-template-columns: 1fr;
        }

        .edu-inputs,
        .edu-results {
            grid-template-columns: 1fr;
        }

        .impacto-card {
            padding: 1.5rem;
        }

        .impacto-value {
            font-size: 2rem;
        }

        .impacto-icon {
            font-size: 2.5rem;
        }
    }
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

.public-page {
    --public-bg: #edf8ee;
    --public-surface: rgba(248, 253, 248, 0.96);
    --public-panel: #0f4a35;
    --public-text: #17362a;
    --public-muted: #5f776a;
    --public-blue: #2c8b57;
    --public-teal: #4db56c;
    --public-orange: #8ecf4d;
    --public-yellow: #d9f08b;
    --public-pink: #6fbe7a;
    --public-purple: #235f43;
    --mat-papelao: #3d7e55;
    --mat-plastico: #5f9b5a;
    --mat-latinha: #a9bc5a;
    --mat-pet: #4ea66b;
    --mat-oleo: #859749;
    --mat-vidro: #246a4a;
    background:
        radial-gradient(circle at top left, rgba(104, 195, 120, 0.16), transparent 34%),
        radial-gradient(circle at top right, rgba(182, 224, 110, 0.14), transparent 28%),
        linear-gradient(180deg, #f5fbf4 0%, #eaf4e8 100%) !important;
}

.public-page .hero-banner {
    background:
        radial-gradient(circle at top right, rgba(224, 245, 132, 0.18), transparent 22%),
        linear-gradient(140deg, #0f4a35 0%, #186548 52%, #3b9660 100%) !important;
}

.public-page .hero-banner h1 {
    font-size: clamp(1.95rem, 3.4vw, 3.1rem) !important;
    letter-spacing: -0.04em !important;
}

.public-page .hero-subtitle {
    max-width: 60ch !important;
    font-size: clamp(0.96rem, 1.25vw, 1.05rem) !important;
    line-height: 1.6 !important;
}

.public-page .section-title {
    align-items: center !important;
    gap: 0.65rem !important;
    margin-bottom: 0.95rem !important;
}

.public-page .section-title h2 {
    font-size: clamp(1.35rem, 2.3vw, 2rem) !important;
    letter-spacing: -0.03em !important;
}

.public-page .section-title .second {
    background: linear-gradient(135deg, #1f7c4f, #3da56a) !important;
    padding: 0.16rem 0.58rem !important;
}

.section-title-dot.blue {
    background: #2d7c53 !important;
}

.section-title-dot.yellow {
    background: #6fb264 !important;
}

.section-title-dot.magenta {
    background: #b6d66b !important;
}

.badge-tempo-real {
    background: rgba(14, 61, 43, 0.92) !important;
}

.public-actions .btn-primary,
.btn-public-calc {
    min-height: 44px !important;
    padding: 0.78rem 1.1rem !important;
    font-size: 0.92rem !important;
}

.btn-public-calc {
    background: linear-gradient(135deg, #3fae64, #79c252) !important;
}

.public-actions .btn-primary {
    background: #0d4731 !important;
}

.public-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0.9rem !important;
}

.public-kpi-grid .stats-card,
.chart-card,
.event-card {
    background: linear-gradient(180deg, rgba(250, 254, 249, 0.98), rgba(241, 248, 239, 0.92)) !important;
    box-shadow: 0 16px 34px rgba(26, 72, 46, 0.09) !important;
}

.public-kpi-grid .stats-card {
    padding: 1.05rem !important;
    border-radius: 1.15rem !important;
    min-height: 196px !important;
}

.public-kpi-grid .card-border-orange {
    border-top-color: #8ebe62 !important;
}

.public-kpi-grid .card-border-blue {
    border-top-color: #2e7c53 !important;
}

.public-kpi-grid .card-border-green {
    border-top-color: #4ea66b !important;
}

.public-kpi-grid .card-border-yellow {
    border-top-color: #b6d66b !important;
}

.public-kpi-grid .stats-icon {
    width: 2.55rem !important;
    height: 2.55rem !important;
    min-width: 2.55rem !important;
    border-radius: 0.85rem !important;
}

.public-kpi-grid .stats-label {
    font-size: 0.72rem !important;
    letter-spacing: 0.1em !important;
}

.public-kpi-grid .stats-value {
    font-size: clamp(1.55rem, 2vw, 2.05rem) !important;
}

.public-kpi-grid .stats-value small {
    font-size: 0.74rem !important;
    padding-bottom: 0.2rem !important;
}

.stats-sub {
    margin-top: 0.25rem !important;
    font-size: 0.82rem !important;
    line-height: 1.45 !important;
}

#public-impacto-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0.9rem !important;
    align-items: stretch !important;
}

#public-impacto-cards > .impacto-card-link {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 100% !important;
    margin: 0 !important;
}

#public-impacto-cards > .impacto-card-link > .impacto-card {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    grid-template-areas:
        "icon label"
        "value value"
        "support support"
        "meta meta" !important;
    align-content: start !important;
    gap: 0.55rem 0.72rem !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 100% !important;
    min-height: 226px !important;
    padding: 1.08rem !important;
    border-radius: 1.2rem !important;
    background: linear-gradient(180deg, rgba(15, 60, 42, 0.98), rgba(16, 74, 51, 0.95)) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 16px 34px rgba(19, 71, 46, 0.16) !important;
}

.impacto-card::before {
    background:
        radial-gradient(circle at top right, var(--card-glow, rgba(67, 187, 109, 0.24)), transparent 42%),
        linear-gradient(150deg, rgba(255, 255, 255, 0.08), transparent 58%) !important;
}

.impacto-card.blue {
    --card-glow: rgba(104, 207, 128, 0.24);
}

.impacto-card.green {
    --card-glow: rgba(130, 219, 145, 0.25);
}

.impacto-card.orange {
    --card-glow: rgba(204, 231, 123, 0.22);
}

.impacto-card.cyan {
    --card-glow: rgba(79, 192, 152, 0.24);
}

.impacto-card.purple,
#card-pet-oceano {
    --card-glow: rgba(109, 197, 120, 0.26);
}

.impacto-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 20px 40px rgba(19, 71, 46, 0.18) !important;
}

.impacto-icon {
    grid-area: icon !important;
    width: 2.35rem !important;
    height: 2.35rem !important;
    border-radius: 0.82rem !important;
    font-size: 1.05rem !important;
}

.impacto-label {
    grid-area: label !important;
    align-self: center !important;
    font-size: 0.73rem !important;
    line-height: 1.35 !important;
    letter-spacing: 0.08em !important;
}

.impacto-value {
    grid-area: value !important;
    font-size: clamp(1.55rem, 2.1vw, 2.08rem) !important;
    line-height: 1.02 !important;
}

.impacto-unit {
    grid-area: meta !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.12em !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

.impacto-secondary {
    grid-area: support !important;
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
    color: rgba(242, 250, 244, 0.84) !important;
}

.impacto-card .impacto-secondary + .impacto-secondary {
    display: none !important;
}

#card-pet-oceano .impacto-value {
    font-size: clamp(1.42rem, 1.95vw, 1.88rem) !important;
}

.chart-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0.9rem !important;
}

.chart-card {
    padding: 1.1rem !important;
    border-radius: 1.15rem !important;
}

.chart-card::before {
    background: linear-gradient(90deg, #2e7c53, #63ae63) !important;
}

.chart-grid > .chart-card:nth-child(1)::before {
    background: linear-gradient(90deg, #4b9760, #a9bc5a) !important;
}

.chart-grid > .chart-card:nth-child(3)::before {
    background: linear-gradient(90deg, #285f44, #5f9b5a) !important;
}

.chart-card .stats-label {
    font-size: 0.72rem !important;
}

.chart-card .stats-value {
    font-size: 1.6rem !important;
}

.chart-card .stats-value small {
    font-size: 0.72rem !important;
}

.chart-card canvas {
    max-width: 188px !important;
    max-height: 188px !important;
}

.chart-legend-item {
    padding: 0.48rem 0.64rem !important;
    border-radius: 0.82rem !important;
}

.chart-legend .material {
    font-size: 0.84rem !important;
}

.chart-legend .value {
    font-size: 0.79rem !important;
}

.public-events-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.9rem !important;
}

.event-card {
    padding: 1.08rem !important;
    border-radius: 1.15rem !important;
}

.event-card-header strong {
    font-size: 0.98rem !important;
}

.event-badge {
    min-height: 24px !important;
    padding: 0.28rem 0.7rem !important;
    font-size: 0.67rem !important;
}

.event-badge.ativo {
    background: rgba(78, 166, 107, 0.16) !important;
    color: #245a3f !important;
    border: 1px solid rgba(78, 166, 107, 0.26) !important;
}

.event-badge.aguardando {
    background: rgba(169, 188, 90, 0.18) !important;
    color: #506333 !important;
    border: 1px solid rgba(169, 188, 90, 0.26) !important;
}

.event-total {
    font-size: 1.52rem !important;
    margin-bottom: 0.68rem !important;
}

.event-bar-head span {
    font-size: 0.82rem !important;
}

.event-bar-head strong {
    font-size: 0.76rem !important;
}

.bar {
    height: 0.48rem !important;
}

.edu-simulator {
    position: relative;
    overflow: hidden;
    padding: 1.35rem !important;
    border-radius: 1.25rem !important;
    background:
        radial-gradient(circle at top right, rgba(184, 232, 118, 0.2), transparent 30%),
        linear-gradient(145deg, #103f2f 0%, #165540 46%, #2f7a52 100%) !important;
}

.edu-simulator::before {
    content: "";
    position: absolute;
    inset: -30% auto auto -6%;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
}

.edu-simulator::after {
    content: "";
    position: absolute;
    right: -40px;
    bottom: -40px;
    width: 160px;
    height: 160px;
    border-radius: 50%;
    background: rgba(179, 232, 118, 0.12);
}

.edu-simulator > * {
    position: relative;
    z-index: 1;
}

.edu-simulator-header h3 {
    font-size: clamp(1.18rem, 2vw, 1.52rem) !important;
    line-height: 1.15 !important;
}

.edu-description {
    font-size: 0.94rem !important;
    line-height: 1.6 !important;
}

.edu-simulator-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
    gap: 0.9rem !important;
    align-items: start;
}

.edu-inputs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.74rem !important;
}

.edu-field,
.edu-result-card,
.edu-simulator-note {
    border-radius: 0.95rem !important;
}

.edu-field {
    padding: 0.78rem !important;
}

.edu-field span {
    font-size: 0.78rem !important;
}

.edu-field input {
    min-height: 42px !important;
    font-size: 0.95rem !important;
}

.edu-field small {
    display: block;
    margin-top: 0.15rem;
    font-size: 0.74rem;
    line-height: 1.45;
    color: rgba(236, 255, 242, 0.72);
}

.edu-results {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.74rem !important;
}

.edu-result-card {
    min-height: 124px;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    padding: 0.9rem !important;
    background: rgba(248, 255, 248, 0.12) !important;
}

.edu-result-card p {
    font-size: 0.73rem !important;
    letter-spacing: 0.04em !important;
    color: rgba(241, 255, 246, 0.78) !important;
}

.edu-result-card strong {
    font-size: clamp(1.02rem, 1.7vw, 1.34rem) !important;
    line-height: 1.15 !important;
}

.edu-result-card span {
    font-size: 0.78rem !important;
    line-height: 1.4 !important;
    color: rgba(236, 255, 242, 0.82) !important;
}

.edu-simulator-note {
    margin-top: 0.1rem;
    padding: 0.84rem !important;
    font-size: 0.81rem !important;
    line-height: 1.55 !important;
    background: rgba(8, 31, 22, 0.36) !important;
}

@media (max-width: 1180px) {
    .public-kpi-grid,
    #public-impacto-cards,
    .chart-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .public-events-grid,
    .edu-simulator-grid {
        grid-template-columns: 1fr !important;
    }

    .edu-results {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 768px) {
    .public-page .hero-banner h1 {
        font-size: clamp(1.7rem, 7vw, 2.35rem) !important;
    }

    .public-kpi-grid,
    #public-impacto-cards,
    .chart-grid,
    .public-events-grid,
    .edu-inputs,
    .edu-results {
        grid-template-columns: 1fr !important;
    }

    #public-impacto-cards > .impacto-card-link > .impacto-card {
        min-height: 0 !important;
    }

    .edu-simulator {
        padding: 1.12rem !important;
    }

}

.landing-tabs-shell {
    display: grid;
    gap: 1rem;
    padding: 1.2rem 1.3rem;
    border-radius: 1.35rem;
    border: 1px solid rgba(19, 71, 46, 0.1);
    background: linear-gradient(180deg, rgba(250, 254, 249, 0.98), rgba(241, 248, 239, 0.92));
    box-shadow: 0 16px 34px rgba(26, 72, 46, 0.09);
}

.landing-tab-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.landing-tab-button {
    min-height: 52px;
    padding: 0.85rem 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(31, 102, 64, 0.12);
    background: rgba(255, 255, 255, 0.7);
    color: var(--public-text);
    font-family: inherit;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.3;
    box-shadow: 0 10px 24px rgba(26, 72, 46, 0.05);
    cursor: pointer;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease, color 0.22s ease;
}

.landing-tab-button:hover,
.landing-tab-button:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(46, 124, 83, 0.3);
    box-shadow: 0 14px 28px rgba(26, 72, 46, 0.1);
    outline: none;
}

.landing-tab-button.is-active {
    color: #f7fff7;
    border-color: rgba(255, 255, 255, 0.16);
    background: linear-gradient(135deg, #1f7c4f, #53ab65);
    box-shadow: 0 16px 30px rgba(31, 124, 79, 0.22);
}

.tab-section {
    animation: landingTabEnter 0.32s ease both;
}

.public-page[data-active-tab="dashboard"] .tab-section[data-tab-panel]:not([data-tab-panel="dashboard"]),
.public-page[data-active-tab="educacao"] .tab-section[data-tab-panel]:not([data-tab-panel="educacao"]),
.public-page[data-active-tab="historias"] .tab-section[data-tab-panel]:not([data-tab-panel="historias"]),
.public-page[data-active-tab="participacao"] .tab-section[data-tab-panel]:not([data-tab-panel="participacao"]) {
    display: none !important;
}

.landing-resource-list {
    display: grid;
    gap: 0.75rem;
}

.landing-resource-list a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 0.8rem 0.95rem;
    border-radius: 0.95rem;
    text-decoration: none;
    font-weight: 600;
    color: var(--public-text);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(19, 71, 46, 0.08);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.landing-resource-list a:hover,
.landing-resource-list a:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(46, 124, 83, 0.22);
    box-shadow: 0 12px 24px rgba(26, 72, 46, 0.08);
    outline: none;
}

@keyframes landingTabEnter {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 960px) {
    .landing-tab-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .landing-tabs-shell {
        padding: 1rem;
    }

    .landing-tab-list {
        grid-template-columns: 1fr;
    }
}

.public-page {
    --public-bg: #eef7ee;
    --public-surface: rgba(247, 252, 247, 0.97);
    --public-panel: #113b2c;
    --public-text: #18382a;
    --public-muted: #607668;
    --public-blue: #2f7d58;
    --public-teal: #58a56d;
    --public-orange: #7eb85b;
    --public-yellow: #b9d86f;
    --public-pink: #3f8e5e;
    --public-purple: #255e42;
    --mat-papelao: #3a7450;
    --mat-plastico: #5b9759;
    --mat-latinha: #a7ba5a;
    --mat-pet: #4b9c64;
    --mat-oleo: #7d9447;
    --mat-vidro: #255f43;
    background:
        radial-gradient(circle at top left, rgba(96, 165, 84, 0.14), transparent 34%),
        radial-gradient(circle at top right, rgba(185, 216, 111, 0.14), transparent 28%),
        linear-gradient(180deg, #f5fbf4 0%, #eaf4e8 100%) !important;
    color: var(--public-text);
}

.landing-hero-shell {
    background:
        radial-gradient(circle at top right, rgba(185, 216, 111, 0.16), transparent 28%),
        radial-gradient(circle at bottom left, rgba(88, 165, 109, 0.14), transparent 30%),
        linear-gradient(180deg, rgba(15, 60, 42, 0.98), rgba(18, 78, 53, 0.95)) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 24px 44px rgba(17, 59, 44, 0.2) !important;
}

.public-sponsors-bar img,
.partner-logo {
    opacity: 1 !important;
    filter: none !important;
    mix-blend-mode: normal !important;
}

.landing-hero-badge {
    background: rgba(185, 216, 111, 0.14) !important;
    border: 1px solid rgba(185, 216, 111, 0.2);
    color: rgba(246, 255, 247, 0.92) !important;
}

.landing-hero-impact {
    background: rgba(255, 255, 255, 0.08) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.landing-hero-copy h1,
.landing-hero-impact-main strong {
    color: #ffffff !important;
}

.hero-subtitle,
.landing-hero-impact-main span,
.landing-hero-impact p,
.landing-scroll-link {
    color: rgba(241, 255, 245, 0.86) !important;
}

.landing-hero-visual {
    background: linear-gradient(180deg, rgba(17, 59, 44, 0.26), rgba(18, 78, 53, 0.16)) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.landing-hero-placeholder {
    background:
        radial-gradient(circle at top left, rgba(185, 216, 111, 0.18), transparent 32%),
        linear-gradient(180deg, rgba(15, 60, 42, 0.78), rgba(18, 78, 53, 0.58)) !important;
}

.landing-hero-placeholder-chip {
    background: rgba(255, 255, 255, 0.12) !important;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.landing-hero-grid {
    grid-template-columns: minmax(0, 0.98fr) minmax(380px, 0.88fr) !important;
    gap: clamp(1rem, 2vw, 1.6rem) !important;
    align-items: stretch !important;
}

.landing-hero-copy {
    display: grid !important;
    align-content: start !important;
    gap: 0.7rem !important;
    max-width: 44rem !important;
    min-height: 100%;
}

.landing-hero-shell {
    padding: 1.3rem !important;
}

.landing-hero-brand {
    width: fit-content;
    max-width: 100%;
    margin-bottom: 0.1rem !important;
    padding: 0.4rem 0.65rem !important;
    border-radius: 1rem !important;
}

.landing-hero-brand-copy {
    gap: 0.2rem !important;
}

.landing-hero-brand-copy span {
    letter-spacing: 0.08em !important;
}

.landing-hero-brand-copy strong {
    font-size: 0.98rem !important;
}

.landing-hero-badge {
    width: fit-content;
    margin-top: 0.15rem;
    font-size: 0.72rem !important;
    letter-spacing: 0.08em !important;
}

.landing-hero-copy h1 {
    margin: 0 !important;
    max-width: 17ch;
    font-size: clamp(1.9rem, 3vw, 2.85rem) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.045em !important;
    text-align: left !important;
    text-wrap: balance;
}

.landing-hero-copy .hero-subtitle {
    margin: 0 !important;
    max-width: 58ch !important;
    font-size: clamp(0.96rem, 1.15vw, 1.03rem) !important;
    line-height: 1.52 !important;
    text-align: left !important;
    text-wrap: pretty;
}

.landing-hero-impact {
    max-width: 35rem;
    margin: 0.2rem 0 0.1rem !important;
    padding: 0.82rem 0.92rem !important;
    gap: 0.28rem !important;
}

.landing-hero-impact-main {
    gap: 0.28rem !important;
}

.landing-hero-impact-main strong {
    font-size: clamp(1.8rem, 2.6vw, 2.55rem) !important;
}

.landing-hero-impact p {
    max-width: 42ch;
    line-height: 1.48 !important;
}

.public-actions-hero {
    gap: 0.55rem !important;
    margin-top: auto;
    padding-top: 0.5rem;
}

.landing-hero-visual {
    width: 100%;
    max-width: none;
    min-height: clamp(360px, 38vw, 540px) !important;
    height: 100%;
    align-self: stretch !important;
    justify-self: stretch !important;
}

.landing-hero-placeholder {
    align-content: flex-start !important;
    justify-content: flex-start !important;
    text-align: left !important;
    gap: 0.6rem !important;
    min-height: clamp(360px, 38vw, 540px) !important;
    padding: 0.95rem !important;
    padding-bottom: 0.95rem !important;
}

.landing-hero-image {
    object-position: center center;
}

.landing-hero-placeholder strong {
    margin-top: 0.15rem;
    font-size: 0.96rem !important;
    line-height: 1.22 !important;
}

.landing-hero-placeholder p {
    max-width: 30ch;
    font-size: 0.88rem;
    line-height: 1.45 !important;
}

@media (max-width: 960px) {
    .landing-hero-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
    }

    .landing-hero-copy {
        max-width: none !important;
    }

    .landing-hero-copy h1 {
        max-width: 13.5ch;
        font-size: clamp(1.8rem, 7vw, 2.55rem) !important;
    }

    .landing-hero-impact,
    .landing-hero-placeholder p {
        max-width: none;
    }

    .landing-hero-visual {
        width: 100%;
        min-height: 260px !important;
        height: auto;
        justify-self: stretch !important;
    }

    .landing-ods-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .landing-hero-shell {
        padding: 0.95rem !important;
    }

    .landing-hero-brand {
        width: 100%;
    }

    .landing-hero-copy h1 {
        max-width: 12.4ch;
        line-height: 0.98 !important;
    }

    .landing-hero-visual {
        min-height: 220px !important;
    }

    .public-actions-hero {
        width: 100%;
    }

    .public-actions-hero .btn-primary,
    .public-actions-hero .btn-public-calc,
    .public-actions-hero .badge-tempo-real {
        width: 100%;
        justify-content: center;
    }

    .landing-ods-grid {
        grid-template-columns: 1fr;
    }
}

.public-page-shell {
    padding-top: 2rem;
}

.section-title-compact {
    margin-bottom: 1rem !important;
}

.section-title-top {
    margin-top: 2rem !important;
}

.section-title-spaced {
    margin: 2rem 0 1.5rem !important;
}

.public-impact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
    align-items: stretch;
}

.chart-grid-public {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
    margin-bottom: 2rem !important;
}

.chart-card-public {
    text-align: center;
}

.chart-card-label {
    margin-bottom: 0.75rem !important;
    font-size: 0.875rem !important;
}

.chart-card-value {
    margin-top: 0.5rem !important;
    font-size: 1.25rem !important;
}

.chart-card-unit {
    font-size: 0.75rem !important;
}

.chart-card-legend {
    margin-top: 0.75rem !important;
}

.public-events-grid-spaced {
    margin-top: 1.5rem !important;
}

.public-sponsor-image {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.landing-story-card,
.landing-points-card,
.landing-participation-card,
.landing-highlight-card,
.landing-point-item,
.landing-faq-item,
.landing-bullet-item,
.landing-explainer-card,
.landing-club-card,
.landing-daily-chart-card,
.landing-participation-column,
.landing-story-item,
.landing-gallery-item,
.landing-tabs-shell,
.public-kpi-grid .stats-card,
.chart-card,
.event-card {
    background: linear-gradient(180deg, rgba(250, 254, 249, 0.98), rgba(241, 248, 239, 0.92)) !important;
    border-color: rgba(19, 71, 46, 0.1) !important;
    box-shadow: 0 16px 34px rgba(26, 72, 46, 0.09) !important;
}

.public-kpi-grid {
    gap: 1.1rem !important;
    margin: 1.35rem 0 1.15rem !important;
}

.public-kpi-grid .stats-card,
.chart-card,
.event-card,
.landing-tabs-shell,
.landing-story-card,
.landing-points-card,
.landing-participation-card,
.landing-highlight-card,
.landing-point-item,
.landing-faq-item,
.landing-bullet-item,
.landing-explainer-card,
.landing-club-card,
.landing-daily-chart-card,
.landing-participation-column,
.landing-story-item {
    padding: 1.05rem !important;
}

.landing-faq-list,
.landing-bullet-list {
    grid-auto-rows: 1fr !important;
}

.landing-faq-item,
.landing-bullet-item {
    min-height: 84px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.landing-participation-column,
.landing-story-card,
.landing-points-card,
.landing-participation-card,
.landing-story-item,
.landing-gallery-item {
    display: grid !important;
    align-content: start !important;
    height: 100%;
}

.landing-participation-column {
    gap: 0.8rem !important;
}

.landing-highlight-icon {
    background: rgba(47, 125, 88, 0.1) !important;
    color: #1f6947 !important;
}

.landing-mini-title,
.landing-story-meta {
    color: #246345 !important;
}

.public-page .section-title .second {
    background: linear-gradient(135deg, #215f43, #4f9b63) !important;
    color: #ffffff !important;
}

.section-title-dot.blue {
    background: #2f7d58 !important;
}

.section-title-dot.yellow {
    background: #6faa60 !important;
}

.section-title-dot.magenta {
    background: #b9d86f !important;
}

.badge-tempo-real {
    background: rgba(16, 61, 43, 0.95) !important;
}

.btn-public-refresh {
    background: rgba(247, 255, 247, 0.9) !important;
    border-color: rgba(255, 255, 255, 0.16) !important;
    color: #154d35 !important;
}

.btn-public-refresh.is-loading {
    opacity: 0.82 !important;
}

.btn-public-refresh.is-success {
    background: linear-gradient(135deg, #1f6a47, #3f9b63) !important;
    border-color: rgba(20, 77, 53, 0.28) !important;
    color: #f7fff7 !important;
    box-shadow: 0 14px 28px rgba(23, 90, 55, 0.22) !important;
}

.btn-public-calc {
    background: linear-gradient(135deg, #3d9b61, #79bf5d) !important;
    border-color: rgba(255, 255, 255, 0.18) !important;
    box-shadow: 0 12px 24px rgba(23, 90, 55, 0.25) !important;
}

.public-actions .btn-primary {
    background: #123c2c !important;
}

.public-kpi-grid .stats-icon {
    background: rgba(47, 125, 88, 0.09) !important;
    color: #1c5b3e !important;
}

.public-kpi-grid .card-border-orange {
    border-top-color: #7eb85b !important;
}

.public-kpi-grid .card-border-blue {
    border-top-color: #2f7d58 !important;
}

.public-kpi-grid .card-border-green {
    border-top-color: #58a56d !important;
}

.public-kpi-grid .card-border-yellow {
    border-top-color: #b9d86f !important;
}

#public-impacto-cards > .impacto-card-link > .impacto-card {
    background: linear-gradient(180deg, rgba(15, 60, 42, 0.98), rgba(18, 78, 53, 0.95)) !important;
    box-shadow: 0 18px 36px rgba(17, 59, 44, 0.18) !important;
}

.impacto-card.blue {
    --card-glow: rgba(94, 183, 110, 0.24);
}

.impacto-card.green {
    --card-glow: rgba(126, 188, 96, 0.23);
}

.impacto-card.orange {
    --card-glow: rgba(171, 210, 103, 0.22);
}

.impacto-card.cyan {
    --card-glow: rgba(73, 162, 103, 0.24);
}

.impacto-card.purple,
#card-pet-oceano {
    --card-glow: rgba(126, 188, 96, 0.25);
}

.chart-card::before {
    background: linear-gradient(90deg, #2f7d58, #6faa60) !important;
}

.chart-grid > .chart-card:nth-child(1)::before {
    background: linear-gradient(90deg, #4b9760, #a7ba5a) !important;
}

.chart-grid > .chart-card:nth-child(3)::before {
    background: linear-gradient(90deg, #245e42, #5b9759) !important;
}

.event-badge.ativo {
    background: rgba(78, 166, 107, 0.16) !important;
    color: #255a3f !important;
    border-color: rgba(78, 166, 107, 0.26) !important;
}

.event-badge.aguardando {
    background: rgba(169, 188, 90, 0.18) !important;
    color: #536633 !important;
    border-color: rgba(169, 188, 90, 0.26) !important;
}

.edu-simulator {
    background:
        radial-gradient(circle at top right, rgba(190, 224, 116, 0.2), transparent 30%),
        linear-gradient(145deg, #103f2f 0%, #15523d 48%, #2f7d58 100%) !important;
    box-shadow: 0 24px 48px rgba(17, 59, 44, 0.18) !important;
}

.edu-eyebrow {
    color: rgba(225, 245, 221, 0.92) !important;
}

.edu-field input:focus {
    outline: 2px solid rgba(185, 216, 111, 0.55) !important;
    border-color: rgba(185, 216, 111, 0.4) !important;
}

.impacto-modal p strong {
    color: #2f7d58 !important;
}

.public-sponsors-bar {
    padding: 0.35rem !important;
    background: linear-gradient(180deg, #ffffff, #f6fbf4) !important;
    border: 1px solid rgba(19, 71, 46, 0.1) !important;
    box-shadow: 0 14px 28px rgba(26, 72, 46, 0.08) !important;
}

.footer.public-footer {
    background: transparent !important;
    border-top: 1px solid rgba(255, 255, 255, 0.16);
    border-left: none;
    border-right: none;
    border-bottom: none;
    padding: 0;
}

.footer.public-footer.minimal-footer {
    padding: 0.25rem 0 !important;
}

.footer.public-footer.minimal-footer .minimal-footer-line {
    margin: 0;
    padding: 0;
    text-align: center;
    font-size: 0.9rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.78);
    letter-spacing: 0.08em;
}

.footer.public-footer.minimal-footer .container {
    padding: 0;
}

/* Consolidated layout fixes */
.public-page-shell {
    padding-top: 0 !important;
}

.landing-highlight-grid,
.landing-ods-grid,
.landing-gallery-grid,
.landing-stories-grid,
.landing-participation-grid {
    align-items: stretch;
    grid-auto-rows: 1fr;
}

.landing-highlight-card,
.landing-ods-card,
.landing-story-item,
.landing-gallery-item,
.landing-participation-column,
.landing-story-card,
.landing-points-card,
.landing-participation-card,
.landing-faq-item,
.landing-bullet-item {
    height: 100%;
}

.landing-highlight-card {
    display: grid;
    align-content: start;
}

.landing-ods-card {
    height: 100%;
}

/* Harmonized public dashboard */
.landing-ods-section {
    padding: 1.4rem !important;
    display: grid;
    gap: 0 !important;
}

.landing-ods-section .section-title-compact {
    margin-bottom: 1.2rem !important;
}

.landing-ods-body {
    margin-top: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    gap: 1rem !important;
}

.landing-ods-stage {
    grid-template-columns: minmax(0, 1.35fr) auto !important;
    gap: 1rem 1.4rem !important;
    align-items: center !important;
    padding: 1rem 1.1rem !important;
    border-radius: 1.2rem;
    border: 1px solid rgba(19, 71, 46, 0.08);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.76), rgba(247, 251, 245, 0.78));
}

.landing-ods-copy {
    max-width: 100% !important;
    display: grid;
    align-content: center;
    gap: 0.35rem;
    padding: 0.95rem 1.05rem !important;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(244, 250, 241, 0.9));
    border: 1px solid rgba(19, 71, 46, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.landing-ods-copy .landing-mini-title {
    margin-bottom: 0.2rem;
}

.landing-ods-copy .landing-section-copy {
    max-width: none !important;
    margin-bottom: 0 !important;
    font-size: clamp(1rem, 1.02vw, 1.08rem) !important;
    line-height: 1.72 !important;
    text-align: left !important;
    text-wrap: normal !important;
    text-align-last: left;
    text-justify: inter-word;
}

.landing-ods-mosaic {
    justify-self: end;
}

.landing-ods-grid {
    margin-top: 0 !important;
    gap: 0.95rem !important;
}

.landing-ods-card {
    padding: 0.95rem !important;
    gap: 0.55rem !important;
    min-height: 0 !important;
}

.landing-ods-head {
    gap: 0.35rem !important;
}

.landing-ods-topline {
    align-items: center;
}

.landing-ods-icon {
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 0.7rem;
}

.landing-ods-number {
    font-size: 0.74rem;
    letter-spacing: 0.1em;
}

.landing-ods-head strong {
    font-size: 0.98rem;
    line-height: 1.22;
}

.landing-ods-card p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
}

.landing-realtime-intro {
    display: grid;
    gap: 1.1rem;
}

.landing-dashboard-nav-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem 1.25rem;
    align-items: end;
    padding: 1rem 1.15rem;
    border-radius: 1.2rem;
    border: 1px solid rgba(19, 71, 46, 0.08);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(247, 251, 245, 0.76));
}

.landing-dashboard-nav-copy {
    margin: 0.3rem 0 0;
    color: #4f6457;
    line-height: 1.55;
    max-width: 54ch;
}

.landing-dashboard-nav {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.7rem;
    width: min(100%, 28rem);
}

.landing-dashboard-button {
    min-height: 48px;
    padding: 0.8rem 0.95rem;
    border-radius: 0.95rem;
    border: 1px solid rgba(31, 102, 64, 0.12);
    background: rgba(255, 255, 255, 0.76);
    color: var(--public-text);
    font: inherit;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.2;
    box-shadow: 0 10px 22px rgba(26, 72, 46, 0.05);
    cursor: pointer;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease, color 0.22s ease;
}

.landing-dashboard-button:hover,
.landing-dashboard-button:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(46, 124, 83, 0.28);
    box-shadow: 0 14px 28px rgba(26, 72, 46, 0.1);
    outline: none;
}

.landing-dashboard-button.is-active {
    color: #f7fff7;
    border-color: rgba(255, 255, 255, 0.12);
    background: linear-gradient(135deg, #1f7c4f, #53ab65);
    box-shadow: 0 16px 30px rgba(31, 124, 79, 0.2);
}

.landing-dashboard-shell {
    display: grid;
    gap: 1rem;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.landing-dashboard-panel[hidden] {
    display: none !important;
}

.landing-dashboard-panel.is-active {
    display: grid;
}

.landing-dashboard-stack {
    display: grid;
    gap: 1rem;
}

.landing-dashboard-grid {
    display: grid;
    gap: 1rem;
}

.landing-dashboard-grid-resumo {
    grid-template-columns: minmax(0, 1.04fr) minmax(360px, 0.96fr);
    align-items: stretch;
}

.landing-dashboard-block {
    display: grid;
    gap: 0.95rem;
    padding: 1.2rem;
    border-radius: 1.3rem;
    border: 1px solid rgba(19, 71, 46, 0.1);
    background: linear-gradient(180deg, rgba(250, 254, 249, 0.98), rgba(241, 248, 239, 0.92));
    box-shadow: 0 16px 34px rgba(26, 72, 46, 0.09);
}

.landing-dashboard-block-emphasis {
    padding: 0.9rem;
    background: linear-gradient(180deg, rgba(18, 68, 48, 0.1), rgba(18, 68, 48, 0.04));
}

.landing-dashboard-heading {
    display: grid;
    gap: 0.35rem;
}

.landing-dashboard-copy {
    margin: 0;
    color: #4f6457;
    line-height: 1.58;
    max-width: 64ch;
}

.landing-dashboard-block .public-kpi-grid,
.landing-dashboard-block .chart-grid-public,
.landing-dashboard-block .public-events-grid-spaced {
    margin: 0 !important;
}

.landing-dashboard-block #public-impacto-cards {
    margin: 0 !important;
}

.landing-dashboard-block .chart-grid-public {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.landing-dashboard-block .chart-grid-public .chart-card-public:last-child {
    grid-column: 1 / -1;
}

.landing-dashboard-block .chart-card-public {
    min-width: 0;
    overflow: clip;
}

.landing-dashboard-block .chart-card-public canvas {
    width: min(100%, 166px) !important;
    max-width: min(100%, 166px) !important;
    height: auto !important;
    margin-inline: auto;
}

.landing-dashboard-block .chart-card-label {
    line-height: 1.25;
}

.landing-dashboard-block .chart-card-value {
    font-size: clamp(1.02rem, 1.2vw, 1.18rem) !important;
    line-height: 1.18;
    overflow-wrap: anywhere;
}

.landing-dashboard-block .chart-card-unit {
    font-size: 0.7rem !important;
}

.landing-dashboard-block .chart-card-legend {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.45rem !important;
    width: 100%;
    min-width: 0;
    margin-top: 0.7rem !important;
}

.landing-dashboard-block .chart-legend-item {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 0.18rem 0.45rem !important;
    align-items: start;
    width: 100%;
    min-width: 0;
    padding: 0.44rem 0.5rem !important;
    text-align: left;
}

.landing-dashboard-block .chart-legend-item .color-dot {
    margin-top: 0.26rem;
}

.landing-dashboard-block .chart-legend-item .material {
    min-width: 0;
    font-size: 0.76rem !important;
    line-height: 1.28;
    overflow-wrap: anywhere;
}

.landing-dashboard-block .chart-legend-item .value {
    grid-column: 2;
    min-width: 0;
    font-size: 0.72rem !important;
    line-height: 1.2;
    color: #5d7265;
    overflow-wrap: anywhere;
}

.badge-tempo-real {
    color: #f2fbf4 !important;
    border-color: rgba(255, 255, 255, 0.18) !important;
    font-weight: 600 !important;
}

.landing-dashboard-block .public-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.95rem !important;
}

.landing-dashboard-block .public-events-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.landing-visual-grid-dashboard {
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.92fr) !important;
    gap: 1rem !important;
}

.landing-visual-grid-dashboard .landing-story-card,
.landing-visual-grid-dashboard .landing-points-card {
    padding: 1.15rem !important;
}

.landing-dashboard-block .landing-daily-chart-frame {
    min-height: 300px;
}

.landing-dashboard-block .edu-simulator {
    margin: 0 !important;
}

.landing-dashboard-block .event-empty-state {
    display: grid;
    place-items: center;
    min-height: 180px;
    border-radius: 1rem;
    border: 1px dashed rgba(19, 71, 46, 0.16);
    color: var(--public-muted);
    background: rgba(255, 255, 255, 0.55);
}

@media (max-width: 1180px) {
    .landing-dashboard-nav-shell,
    .landing-dashboard-grid-resumo,
    .landing-visual-grid-dashboard {
        grid-template-columns: 1fr !important;
    }

    .landing-dashboard-nav {
        width: 100%;
    }
}

@media (max-width: 960px) {
    .landing-ods-stage {
        grid-template-columns: 1fr !important;
        align-items: start !important;
    }

    .landing-ods-mosaic {
        justify-self: start;
    }

    .landing-dashboard-block .chart-grid-public {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 768px) {
    .landing-ods-section {
        padding: 1rem !important;
    }

    .landing-ods-section .section-title-compact {
        margin-bottom: 0.95rem !important;
    }

    .landing-ods-stage {
        padding: 0.95rem !important;
    }

    .landing-dashboard-nav-shell,
    .landing-dashboard-block {
        padding: 1rem !important;
    }

    .landing-dashboard-nav {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .landing-dashboard-button {
        min-height: 46px;
        padding-inline: 0.75rem;
        font-size: 0.85rem;
    }

    .landing-dashboard-block .public-kpi-grid,
    .landing-dashboard-block .chart-grid-public,
    .landing-dashboard-block .public-events-grid {
        grid-template-columns: 1fr !important;
    }

    .landing-dashboard-block .chart-grid-public .chart-card-public:last-child {
        grid-column: auto;
    }

    .landing-dashboard-block .landing-daily-chart-frame {
        min-height: 260px;
    }
}

@media (max-width: 640px) {
    .landing-ods-copy .landing-section-copy,
    .landing-dashboard-copy,
    .landing-dashboard-nav-copy {
        max-width: none;
    }

    .landing-tab-list {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .landing-ods-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .landing-dashboard-nav {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .landing-dashboard-button {
        width: auto;
    }

    #public-impacto-cards,
    .landing-dashboard-block .public-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 360px) {
    .landing-ods-grid {
        grid-template-columns: 1fr !important;
    }

    #public-impacto-cards,
    .landing-dashboard-block .public-kpi-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Final hero + KPI rebalance */
.landing-hero-shell {
    position: relative !important;
    display: block !important;
    overflow: hidden !important;
    min-height: clamp(236px, 24vw, 300px) !important;
    padding: clamp(0.9rem, 1.6vw, 1.1rem) !important;
    border-radius: 1.6rem !important;
}

.landing-hero-shell.has-hero-media::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(100deg, rgba(8, 30, 22, 0.88) 0%, rgba(10, 44, 31, 0.76) 38%, rgba(11, 54, 37, 0.38) 68%, rgba(11, 54, 37, 0.18) 100%),
        linear-gradient(180deg, rgba(11, 54, 37, 0.24), rgba(11, 54, 37, 0.42));
}

.landing-hero-grid {
    position: relative !important;
    z-index: 2;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 0 !important;
    min-height: clamp(210px, 20vw, 258px) !important;
}

.landing-hero-copy {
    max-width: min(1100px, 100%) !important;
    min-height: 100%;
    color: #f5fff7 !important;
    display: grid !important;
    align-content: center !important;
    gap: 0.45rem !important;
    --hero-copy-line: min(38rem, 100%);
}

.landing-admin-link {
    backdrop-filter: blur(12px);
}

.landing-admin-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0.45rem 0.82rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.12);
    color: #f4fff6;
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(6, 28, 19, 0.16);
}

.landing-admin-link:hover,
.landing-admin-link:focus-visible {
    transform: translateY(-1px);
    outline: none;
}

.landing-admin-link-hero {
    position: absolute;
    top: 0.95rem;
    right: 0.95rem;
    z-index: 3;
}

.landing-hero-brand {
    background: transparent !important;
    border: none !important;
    width: auto !important;
    max-width: 100% !important;
    display: inline-flex !important;
    grid-template-columns: none !important;
    align-items: center;
    gap: 0.65rem !important;
    padding: 0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.landing-hero-brand-copy span,
.landing-hero-brand-copy strong,
.landing-hero-copy .hero-subtitle {
    color: rgba(244, 255, 246, 0.92) !important;
}

.landing-hero-copy h1 {
    width: var(--hero-copy-line);
    max-width: 100% !important;
    font-size: clamp(1.75rem, 2.7vw, 2.55rem) !important;
    line-height: 0.95 !important;
    letter-spacing: -0.052em !important;
    text-align: left !important;
    text-align-last: left;
    text-wrap: normal !important;
    text-justify: auto;
}

.landing-hero-copy .hero-subtitle {
    width: var(--hero-copy-line);
    max-width: 100% !important;
    font-size: clamp(0.88rem, 0.92vw, 0.96rem) !important;
    line-height: 1.42 !important;
    text-align: left !important;
    text-align-last: left;
    text-wrap: normal !important;
    text-justify: auto;
}

.landing-hero-copy-lead {
    display: grid;
    align-content: center;
    gap: 0.4rem;
    min-width: 0;
    width: var(--hero-copy-line);
    max-width: 100%;
}

.landing-hero-visual {
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    min-height: 100% !important;
    max-width: none !important;
    width: 100% !important;
    height: 100% !important;
}

.landing-hero-carousel,
.landing-hero-slides,
.landing-hero-slide,
.landing-hero-image,
.landing-hero-placeholder {
    width: 100% !important;
    height: 100% !important;
}

.landing-hero-carousel,
.landing-hero-slides {
    position: absolute !important;
    inset: 0 !important;
}

.landing-hero-slide {
    position: absolute !important;
    inset: 0 !important;
}

.landing-hero-image {
    object-fit: cover !important;
    object-position: center 34% !important;
    filter: saturate(0.92) contrast(1.03) brightness(0.82) !important;
}

.landing-hero-placeholder {
    justify-content: flex-end !important;
    padding: 1.25rem !important;
    background:
        radial-gradient(circle at 18% 18%, rgba(185, 216, 111, 0.28), transparent 28%),
        linear-gradient(135deg, #133f2e, #20583d 54%, #2d7a52) !important;
}

.landing-hero-carousel-dots {
    right: 1rem !important;
    bottom: 1rem !important;
    z-index: 3 !important;
}

.landing-dashboard-grid-resumo {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
    align-items: start !important;
}

.landing-dashboard-block .public-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1rem !important;
    align-items: stretch !important;
}

.landing-dashboard-block-graficos .chart-grid-public {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 1rem !important;
    align-items: stretch !important;
}

.landing-dashboard-block-graficos .chart-grid-public .chart-card-public:last-child {
    grid-column: auto !important;
}

.landing-dashboard-block-graficos .chart-card-public {
    min-height: 100% !important;
}

.landing-dashboard-block-graficos .chart-card-public canvas {
    max-width: min(100%, 154px) !important;
}

.landing-dashboard-block-graficos .chart-card-legend {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.5rem !important;
}

.landing-dashboard-block-graficos #eventos-chart-content {
    display: grid;
    gap: 0.7rem;
    align-content: start;
}

.public-page-shell,
.public-page .tab-section,
.public-page .public-footer .container,
.public-page .public-sponsors-bar .container {
    width: min(1180px, calc(100vw - 2rem));
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.public-page .tab-section[data-tab-panel]:not([data-tab-panel="dashboard"]) {
    width: 100% !important;
    max-width: 100% !important;
}

.public-page .tab-section[data-tab-panel="dashboard"] {
    width: 100% !important;
    max-width: 100% !important;
}

.public-page .landing-hero-copy h1,
.public-page .landing-hero-copy .hero-subtitle {
    text-align: left !important;
    text-wrap: normal !important;
}

.public-page .container.tab-section[data-tab-panel]:not([data-tab-panel="dashboard"]) {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.landing-dashboard-block .public-kpi-grid .stats-card {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-content: start !important;
    gap: 0.55rem 0.9rem !important;
    min-height: 208px !important;
    height: 100% !important;
    padding: 1.2rem !important;
    border-top-width: 5px !important;
}

.landing-dashboard-block .public-kpi-grid .stats-icon {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    width: 3rem !important;
    height: 3rem !important;
    border-radius: 1rem !important;
}

.landing-dashboard-block .public-kpi-grid .stats-info {
    display: grid !important;
    align-content: start !important;
    gap: 0.55rem !important;
    min-width: 0;
}

.landing-dashboard-block .public-kpi-grid .stats-label {
    font-size: 0.74rem !important;
    line-height: 1.25 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.landing-dashboard-block .public-kpi-grid .stats-value {
    font-size: clamp(1.55rem, 2.2vw, 2.35rem) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.045em !important;
    overflow-wrap: anywhere !important;
}

.landing-dashboard-block .public-kpi-grid .stats-value small {
    display: block !important;
    margin-top: 0.35rem !important;
    font-size: 0.76rem !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.landing-dashboard-block .public-kpi-grid .stats-sub {
    margin-top: auto !important;
    font-size: 0.83rem !important;
    line-height: 1.42 !important;
    color: #587063 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

@media (max-width: 960px) {
    .landing-hero-shell {
        min-height: 272px !important;
    }

    .landing-hero-shell.has-hero-media::before {
        background:
            linear-gradient(180deg, rgba(8, 30, 22, 0.82) 0%, rgba(9, 37, 27, 0.72) 44%, rgba(10, 46, 32, 0.52) 100%),
            linear-gradient(180deg, rgba(11, 54, 37, 0.2), rgba(11, 54, 37, 0.38));
    }

    .landing-hero-copy {
        max-width: none !important;
        --hero-copy-line: min(100%, 34rem);
    }

    .landing-hero-copy h1 {
        font-size: clamp(1.7rem, 6vw, 2.35rem) !important;
    }

    .landing-dashboard-block-graficos .chart-grid-public {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .landing-dashboard-block-graficos .chart-grid-public .chart-card-public:last-child {
        grid-column: 1 / -1 !important;
    }

    .landing-ods-copy {
        padding: 0.9rem 0.95rem !important;
    }
}

@media (max-width: 768px) {
    .landing-hero-shell {
        min-height: 244px !important;
        padding: 0.9rem !important;
    }

    .landing-dashboard-grid-resumo,
    .landing-dashboard-block .public-kpi-grid {
        grid-template-columns: 1fr !important;
    }

    .landing-hero-copy {
        --hero-copy-line: 100%;
    }

    .landing-hero-copy-lead,
    .landing-hero-copy h1,
    .landing-hero-copy .hero-subtitle {
        width: 100% !important;
    }

    .landing-hero-brand {
        width: auto !important;
    }

    .landing-hero-copy h1,
    .landing-hero-copy .hero-subtitle {
        text-align: left !important;
    }

    .landing-dashboard-block-graficos .chart-grid-public {
        grid-template-columns: 1fr !important;
    }

    .landing-dashboard-block-graficos .chart-card-legend {
        grid-template-columns: 1fr !important;
    }

    .landing-dashboard-block-graficos .chart-grid-public .chart-card-public:last-child {
        grid-column: auto !important;
    }

    .public-page-shell,
    .public-page .tab-section,
    .public-page .public-footer .container,
    .public-page .public-sponsors-bar .container {
        width: calc(100vw - 1.5rem);
    }

    .landing-admin-link-hero {
        top: 0.8rem;
        right: 0.8rem;
    }

    .landing-ods-copy .landing-section-copy {
        font-size: 0.96rem !important;
        line-height: 1.64 !important;
    }

    .landing-dashboard-block .public-kpi-grid .stats-card {
        min-height: 178px !important;
    }
}
