/* Reset & Variables */
:root {
    /* Base */
    --bg-dark: #0E1116;
    --surface-dark: #151A21;
    --border-dark: rgba(255, 255, 255, 0.08);

    /* Fonts */
    --font-section-title: 'Titan One', cursive, system-ui;

    /* Texto */
    --text-main: #E6EAF0;
    --text-muted: #9AA4B2;

    /* Azul (principal elegido) */
    --primary: #5B8CFF;

    /* Variantes del azul (para UI states) */
    --primary-hover: #4F7DFF;
    --primary-soft: rgba(91, 140, 255, 0.18);
    --primary-glow: rgba(91, 140, 255, 0.35);

    /* Utils kept from original or re-mapped */
    --error: #ef4444;
    --success: #10b981;

    /* Spacing */
    --container-width: 1200px;
    --section-padding: 80px;

    /* Typography */
    --font-main: 'Inter', sans-serif;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-main);
    background-color: var(--bg-dark);
    color: var(--text-main);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--text-main);
    font-weight: 700;
    line-height: 1.2;
}

a {
    text-decoration: none;
    color: var(--primary);
    transition: color 0.3s ease;
}

a:hover {
    color: var(--primary-hover);
}

ul {
    list-style: none;
    /* Removed default bullets */
}

/* Utilities */
.container {
    width: 100%;
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 20px;
}

.section-padding {
    padding: var(--section-padding) 0;
}

.bg-offset {
    background-color: var(--bg-dark);
}

.bg-dark {
    background-color: var(--bg-dark);
}

.divider {
    height: 3px;
    width: 60px;
    background-color: var(--primary);
    margin: 20px 0 30px 0;
}

.btn {
    display: inline-block;
    padding: 12px 30px;
    border-radius: 4px;
    font-weight: 500;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
}

.btn-primary {
    background-color: var(--primary);
    color: var(--text-main);
    border: 1px solid var(--primary);
}

.btn-primary:hover {
    background: var(--primary-hover);
    color: var(--text-main);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
    transform: translateY(-1px);
}

.btn:focus-visible,
a:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.btn-secondary {
    background-color: transparent;
    color: var(--text-main);
    border: 1px solid var(--border-dark);
}

.btn-secondary:hover {
    background-color: var(--primary-soft);
    border-color: rgba(91, 140, 255, 0.35);
    color: var(--text-main);
    transform: translateY(-2px);
}

.btn-block {
    display: block;
    width: 100%;
}

/* Header */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: rgba(14, 17, 22, 0.95);
    /* Using bg-dark rgb with alpha */
    backdrop-filter: blur(10px);
    z-index: 1000;
    border-bottom: 1px solid var(--border-dark);
    padding: 20px 0;
}

.site-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--text-main);
}

.main-nav ul {
    display: flex;
    gap: 30px;
    align-items: center;
}

.main-nav a {
    font-size: 0.95rem;
    color: var(--text-muted);
}

.main-nav a:hover,
.main-nav a.active {
    color: var(--text-main);
}

.main-nav .btn-nav {
    padding: 8px 18px;
    border: 1px solid var(--border-dark);
    border-radius: 4px;
    color: var(--text-main);
}

.main-nav .btn-nav:hover {
    border-color: var(--primary);
    background-color: var(--primary-soft);
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
}

.menu-toggle span {
    display: block;
    width: 25px;
    height: 2px;
    background-color: var(--text-main);
    margin: 5px 0;
    transition: 0.3s;
}

/* Hero Section */
/* Hero Section */
.hero-section {
    padding: 180px 0 100px;
    min-height: 80vh;
    display: flex;
    align-items: center;
}

.hero-inner {
    display: flex;
    align-items: center;
    gap: 60px;
}

.hero-visual {
    flex: 1;
    display: flex;
    justify-content: center;
}

.hero-svg {
    width: 100%;
    max-width: 500px;
    height: auto;
}

.hero-content {
    flex: 1;
}

.hero-title {
    font-size: 4rem;
    margin-bottom: 25px;
    letter-spacing: -0.03em;
    color: var(--text-main);
    text-shadow: 0 0 40px rgba(91, 140, 255, 0.6);
}

.hero-subtitle {
    /* kept the same but ensuring max-width doesn't break layout */
    font-size: 1.25rem;
    color: var(--text-muted);
    max-width: 60ch;
    margin-bottom: 30px;
}

.hero-bullets {
    margin-bottom: 40px;
    color: var(--text-muted);
    font-size: 1.1rem;
}

.hero-bullets li {
    margin-bottom: 12px;
    padding-left: 20px;
    position: relative;
    line-height: 1.5;
}

.hero-bullets li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--primary);
    font-weight: bold;
}

.hero-actions {
    display: flex;
    gap: 20px;
}

.hero-actions .hero-primary-cta {
    background: linear-gradient(122deg, #f3f8ff 8%, #93b5ff 44%, #66e0d0 88%);
    background-size: 210% 210%;
    border-color: rgba(91, 140, 255, 0.72);
    color: #081523;
    box-shadow: 0 12px 28px rgba(91, 140, 255, 0.28);
    animation: title-shift 9s ease-in-out infinite;
}

.hero-actions .hero-primary-cta:hover {
    border-color: rgba(102, 224, 208, 0.9);
    color: #06121e;
    box-shadow: 0 16px 34px rgba(91, 140, 255, 0.35);
}

/* Section Common */
.section-header {
    margin-bottom: 60px;
}

.section-header h2 {
    font-size: 2.5rem;
}

.content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
}

.text-block p {
    margin-bottom: 20px;
    font-size: 1.1rem;
    color: var(--text-muted);
    max-width: 800px;
}

.about-list {
    margin-bottom: 20px;
    padding-left: 20px;
}

.about-list li {
    margin-bottom: 15px;
    color: var(--text-muted);
    font-size: 1.05rem;
    list-style-type: disc;
}

.about-list strong {
    color: var(--text-main);
}

/* Services Pages (Home) */
#services-pages {
    --section-accent: #79b6ff;
    position: relative;
}

#services-pages .section-header {
    max-width: none;
    margin: 0 0 34px;
    text-align: center;
}

#services-pages .services-pages-head {
    display: block;
}

#services-pages .services-pages-head-main {
    max-width: 760px;
    margin: 0 auto;
}

#services-pages .section-title {
    display: inline-block;
    margin: 0 0 12px;
    max-width: 24ch;
}

#services-pages .section-title::after {
    left: 50%;
    transform: translateX(-50%);
    width: min(160px, 64%);
}

#services-pages .section-subtitle {
    margin: 0;
    max-width: 62ch;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

#services-pages::before {
    content: "";
    position: absolute;
    inset: 7% auto auto -6%;
    width: min(42vw, 420px);
    height: min(42vw, 420px);
    border-radius: 999px;
    pointer-events: none;
    background: radial-gradient(circle, rgba(91, 140, 255, 0.2), transparent 68%);
    filter: blur(30px);
    opacity: 0.5;
}

#services-pages .services-pages-kicker {
    display: inline-block;
    margin-bottom: 10px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.35);
    background: rgba(91, 140, 255, 0.1);
    color: #b6ccff;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

#services-pages .services-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

#services-pages .service-card {
    --card-primary-rgb: 91, 140, 255;
    --card-primary: #93b5ff;
    --card-context: #9cb6e9;
    --card-link-start: #f3f8ff;
    --card-chip-text: #d8e5ff;
    --card-link-fallback: #cfe0ff;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 100%;
    padding: 26px 24px 24px;
    border: 1px solid rgba(var(--card-primary-rgb), 0.16);
    border-radius: 18px;
    background:
        linear-gradient(165deg, rgba(var(--card-primary-rgb), 0.16), rgba(var(--card-primary-rgb), 0.05) 52%, transparent 86%),
        var(--panel-frost);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.3);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

#services-pages .service-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(120deg, rgba(var(--card-primary-rgb), 0.28), transparent 46%, rgba(var(--card-primary-rgb), 0.14));
    transition: opacity 0.35s ease;
}

#services-pages .service-card:hover {
    transform: translateY(-6px);
    border-color: rgba(var(--card-primary-rgb), 0.44);
    box-shadow: 0 22px 42px rgba(0, 0, 0, 0.42);
}

#services-pages .service-card:hover::before {
    opacity: 1;
}

#services-pages .service-card.service-card-highlight {
    border-color: rgba(var(--card-primary-rgb), 0.46);
}

#services-pages .service-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

#services-pages .service-card-order {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 8px;
    border-radius: 10px;
    border: 1px solid rgba(var(--card-primary-rgb), 0.42);
    background: rgba(var(--card-primary-rgb), 0.16);
    color: var(--card-primary);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

#services-pages .service-card-chip {
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--card-chip-text);
    background: rgba(var(--card-primary-rgb), 0.2);
    border: 1px solid rgba(var(--card-primary-rgb), 0.34);
}

#services-pages .service-card-context {
    display: inline-flex;
    width: fit-content;
    color: var(--card-context);
    font-size: 0.76rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

#services-pages .service-card h3 {
    margin: 0;
    font-size: 1.22rem;
    line-height: 1.3;
    letter-spacing: -0.01em;
}

#services-pages .service-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.96rem;
    line-height: 1.62;
}

#services-pages .service-card-points {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

#services-pages .service-card-points li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d0daec;
    font-size: 0.9rem;
    line-height: 1.5;
}

#services-pages .service-card-points li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    flex: 0 0 8px;
    border-radius: 999px;
    background: var(--card-primary);
    box-shadow: 0 0 0 4px rgba(var(--card-primary-rgb), 0.18);
}

#services-pages .service-card-link,
#services-pages .service-card-secondary {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    padding: 2px 0 4px;
    color: var(--card-link-fallback);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    line-height: 1.2;
    transition: transform 0.22s ease, opacity 0.22s ease;
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    #services-pages .service-card-link,
    #services-pages .service-card-secondary {
        background: linear-gradient(96deg, var(--card-link-start) 12%, var(--card-primary) 58%, var(--card-link-start) 96%);
        background-size: 170% 170%;
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        -webkit-text-fill-color: transparent;
        animation: title-shift 9s ease-in-out infinite;
    }
}

#services-pages .service-card-link {
    margin-top: auto;
}

#services-pages .service-card-link::after,
#services-pages .service-card-secondary::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 100%;
    height: 1.5px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(var(--card-primary-rgb), 0.24), rgba(var(--card-primary-rgb), 0.68), rgba(var(--card-primary-rgb), 0.24));
    transform: scaleX(0.36);
    transform-origin: left center;
    transition: transform 0.22s ease, opacity 0.22s ease;
    opacity: 0.85;
}

#services-pages .service-card-link span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    transition: transform 0.2s ease;
}

#services-pages .service-card-secondary {
    margin-top: 4px;
    font-size: 0.88rem;
    opacity: 0.9;
}

#services-pages .service-card-link:hover,
#services-pages .service-card-secondary:hover {
    transform: translateY(-1px);
    opacity: 1;
}

#services-pages .service-card-link:hover::after,
#services-pages .service-card-secondary:hover::after {
    transform: scaleX(1);
}

#services-pages .service-card-link:hover span {
    transform: translateX(2px);
}

#services-pages .service-card-link:focus-visible,
#services-pages .service-card-secondary:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 3px rgba(var(--card-primary-rgb), 0.42);
    border-radius: 4px;
}

#services-pages .service-card-theme-corporativa {
    --card-primary-rgb: 91, 140, 255;
    --card-primary: #93b5ff;
    --card-context: #9cb6e9;
    --card-link-start: #f3f8ff;
    --card-chip-text: #d8e5ff;
    --card-link-fallback: #cfe0ff;
}

#services-pages .service-card-theme-landing {
    --card-primary-rgb: 89, 225, 208;
    --card-primary: #79e6d7;
    --card-context: #94ddd4;
    --card-link-start: #f2fffc;
    --card-chip-text: #d6f5ef;
    --card-link-fallback: #d8f7f3;
}

#services-pages .service-card-theme-blog {
    --card-primary-rgb: 95, 172, 255;
    --card-primary: #8dc1ff;
    --card-context: #9dcce7;
    --card-link-start: #f4f9ff;
    --card-chip-text: #d9e9ff;
    --card-link-fallback: #d6e9ff;
}

#services-pages .service-card-theme-guia {
    --card-primary-rgb: 255, 186, 102;
    --card-primary: #ffc987;
    --card-context: #f0d1a6;
    --card-link-start: #fff6e9;
    --card-chip-text: #ffe8ca;
    --card-link-fallback: #ffe7c7;
}

#services-pages .service-card-theme-presupuesto {
    --card-primary-rgb: 156, 225, 143;
    --card-primary: #a6e89b;
    --card-context: #cae9c4;
    --card-link-start: #f5fff2;
    --card-chip-text: #d8f2d3;
    --card-link-fallback: #dff6da;
}

#services-pages .services-pages-footer {
    margin-top: 24px;
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 18px;
    padding: 18px 20px;
    display: flex;
    gap: 18px;
    align-items: center;
    justify-content: space-between;
    background:
        linear-gradient(135deg, rgba(91, 140, 255, 0.14), rgba(102, 224, 208, 0.06) 52%, transparent 88%),
        rgba(13, 19, 28, 0.76);
}

#services-pages .services-pages-footer p {
    margin: 0;
    max-width: 680px;
    color: #d2dcef;
    font-size: 0.95rem;
}

/* Tech Stack */
.tech-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 20px;
}

.tech-item {
    background-color: var(--surface-dark);
    border: 1px solid var(--border-dark);
    padding: 20px;
    text-align: center;
    border-radius: 4px;
    font-weight: 500;
    color: var(--text-muted);
    transition: 0.3s;
}

.tech-item:hover {
    color: var(--text-main);
    border-color: var(--primary);
    background-color: var(--primary-soft);
}

/* Projects */
.projects-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
}

.project-card {
    background-color: var(--surface-dark);
    border: 1px solid var(--border-dark);
    padding: 40px;
    border-radius: 6px;
    transition: border-color 0.3s ease;
}

.project-card-link,
.project-card-link:hover,
.project-card-link:visited {
    color: var(--text-main);
    text-decoration: none;
}

.project-card-link {
    display: block;
}

.project-card:hover {
    border-color: var(--primary-glow);
}

.project-content h3 {
    font-size: 1.8rem;
    margin-bottom: 30px;
}

.project-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
    margin-bottom: 30px;
}

.detail-group .label {
    display: block;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    margin-bottom: 8px;
    font-weight: 600;
}

.tags {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 20px;
}

.tags span {
    font-size: 0.8rem;
    padding: 5px 12px;
    background-color: var(--primary-soft);
    border: 1px solid rgba(91, 140, 255, 0.25);
    border-radius: 20px;
    color: var(--text-main);
}

/* Ensure technologies chips are responsive and use full card width */
.project-details .tags {
    grid-column: 1 / -1;
    margin-top: 0;
    align-self: start;
}

.project-details .tags span {
    white-space: nowrap;
    line-height: 1.2;
}

@media (max-width: 640px) {
    .project-card {
        padding: 26px 20px;
    }

    .project-content h3 {
        font-size: clamp(1.25rem, 5vw, 1.55rem);
        margin-bottom: 22px;
    }

    .project-details {
        gap: 20px;
    }

    .project-details .tags {
        gap: 8px;
    }

    .project-details .tags span {
        font-size: 0.75rem;
        padding: 6px 10px;
    }
}

/* Process */
#process .process-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
}

#process .step {
    position: relative;
    padding-top: 20px;
    z-index: 2;
    /* Ensure steps are above connection lines */
}

.step-number {
    display: block;
    font-size: 3rem;
    font-weight: 700;
    color: var(--surface-dark);
    -webkit-text-stroke: 1px var(--border-dark);
    margin-bottom: 15px;
    transition: color 0.3s ease;
}

#process .step:hover .step-number {
    color: transparent;
    -webkit-text-stroke: 1px var(--primary);
}

.step h3 {
    margin-bottom: 10px;
    font-size: 1.2rem;
}

.step p {
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Desktop Zigzag Layout */
@media (min-width: 900px) {
    #process .process-steps {
        grid-template-columns: repeat(6, 1fr);
        column-gap: 30px;
        row-gap: 80px;
        /* Space for the line drop */
    }

    /* Positioning */
    /* Row 1: 1-2-3 */
    #process .step:nth-child(1) {
        grid-column: 1 / 3;
    }

    #process .step:nth-child(2) {
        grid-column: 3 / 5;
    }

    #process .step:nth-child(3) {
        grid-column: 5 / 7;
    }

    /* Row 2: 4-5 (Centered: Cols 2-4 and 4-6) */
    #process .step:nth-child(4) {
        grid-column: 2 / 4;
    }

    #process .step:nth-child(5) {
        grid-column: 4 / 6;
    }

    /* Connecting lines removed by design */
    #process .step::after {
        content: none;
    }
}

/* Contact */
.contact-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
}

.contact-info h2 {
    margin-bottom: 20px;
}

.contact-info p {
    color: var(--text-muted);
    margin-bottom: 40px;
    font-size: 1.1rem;
}

.contact-list li {
    margin-bottom: 15px;
}

.contact-list a {
    font-size: 1.2rem;
    border-bottom: 1px solid var(--border-dark);
    padding-bottom: 2px;
}

.contact-list a:hover {
    color: var(--primary);
    border-color: var(--primary);
}

.contact-social-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.contact-social-link svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
}

.form-group {
    margin-bottom: 25px;
}

.form-group label {
    display: block;
    margin-bottom: 10px;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 15px;
    background-color: var(--surface-dark);
    border: 1px solid var(--border-dark);
    border-radius: 4px;
    color: var(--text-main);
    font-family: var(--font-main);
    font-size: 1rem;
    transition: border-color 0.3s;
}

.form-group input:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.form-message {
    margin-top: 15px;
    font-size: 0.95rem;
    text-align: center;
}

.form-message.success {
    color: var(--success);
}

.form-message.error {
    color: var(--error);
}

/* Contact page: simple conversion-first layout */
.contact-page-simple {
    --contact-simple-primary-rgb: 91, 140, 255;
    --contact-simple-secondary-rgb: 102, 224, 208;
    --contact-simple-primary: #93b5ff;
    --contact-simple-secondary: #8ee8dc;
}

.contact-page-simple .contact-simple-hero {
    padding-bottom: 62px;
}

.contact-page-simple .contact-simple-shell {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.06fr) minmax(340px, 0.94fr);
    grid-template-areas:
        "intro form"
        "alt form";
    column-gap: clamp(22px, 3vw, 38px);
    row-gap: 16px;
    align-items: start;
}

.contact-page-simple .contact-simple-intro {
    grid-area: intro;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.3);
    border-radius: 20px;
    padding: clamp(20px, 2.8vw, 34px);
    background:
        linear-gradient(148deg, rgba(var(--contact-simple-primary-rgb), 0.16), rgba(var(--contact-simple-secondary-rgb), 0.08) 56%, transparent 92%),
        rgba(13, 19, 28, 0.82);
}

.contact-page-simple .contact-simple-intro .service-kicker {
    margin-bottom: 10px;
    border-color: rgba(var(--contact-simple-primary-rgb), 0.44);
    background: linear-gradient(140deg, rgba(var(--contact-simple-primary-rgb), 0.2), rgba(var(--contact-simple-secondary-rgb), 0.1));
    color: #d7e4ff;
}

.contact-page-simple .contact-simple-intro .section-title {
    margin-top: 0;
    margin-bottom: 14px;
    max-width: 24ch;
}

.contact-page-simple .contact-simple-intro .section-title::after {
    left: 0;
    transform: none;
    width: min(220px, 64%);
}

.contact-page-simple .contact-simple-intro .section-subtitle {
    margin: 0;
    max-width: 70ch;
}

.contact-page-simple .contact-simple-trust {
    margin: 16px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.contact-page-simple .contact-simple-trust li {
    list-style: none;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.3);
    border-radius: 12px;
    padding: 10px 12px;
    background: linear-gradient(142deg, rgba(var(--contact-simple-primary-rgb), 0.14), rgba(var(--contact-simple-secondary-rgb), 0.08));
    color: #d8e2f5;
    font-size: 0.9rem;
    line-height: 1.42;
}

.contact-page-simple .contact-simple-trust li span {
    color: #f2f7ff;
    font-weight: 700;
}

.contact-page-simple .contact-simple-form {
    grid-area: form;
    align-self: start;
    width: 100%;
    max-width: none;
    margin: 0;
    border-color: rgba(var(--contact-simple-primary-rgb), 0.3);
    padding: clamp(24px, 2.2vw, 32px);
    border-radius: 20px;
    background:
        linear-gradient(150deg, rgba(var(--contact-simple-primary-rgb), 0.16), rgba(var(--contact-simple-secondary-rgb), 0.08) 54%, transparent 92%),
        rgba(12, 18, 28, 0.84);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
}

.contact-page-simple .contact-simple-form:hover {
    transform: none;
    border-color: rgba(var(--contact-simple-primary-rgb), 0.38);
    box-shadow: 0 20px 46px rgba(0, 0, 0, 0.36);
}

.contact-page-simple .contact-simple-form form {
    display: grid;
    gap: 14px;
}

.contact-page-simple .contact-simple-form-head {
    display: grid;
    gap: 8px;
    margin-bottom: 2px;
}

.contact-page-simple .contact-simple-form-head h2 {
    margin: 0;
    font-size: clamp(1.14rem, 1rem + 0.4vw, 1.38rem);
    color: #ebf3ff;
    letter-spacing: -0.01em;
}

.contact-page-simple .contact-simple-form-head p {
    margin: 0;
    color: #c2d3ef;
    font-size: 0.93rem;
    line-height: 1.5;
}

.contact-page-simple .contact-simple-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.contact-page-simple .contact-simple-form .form-group {
    margin: 0;
}

.contact-page-simple .contact-simple-form .form-group label {
    color: #bfd1ef;
    margin-bottom: 8px;
    font-size: 0.73rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.contact-page-simple .contact-simple-form .form-group input,
.contact-page-simple .contact-simple-form .form-group textarea {
    border-radius: 12px;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.26);
    background:
        linear-gradient(150deg, rgba(var(--contact-simple-primary-rgb), 0.12), rgba(var(--contact-simple-secondary-rgb), 0.04) 60%, transparent),
        rgba(10, 15, 24, 0.82);
    color: #ecf3ff;
    padding: 13px 14px;
}

.contact-page-simple .contact-simple-form .form-group input::placeholder,
.contact-page-simple .contact-simple-form .form-group textarea::placeholder {
    color: #8fa3c7;
}

.contact-page-simple .contact-simple-form .form-group input:hover,
.contact-page-simple .contact-simple-form .form-group textarea:hover {
    border-color: rgba(var(--contact-simple-primary-rgb), 0.44);
}

.contact-page-simple .contact-simple-form .form-group input:focus,
.contact-page-simple .contact-simple-form .form-group textarea:focus {
    border-color: rgba(var(--contact-simple-secondary-rgb), 0.56);
    box-shadow: 0 0 0 3px rgba(var(--contact-simple-primary-rgb), 0.22);
}

.contact-page-simple .contact-simple-message-group textarea {
    min-height: 164px;
    resize: vertical;
}

.contact-page-simple .contact-simple-form-note {
    margin: 0;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.24);
    background: rgba(var(--contact-simple-primary-rgb), 0.08);
    color: #c0d1ed;
    font-size: 0.86rem;
    line-height: 1.45;
}

.contact-page-simple .contact-simple-form .btn-primary {
    border-color: rgba(var(--contact-simple-primary-rgb), 0.74);
    background: linear-gradient(132deg, #c8d9ff 0%, #9ebdff 44%, #92e8dc 100%);
    color: #101f33;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 12px 28px rgba(var(--contact-simple-primary-rgb), 0.3);
}

.contact-page-simple .contact-simple-form .btn-primary:hover {
    background: linear-gradient(132deg, #d9e5ff 0%, #b4cfff 44%, #a8efe5 100%);
    color: #0b192b;
    box-shadow: 0 16px 34px rgba(var(--contact-simple-secondary-rgb), 0.28);
}

.contact-page-simple .contact-simple-form .btn-primary:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.contact-page-simple .contact-simple-form .form-message {
    text-align: left;
    margin-top: 2px;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: rgba(255, 255, 255, 0.02);
}

.contact-page-simple .contact-simple-form .form-message:empty {
    display: none;
}

.contact-page-simple .contact-simple-form .form-message.success {
    border-color: rgba(104, 219, 176, 0.5);
    background: rgba(104, 219, 176, 0.12);
}

.contact-page-simple .contact-simple-form .form-message.error {
    border-color: rgba(255, 135, 135, 0.5);
    background: rgba(255, 135, 135, 0.12);
}

.contact-page-simple .contact-simple-alt {
    grid-area: alt;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.28);
    border-radius: 16px;
    padding: 16px;
    background:
        linear-gradient(146deg, rgba(var(--contact-simple-primary-rgb), 0.12), rgba(var(--contact-simple-secondary-rgb), 0.06) 52%, transparent 92%),
        rgba(13, 19, 28, 0.72);
}

.contact-page-simple .contact-simple-alt h2 {
    margin: 0 0 8px;
    font-size: 1.06rem;
    color: #e9f0ff;
}

.contact-page-simple .contact-simple-alt p {
    margin: 0;
    color: #c5d3eb;
    font-size: 0.92rem;
}

.contact-page-simple .contact-simple-channels {
    margin: 12px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.contact-page-simple .contact-simple-channel {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    width: 100%;
    padding: 11px 12px;
    border-radius: 12px;
    border: 1px solid rgba(var(--contact-simple-primary-rgb), 0.26);
    background: rgba(var(--contact-simple-primary-rgb), 0.08);
    color: #edf3ff;
    text-decoration: none;
    transition: transform 0.22s ease, border-color 0.22s ease, background-color 0.22s ease;
}

.contact-page-simple .contact-simple-channel:hover {
    transform: translateY(-1px);
    border-color: rgba(var(--contact-simple-secondary-rgb), 0.46);
    background: rgba(var(--contact-simple-secondary-rgb), 0.14);
}

.contact-page-simple .contact-simple-channel svg {
    width: 20px;
    height: 20px;
    margin-top: 1px;
    fill: currentColor;
    flex: 0 0 20px;
}

.contact-page-simple .contact-simple-channel-text {
    display: grid;
    gap: 2px;
}

.contact-page-simple .contact-simple-channel-label {
    color: #b7caec;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.3;
}

.contact-page-simple .contact-simple-channel strong {
    color: #eef4ff;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
}

.contact-page-simple .contact-simple-alt-note {
    margin-top: 10px !important;
    color: #b8cae8 !important;
}

/* Footer */
.site-footer {
    padding: 40px 0;
    border-top: 1px solid var(--border-dark);
    text-align: center;
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Responsive */
@media (max-width: 900px) {
    .menu-toggle {
        display: block;
        z-index: 1001;
    }

    .main-nav ul {
        position: fixed;
        top: 0;
        right: -100%;
        width: 80%;
        height: 100vh;
        background-color: var(--surface-dark);
        flex-direction: column;
        justify-content: center;
        transition: 0.4s ease;
        padding: 40px;
        border-left: 1px solid var(--border-dark);
    }

    .main-nav ul.active {
        right: 0;
    }

    .hero-title {
        font-size: 3rem;
    }

    .contact-page-simple .contact-simple-shell {
        grid-template-columns: 1fr;
        grid-template-areas:
            "intro"
            "form"
            "alt";
        row-gap: 14px;
    }

    .contact-page-simple .contact-simple-form {
        padding: 22px;
    }

    .contact-page-simple .contact-simple-form-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .contact-wrapper {
        grid-template-columns: 1fr;
    }

    .contact-page-simple .contact-simple-trust {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact-page-simple .contact-simple-channels {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .hero-title {
        font-size: 2.2rem;
    }

    .hero-actions {
        flex-direction: column;
    }

    .btn {
        width: 100%;
    }

    .contact-page-simple .contact-simple-intro .section-title {
        max-width: 100%;
    }

    .contact-page-simple .contact-simple-trust {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
    }
}

/* Conversion: "Qué incluye" - estilos acotados */
.includes .container {
    max-width: 900px;
}

.includes .includes-card {
    background: var(--surface-dark);
    border: 1px solid var(--border-dark);
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
}

.includes h3 {
    margin: 0 0 14px 0;
    font-size: clamp(1.2rem, 1rem + 0.6vw, 1.6rem);
}

.includes ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
}

.includes li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: var(--text-muted);
    line-height: 1.5;
}

.includes li::before {
    content: "";
    width: 10px;
    height: 10px;
    margin-top: 6px;
    border-radius: 999px;
    background: var(--primary);
    box-shadow: 0 0 0 4px var(--primary-soft);
}

/* Mobile refinement */
@media (max-width: 640px) {
    .includes .includes-card {
        padding: 20px;
        border-radius: 14px;
    }
}

@media (max-width: 900px) {
    .hero-inner {
        flex-direction: column;
    }

    .hero-visual {
        display: none;
    }
}

/* HERO mockup: caja premium + imagen */
#hero .hero-visual {
    position: relative;
}

#hero .hero-image-slot {
    background: var(--surface-dark);
    border: 1px solid var(--border-dark);
    border-radius: 18px;
    padding: 14px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
}

#hero .hero-mockup {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
}

/* Responsive: si el hero es 2 columnas en desktop, en móvil debe apilarse */
@media (max-width: 900px) {

    /* si ya existe #hero .hero-inner grid, respétalo.
     solo asegurar que la imagen no se sale y queda debajo */
    #hero .hero-image-slot {
        padding: 12px;
    }
}

/* Section titles system (centered + bigger, sober) */
.section-header {
    max-width: 720px;
    margin: 0 auto 40px auto;
    text-align: center;
}

.section-header h2 {
    font-size: clamp(2rem, 1.6rem + 1.2vw, 2.8rem);
    letter-spacing: -0.03em;
    margin-bottom: 14px;
    color: var(--text-main);
}

.section-header .section-subtitle {
    max-width: 640px;
    margin: 0 auto;
    color: var(--text-muted);
    font-size: 1.05rem;
    line-height: 1.7;
}

#about {
    --section-accent: #78b7ff;
}

#process {
    --section-accent: #67dfcf;
}

#projects {
    --section-accent: #93abff;
}

#tech {
    --section-accent: #86caff;
}

#contact {
    --section-accent: #7eaaff;
}

/* Section Title Font Customization */
.section-title {
    font-family: var(--font-main);
    font-weight: 700;
    letter-spacing: -0.02em;
    text-transform: none;
    line-height: 1.1;
    color: #eef3ff;
    padding-left: 0;
}

/* About: Types zig-zag blocks */
#about .about-types {
    display: grid;
    gap: 52px;
    margin-top: 30px;
}

#about .type-block {
    --type-primary-rgb: 91, 140, 255;
    --type-secondary-rgb: 102, 224, 208;
    --type-primary: #93b5ff;
    --type-secondary: #66e0d0;
    --type-heading-color: #9dbdff;
    --type-paragraph-color: #c9d6eb;
    --type-point-color: #d2dff1;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 34px;
    align-items: center;
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
}

#about .type-block.is-reversed .type-text {
    order: 2;
}

#about .type-block.is-reversed .type-visual {
    order: 1;
}

#about .type-theme-corporativa {
    --type-primary-rgb: 91, 140, 255;
    --type-secondary-rgb: 102, 224, 208;
    --type-primary: #93b5ff;
    --type-secondary: #66e0d0;
    --type-heading-color: #a5c3ff;
    --type-paragraph-color: #c6d4ea;
    --type-point-color: #d0def2;
}

#about .type-theme-landing {
    --type-primary-rgb: 89, 225, 208;
    --type-secondary-rgb: 255, 179, 103;
    --type-primary: #79e6d7;
    --type-secondary: #ffc179;
    --type-heading-color: #8be9dc;
    --type-paragraph-color: #c8ddd9;
    --type-point-color: #d5e8e4;
}

#about .type-text h3 {
    margin: 0 0 10px 0;
    color: var(--type-heading-color);
    text-shadow: 0 0 12px rgba(var(--type-primary-rgb), 0.18);
    font-size: 1.2rem;
    letter-spacing: -0.01em;
}

#about .type-text p {
    margin: 0 0 14px 0;
    color: var(--type-paragraph-color);
    line-height: 1.65;
}

#about .type-points {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

#about .type-points li {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    color: var(--type-point-color);
    line-height: 1.5;
}

#about .type-points li::before {
    content: "";
    width: 9px;
    height: 9px;
    margin-top: 7px;
    border-radius: 999px;
    background: linear-gradient(165deg, var(--type-primary), var(--type-secondary));
    box-shadow: 0 0 0 4px rgba(var(--type-primary-rgb), 0.2);
}

#about .type-visual {
    position: relative;
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
}

#about .type-visual::before {
    content: "";
    position: absolute;
    inset: -14px -14px -18px -14px;
    border-radius: 22px;
    background: radial-gradient(circle at 58% 40%, rgba(var(--type-primary-rgb), 0.22), transparent 60%);
    filter: blur(10px);
    opacity: 0.75;
    z-index: 0;
}

#about .type-visual img {
    position: relative;
    z-index: 1;
    width: 100%;
    height: auto;
    display: block;
    border-radius: 18px;
    border: none;
    transform: translateY(-8px);
    box-shadow:
        0 22px 60px rgba(0, 0, 0, 0.55),
        0 6px 18px rgba(0, 0, 0, 0.25);
}

/* Responsive: stack always text then image */
@media (max-width: 900px) {
    #about .type-block {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    #about .type-block.is-reversed .type-text,
    #about .type-block.is-reversed .type-visual {
        order: unset;
    }

    #about .type-visual img {
        transform: translateY(0);
    }
}

/* Visual Effects Layer */
:root {
    --accent-secondary: #66e0d0;
    --panel-frost: rgba(21, 26, 33, 0.72);
    --panel-highlight: rgba(255, 255, 255, 0.04);
}

body {
    position: relative;
    isolation: isolate;
    overflow-x: hidden;
    background: linear-gradient(180deg, #0b1017 0%, #0d131c 44%, #0b1017 100%);
}

body::before,
body::after {
    content: "";
    position: fixed;
    pointer-events: none;
    z-index: 0;
}

body::before {
    inset: -26vh -22vw auto auto;
    width: min(66vw, 760px);
    height: min(66vw, 760px);
    border-radius: 999px;
    opacity: 0.52;
    filter: blur(56px);
    background: radial-gradient(circle at 34% 34%,
            rgba(91, 140, 255, 0.3) 0%,
            rgba(91, 140, 255, 0.14) 26%,
            rgba(91, 140, 255, 0) 66%);
    animation: aura-drift 30s ease-in-out infinite alternate;
}

body::after {
    inset: 0;
    border-radius: 0;
    opacity: 0.14;
    background-image:
        linear-gradient(rgba(230, 234, 240, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(230, 234, 240, 0.03) 1px, transparent 1px);
    background-size: 120px 120px;
    mask-image: radial-gradient(ellipse at 52% 22%, rgba(0, 0, 0, 0.86) 0%, transparent 74%);
    -webkit-mask-image: radial-gradient(ellipse at 52% 22%, rgba(0, 0, 0, 0.86) 0%, transparent 74%);
    animation: grid-drift 26s linear infinite;
}

main,
.site-header,
.site-footer {
    position: relative;
    z-index: 1;
}

@keyframes aura-drift {
    0% {
        transform: translate3d(0, 0, 0) scale(1);
    }

    100% {
        transform: translate3d(5vw, -2.5vh, 0) scale(1.08);
    }
}

@keyframes grid-drift {
    0% {
        transform: translate3d(0, 0, 0);
    }

    100% {
        transform: translate3d(0, -32px, 0);
    }
}

.site-header {
    transition: padding 0.3s ease, background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.site-header.scrolled {
    padding: 12px 0;
    background-color: rgba(10, 13, 18, 0.86);
    border-color: rgba(91, 140, 255, 0.3);
    box-shadow: 0 12px 34px rgba(0, 0, 0, 0.4);
}

.logo {
    position: relative;
    background: linear-gradient(92deg, #f2f6ff, #a8c2ff 42%, #70e9d7 86%);
    background-size: 200% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: logo-shift 8s linear infinite;
}

.logo::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary), transparent);
    transform: scaleX(0.2);
    transform-origin: left center;
    opacity: 0;
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.logo:hover::after {
    opacity: 0.95;
    transform: scaleX(1);
}

@keyframes logo-shift {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

.main-nav a {
    position: relative;
}

.main-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -8px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary), transparent);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.35s ease;
}

.main-nav a:hover::after,
.main-nav a.active::after {
    transform: scaleX(1);
}

.main-nav .btn-nav::after {
    display: none;
}

.btn {
    position: relative;
    overflow: hidden;
    isolation: isolate;
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.35s ease, border-color 0.35s ease;
}

.btn::before {
    content: "";
    position: absolute;
    inset: -160% -55%;
    transform: translateX(-36%) rotate(12deg);
    background: linear-gradient(120deg,
            transparent 36%,
            rgba(255, 255, 255, 0.38) 50%,
            transparent 64%);
    transition: transform 0.85s ease;
    pointer-events: none;
}

.btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
}

.btn:hover::before {
    transform: translateX(36%) rotate(12deg);
}

.btn:active {
    transform: translateY(-1px) scale(0.99);
}

.hero-section {
    position: relative;
}

.hero-section::before {
    content: "";
    position: absolute;
    inset: 12% 5% auto auto;
    width: min(42vw, 480px);
    aspect-ratio: 1 / 1;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(91, 140, 255, 0.28), transparent 62%);
    filter: blur(22px);
    pointer-events: none;
    z-index: -1;
}

.hero-title {
    background: linear-gradient(98deg, #f3f8ff 12%, #93b5ff 48%, #66e0d0 86%);
    background-size: 190% 190%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: none;
    animation: title-shift 9s ease-in-out infinite;
}

@keyframes title-shift {
    0%,
    100% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }
}

.hero-bullets li {
    transition: color 0.25s ease, transform 0.25s ease;
}

.hero-bullets li:hover {
    color: var(--text-main);
    transform: translateX(6px);
}

#hero .hero-image-slot {
    position: relative;
    transform-style: preserve-3d;
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

#hero .hero-image-slot::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: 20px;
    opacity: 0;
    pointer-events: none;
    background: conic-gradient(from 200deg at 50% 50%,
            rgba(91, 140, 255, 0.42),
            rgba(91, 140, 255, 0.04),
            rgba(102, 224, 208, 0.26),
            rgba(91, 140, 255, 0.42));
    transition: opacity 0.35s ease;
}

#hero .hero-image-slot::after {
    content: "";
    position: absolute;
    inset: 20% -12% -20% -12%;
    background: radial-gradient(circle, rgba(91, 140, 255, 0.28), transparent 68%);
    filter: blur(36px);
    opacity: 0.35;
    z-index: -1;
    transition: opacity 0.35s ease;
}

#hero .hero-image-slot:hover {
    border-color: rgba(91, 140, 255, 0.45);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
}

#hero .hero-image-slot:hover::before {
    opacity: 0.82;
}

#hero .hero-image-slot:hover::after {
    opacity: 0.8;
}

#hero .hero-mockup {
    transition: transform 0.55s ease, filter 0.35s ease;
}

#hero .hero-image-slot:hover .hero-mockup {
    transform: translateY(-4px) scale(1.02);
    filter: saturate(1.06);
}

#about .type-block {
    transition: transform 0.45s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

#about .type-block:hover {
    transform: translateY(-4px);
}

#about .type-visual img {
    transition: transform 0.45s ease, box-shadow 0.45s ease;
}

#about .type-block:hover .type-visual img {
    transform: translateY(-12px) scale(1.016);
}

.project-card,
.tech-item,
.includes .includes-card,
.contact-form-container,
#process .step {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(150deg, var(--panel-highlight), transparent 60%),
        var(--panel-frost);
    backdrop-filter: blur(6px);
}

.project-card::before,
.tech-item::before,
.includes .includes-card::before,
.contact-form-container::before,
#process .step::before {
    content: "";
    position: absolute;
    inset: -1px;
    opacity: 0;
    pointer-events: none;
    background: linear-gradient(122deg,
            rgba(91, 140, 255, 0.3),
            transparent 36%,
            rgba(102, 224, 208, 0.22) 76%,
            transparent);
    transition: opacity 0.35s ease;
}

.project-card {
    --spot-x: 50%;
    --spot-y: 50%;
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.project-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: radial-gradient(circle at var(--spot-x) var(--spot-y),
            rgba(91, 140, 255, 0.24),
            transparent 46%);
    transition: opacity 0.25s ease;
}

.project-card:hover {
    transform: translateY(-6px);
    border-color: rgba(91, 140, 255, 0.45);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.42);
}

.project-card:hover::before,
.project-card:hover::after,
.tech-item:hover::before,
.includes .includes-card:hover::before,
.contact-form-container:hover::before,
#process .step:hover::before {
    opacity: 1;
}

.tech-item {
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
}

.tech-item:hover {
    transform: translateY(-6px) scale(1.02);
    border-color: rgba(91, 140, 255, 0.52);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.36);
}

#process .step {
    border: 1px solid var(--border-dark);
    border-radius: 14px;
    padding: 22px 20px;
    overflow: visible;
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

#process .step:hover {
    transform: translateY(-6px);
    border-color: rgba(91, 140, 255, 0.45);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.35);
}

.step-number {
    transition: color 0.3s ease, -webkit-text-stroke 0.3s ease, transform 0.3s ease;
}

#process .step:hover .step-number {
    transform: translateY(-2px);
}

.includes .includes-card {
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.includes .includes-card:hover {
    transform: translateY(-5px);
    border-color: rgba(91, 140, 255, 0.4);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.35);
}

.contact-form-container {
    border: 1px solid var(--border-dark);
    border-radius: 16px;
    padding: 26px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.contact-form-container:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.38);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.36);
}

.form-group input,
.form-group textarea {
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
}

.form-group input:hover,
.form-group textarea:hover {
    border-color: rgba(91, 140, 255, 0.35);
}

.section-title {
    position: relative;
    display: inline-block;
}

.section-title::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -11px;
    width: min(156px, 66%);
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg,
            transparent,
            var(--section-accent, var(--primary)) 28%,
            rgba(236, 241, 255, 0.92) 50%,
            var(--section-accent, var(--primary)) 72%,
            transparent);
    opacity: 0.9;
}

.reveal {
    opacity: 0;
    filter: blur(4px);
    transform: translateY(24px) scale(0.985);
    transition:
        opacity 0.75s ease,
        filter 0.75s ease,
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay, 0ms);
}

.reveal.is-visible {
    opacity: 1;
    filter: none;
    transform: none;
}

@media (max-width: 900px) {
    .section-title {
        padding-left: 0;
    }

    .section-title::after {
        width: min(126px, 70%);
        bottom: -10px;
    }

    body::before {
        opacity: 0.34;
        filter: blur(48px);
    }

    body::after {
        opacity: 0.1;
        background-size: 88px 88px;
    }

    .site-header.scrolled {
        padding: 14px 0;
    }

    .contact-form-container {
        padding: 22px;
    }

    #about .type-block:hover,
    .project-card:hover,
    .tech-item:hover,
    #process .step:hover,
    .includes .includes-card:hover,
    .contact-form-container:hover {
        transform: none;
    }

    #about .type-block:hover .type-visual img {
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    body::before,
    body::after,
    .hero-title,
    .logo {
        animation: none !important;
    }

    .reveal {
        opacity: 1 !important;
        filter: none !important;
        transform: none !important;
    }

    #hero .hero-image-slot,
    #hero .hero-mockup {
        transform: none !important;
    }
}

/* Mobile Overhaul */
main section[id] {
    scroll-margin-top: 96px;
}

@media (max-width: 900px) {
    :root {
        --section-padding: 64px;
    }

    .container {
        padding: 0 18px;
    }

    .section-padding {
        padding: var(--section-padding) 0;
    }

    .site-header {
        padding: 14px 0;
    }

    .site-header .container {
        min-height: 48px;
    }

    .logo {
        font-size: 1.08rem;
        letter-spacing: -0.01em;
    }

    .main-nav ul {
        width: min(88vw, 360px);
        padding: 88px 22px 24px;
        justify-content: flex-start;
        align-items: flex-start;
        gap: 14px;
    }

    .main-nav a {
        width: 100%;
        font-size: 1rem;
    }

    .main-nav .btn-nav {
        margin-top: 10px;
        width: 100%;
        text-align: center;
    }

    .hero-section {
        min-height: auto;
        padding: 128px 0 62px;
    }

    .hero-inner {
        gap: 28px;
    }

    .hero-content {
        width: 100%;
    }

    .hero-title {
        font-size: clamp(2rem, 6.2vw, 2.9rem);
        margin-bottom: 16px;
        line-height: 1.08;
    }

    .hero-subtitle {
        font-size: 1rem;
        margin-bottom: 18px;
        max-width: 100%;
    }

    .hero-bullets {
        font-size: 0.98rem;
        margin-bottom: 24px;
    }

    .hero-bullets li {
        margin-bottom: 10px;
    }

    .hero-actions {
        flex-direction: column;
        gap: 10px;
    }

    .hero-actions .btn {
        width: 100%;
    }

    .section-header {
        margin-bottom: 30px;
    }

    .section-header h2 {
        font-size: clamp(1.7rem, 5.8vw, 2.2rem);
    }

    .section-header .section-subtitle {
        font-size: 0.98rem;
        line-height: 1.6;
    }

    #about .about-types {
        margin-top: 14px;
        gap: 34px;
    }

    #about .type-text h3 {
        font-size: 1.1rem;
    }

    #about .type-text p,
    #about .type-points li {
        font-size: 0.95rem;
    }

    #about .type-visual::before {
        inset: -10px;
        border-radius: 18px;
    }

    #about .type-visual img {
        border-radius: 14px;
    }

    .projects-grid {
        gap: 24px;
    }

    .project-card {
        padding: 24px 20px;
    }

    .project-content h3 {
        font-size: clamp(1.22rem, 4.6vw, 1.55rem);
        margin-bottom: 20px;
        line-height: 1.25;
    }

    .project-details {
        gap: 18px;
        margin-bottom: 0;
        grid-template-columns: 1fr;
    }

    .detail-group p {
        font-size: 0.95rem;
        line-height: 1.55;
    }

    .project-details .tags {
        gap: 8px;
        margin-top: 4px;
    }

    .project-details .tags span {
        font-size: 0.75rem;
        padding: 6px 10px;
    }

    #process .process-steps {
        gap: 18px;
    }

    #process .step {
        padding: 18px 16px;
    }

    #services-pages .services-pages-head {
        margin-bottom: 24px;
    }

    #services-pages .services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    #services-pages .service-card {
        padding: 20px 18px 18px;
        border-radius: 15px;
    }

    #services-pages .service-card h3 {
        font-size: 1.08rem;
    }

    #services-pages .service-card p,
    #services-pages .service-card-points li {
        font-size: 0.9rem;
    }

    #services-pages .services-pages-footer {
        padding: 16px;
        border-radius: 15px;
        flex-direction: column;
        align-items: flex-start;
    }

    #services-pages .services-pages-footer .btn {
        width: 100%;
    }

    .step-number {
        font-size: 2.2rem;
        margin-bottom: 10px;
    }

    .step h3 {
        font-size: 1.05rem;
    }

    .step p {
        font-size: 0.92rem;
    }

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

    .tech-item {
        padding: 14px 10px;
        font-size: 0.92rem;
    }

    .includes .includes-card {
        padding: 20px;
    }

    .contact-wrapper {
        gap: 28px;
    }

    .contact-info p {
        margin-bottom: 18px;
        font-size: 0.98rem;
    }

    .contact-list a {
        font-size: 1rem;
        overflow-wrap: anywhere;
    }

    .contact-form-container {
        padding: 18px;
    }

    .form-group {
        margin-bottom: 18px;
    }

    .form-group input,
    .form-group textarea {
        padding: 13px;
        font-size: 0.96rem;
    }

    .site-footer {
        padding: 26px 0;
        font-size: 0.8rem;
    }
}

@media (max-width: 640px) {
    :root {
        --section-padding: 54px;
    }

    .container {
        padding: 0 14px;
    }

    .site-header {
        padding: 12px 0;
    }

    .logo {
        font-size: 0.96rem;
    }

    .menu-toggle span {
        width: 22px;
    }

    .main-nav ul {
        width: 100%;
        max-width: none;
        padding: 86px 20px 22px;
        gap: 12px;
    }

    .hero-section {
        padding: 114px 0 52px;
    }

    .hero-title {
        font-size: clamp(1.82rem, 7vw, 2.2rem);
    }

    .hero-bullets {
        font-size: 0.93rem;
    }

    .hero-bullets li {
        padding-left: 16px;
        line-height: 1.45;
    }

    .section-header {
        margin-bottom: 24px;
    }

    .section-title::after {
        width: min(110px, 68%);
    }

    #services-pages .services-pages-kicker {
        margin-bottom: 10px;
        font-size: 0.7rem;
    }

    #services-pages .section-title::after {
        width: min(118px, 58%);
    }

    #services-pages .services-pages-head {
        margin-bottom: 20px;
    }

    #services-pages .section-title {
        max-width: 100%;
    }

    #services-pages .services-grid {
        grid-template-columns: 1fr;
    }

    #services-pages .service-card {
        padding: 18px 16px 16px;
    }

    #services-pages .service-card-meta {
        align-items: center;
        justify-content: space-between;
        gap: 10px;
    }

    #services-pages .service-card-order {
        min-width: 30px;
        height: 30px;
        border-radius: 9px;
        font-size: 0.73rem;
    }

    #services-pages .service-card-context {
        font-size: 0.73rem;
    }

    .project-card {
        padding: 20px 16px;
    }

    .project-content h3 {
        font-size: 1.18rem;
    }

    .project-details .tags span {
        white-space: normal;
    }

    .tech-grid {
        gap: 10px;
    }

    .tech-item {
        font-size: 0.86rem;
        padding: 12px 8px;
    }

    .includes .includes-card {
        padding: 18px;
    }
}

@media (max-width: 400px) {
    .hero-title {
        font-size: 1.68rem;
    }

    .hero-subtitle {
        font-size: 0.94rem;
    }

    .project-content h3 {
        font-size: 1.08rem;
    }

    .project-details .tags span {
        font-size: 0.72rem;
        padding: 5px 9px;
    }

    .tech-grid {
        grid-template-columns: 1fr;
    }
}

/* Mobile Menu Fix */
@media (max-width: 900px) {
    body.menu-open {
        overflow: hidden;
        touch-action: none;
    }

    main,
    .site-footer {
        transition: filter 0.28s ease, opacity 0.28s ease;
    }

    body.menu-open main,
    body.menu-open .site-footer {
        filter: blur(4px) brightness(0.5);
        opacity: 0.95;
        pointer-events: none;
    }

    .site-header {
        z-index: 3000;
    }

    body.menu-open .site-header {
        background-color: #0b1017;
        backdrop-filter: none;
    }

    .main-nav {
        position: relative;
        z-index: 3001;
    }

    .main-nav::before {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(5, 11, 18, 0.3);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.28s ease;
        z-index: 2098;
    }

    body.menu-open .main-nav::before {
        opacity: 1;
        pointer-events: auto;
    }

    .menu-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        width: 44px;
        height: 44px;
        border: 1px solid var(--border-dark);
        border-radius: 12px;
        background: #151a21;
        z-index: 2102;
    }

    .menu-toggle span {
        width: 19px;
        height: 2px;
        margin: 3px 0;
        border-radius: 99px;
        transform-origin: center;
        transition: transform 0.25s ease, opacity 0.2s ease;
    }

    .menu-toggle.active span:nth-child(1) {
        transform: translateY(5px) rotate(45deg);
    }

    .menu-toggle.active span:nth-child(2) {
        opacity: 0;
    }

    .menu-toggle.active span:nth-child(3) {
        transform: translateY(-5px) rotate(-45deg);
    }

    .main-nav ul {
        position: fixed;
        top: 0;
        right: 0;
        width: min(84vw, 340px);
        height: 100dvh;
        margin: 0;
        padding: 92px 18px 22px;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        gap: 10px;
        background: #0b1119;
        border-left: 1px solid rgba(255, 255, 255, 0.12);
        box-shadow: -22px 0 46px rgba(0, 0, 0, 0.6);
        isolation: isolate;
        transform: translateX(108%);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        overflow-y: auto;
        transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.2s ease, visibility 0.2s ease;
        z-index: 3101;
    }

    .main-nav ul.active {
        transform: translateX(0);
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .main-nav a {
        display: block;
        width: 100%;
        padding: 11px 10px;
        border-radius: 10px;
        font-size: 0.98rem;
        color: #e9edf5;
        background: #121b29;
        position: relative;
        z-index: 3103;
    }

    .main-nav a:hover,
    .main-nav a.active {
        color: #ffffff;
        background: #1e2d45;
    }

    .main-nav a::after {
        display: none;
    }

    .main-nav .btn-nav {
        margin-top: 8px;
        padding: 12px 12px;
        text-align: center;
        border-color: #3f67b8;
        background: #2f4f92;
        color: #ffffff;
    }
}

@media (max-width: 640px) {
    .main-nav ul {
        width: min(88vw, 320px);
        padding-top: 80px;
    }
}

/* Internal SEO pages */
.page-hero {
    padding: 160px 0 70px;
}

.breadcrumbs {
    margin-bottom: 18px;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.breadcrumbs a {
    color: var(--text-muted);
}

.breadcrumbs a:hover {
    color: var(--text-main);
}

.content-stack {
    display: grid;
    gap: 24px;
}

.content-stack p {
    color: var(--text-muted);
}

.link-list {
    display: grid;
    gap: 10px;
    color: var(--text-muted);
}

.link-list li {
    list-style: disc;
    margin-left: 18px;
}

.inline-cta-row {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

/* Service pages structure */
.service-page {
    --section-accent: #86b7ff;
}

.page-hero-service {
    padding-bottom: 54px;
}

.service-hero-layout {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 24px;
    align-items: start;
}

.service-kicker {
    margin: 0 0 14px 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.35);
    background: rgba(91, 140, 255, 0.1);
    color: #c3d6ff;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-title {
    margin-bottom: 16px;
}

.service-page-title::after {
    left: 0;
    transform: none;
    width: min(190px, 56%);
}

.service-page-subtitle {
    margin: 0;
    max-width: 760px;
    color: var(--text-muted);
    font-size: 1.08rem;
    line-height: 1.7;
}

.service-hero-points {
    margin: 26px 0 28px;
    padding: 0;
    display: grid;
    gap: 10px;
}

.service-hero-points li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: #d1ddef;
    font-size: 0.98rem;
    line-height: 1.55;
}

.service-hero-points li::before {
    content: "";
    width: 9px;
    height: 9px;
    margin-top: 7px;
    flex: 0 0 9px;
    border-radius: 999px;
    background: linear-gradient(160deg, #7caeff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(91, 140, 255, 0.18);
}

.service-hero-card h2 {
    margin: 0 0 14px 0;
    font-size: 1.2rem;
}

.service-hero-note {
    margin: 18px 0 0;
    color: #bfd0ef;
    font-size: 0.9rem;
}

.service-value-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.service-value-card h2 {
    font-size: 1.2rem;
    margin-bottom: 12px;
}

.service-value-label {
    margin: 0 0 10px 0;
    color: #95b5f0;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-section-header {
    margin-bottom: 32px;
}

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

.service-grid-2 h3 {
    margin: 0 0 12px;
    font-size: 1.16rem;
}

.service-steps-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.service-step-card {
    display: grid;
    gap: 10px;
}

.service-step-number {
    display: inline-flex;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.36);
    background: rgba(91, 140, 255, 0.14);
    color: #bdd2ff;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.service-step-card h3 {
    margin: 0;
    font-size: 1.12rem;
}

.service-step-card p {
    margin: 0;
}

.service-faq-list {
    display: grid;
    gap: 16px;
    margin-top: 14px;
}

.service-faq-item {
    border: 1px solid rgba(91, 140, 255, 0.2);
    border-radius: 14px;
    padding: 16px;
    background: rgba(91, 140, 255, 0.05);
}

.service-faq-item h3 {
    margin: 0 0 8px;
    font-size: 1.03rem;
}

.service-faq-item p {
    margin: 0;
}

.service-related-card p {
    margin: 10px 0 0;
}

.service-final-cta {
    border: 1px solid rgba(91, 140, 255, 0.26);
    border-radius: 18px;
    padding: 30px 26px;
    text-align: center;
    background:
        linear-gradient(138deg, rgba(91, 140, 255, 0.14), rgba(102, 224, 208, 0.08) 52%, transparent 88%),
        rgba(13, 19, 28, 0.78);
}

.service-final-cta h2 {
    margin: 0 0 10px 0;
    font-size: clamp(1.38rem, 1.16rem + 0.9vw, 2rem);
    line-height: 1.25;
}

.service-final-cta p {
    margin: 0 auto 20px;
    max-width: 760px;
    color: var(--text-muted);
}

/* Corporate service page: high-end UI layer */
.service-page-corporativa .page-hero-service {
    position: relative;
    overflow: clip;
}

.service-page-corporativa .page-hero-service::before,
.service-page-corporativa .page-hero-service::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.service-page-corporativa .page-hero-service::before {
    inset: 8% auto auto -8%;
    width: min(48vw, 560px);
    height: min(48vw, 560px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(91, 140, 255, 0.28), transparent 66%);
    filter: blur(26px);
    opacity: 0.56;
}

.service-page-corporativa .page-hero-service::after {
    inset: auto -12% 4% auto;
    width: min(40vw, 460px);
    height: min(40vw, 460px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(102, 224, 208, 0.18), transparent 70%);
    filter: blur(24px);
    opacity: 0.48;
}

.service-page-corporativa .page-hero-service .container {
    position: relative;
    z-index: 1;
}

.service-page-corporativa .service-hero-layout {
    gap: 28px;
}

.service-page-corporativa .service-hero-main {
    border: 1px solid rgba(91, 140, 255, 0.2);
    border-radius: 20px;
    padding: clamp(20px, 2vw, 28px);
    background:
        linear-gradient(152deg, rgba(91, 140, 255, 0.12), rgba(102, 224, 208, 0.04) 45%, transparent 86%),
        rgba(14, 20, 30, 0.78);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.28);
}

.service-page-corporativa .service-page-title {
    max-width: 17ch;
    font-size: clamp(2rem, 1.6rem + 1.5vw, 3rem);
    background: linear-gradient(98deg, #f3f8ff 12%, #93b5ff 48%, #66e0d0 86%);
    background-size: 190% 190%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: title-shift 9s ease-in-out infinite;
}

.service-page-corporativa .service-proof-strip {
    margin-top: 22px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.service-page-corporativa .service-proof-item {
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 14px;
    padding: 12px 13px;
    background: rgba(91, 140, 255, 0.08);
    display: grid;
    gap: 5px;
    transition: transform 0.22s ease, border-color 0.22s ease, background-color 0.22s ease;
}

.service-page-corporativa .service-proof-item:hover {
    transform: translateY(-2px);
    border-color: rgba(91, 140, 255, 0.45);
    background: rgba(91, 140, 255, 0.14);
}

.service-page-corporativa .service-proof-label {
    color: #9eb8e8;
    font-size: 0.73rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.service-page-corporativa .service-proof-item strong {
    color: #ecf3ff;
    font-size: 0.92rem;
    letter-spacing: -0.01em;
}

.service-mini-kicker {
    margin: 0 0 10px 0;
    color: #9cb5e7;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-corporativa .service-hero-card {
    border-radius: 20px;
    border-color: rgba(91, 140, 255, 0.3);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.34);
}

.service-page-corporativa .service-outcome-list {
    gap: 12px;
}

.service-page-corporativa .service-outcome-list li {
    list-style: none;
    margin-left: 0;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.service-page-corporativa .service-outcome-list li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    flex: 0 0 8px;
    border-radius: 999px;
    background: linear-gradient(160deg, #7caeff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(91, 140, 255, 0.16);
}

.service-page-corporativa .service-value-card,
.service-page-corporativa .service-feature-card,
.service-page-corporativa .service-step-card,
.service-page-corporativa .service-faq-item,
.service-page-corporativa .service-related-card {
    border-color: rgba(91, 140, 255, 0.18);
}

.service-page-corporativa .service-value-card {
    border-top: 2px solid rgba(91, 140, 255, 0.6);
    border-radius: 16px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.service-page-corporativa .service-value-card:hover {
    transform: translateY(-5px);
    border-color: rgba(91, 140, 255, 0.44);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.36);
}

.service-page-corporativa .service-grid-2 {
    gap: 18px;
}

.service-page-corporativa .service-feature-card {
    border-radius: 16px;
    position: relative;
    overflow: hidden;
}

.service-page-corporativa .service-feature-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(132deg, rgba(91, 140, 255, 0.2), transparent 40%, rgba(102, 224, 208, 0.18));
    transition: opacity 0.3s ease;
}

.service-page-corporativa .service-feature-card:hover::before {
    opacity: 1;
}

.service-page-corporativa .service-feature-card:hover {
    border-color: rgba(91, 140, 255, 0.44);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.3);
}

.service-page-corporativa .service-feature-card .link-list li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.service-page-corporativa .service-feature-card .link-list li::before {
    content: "→";
    color: #88b0ff;
    font-size: 0.9rem;
    margin-top: 1px;
}

.service-page-corporativa .service-steps-grid {
    gap: 18px;
    position: relative;
}

.service-page-corporativa .service-step-card {
    border-radius: 16px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.service-page-corporativa .service-step-card:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.46);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

.service-page-corporativa .service-step-number {
    background: linear-gradient(150deg, rgba(91, 140, 255, 0.3), rgba(102, 224, 208, 0.2));
    border-color: rgba(91, 140, 255, 0.55);
}

.service-page-corporativa .service-faq-list {
    gap: 12px;
}

.service-page-corporativa .service-faq-related-card {
    border-radius: 20px;
    padding: clamp(20px, 2.2vw, 30px);
}

.service-page-corporativa .service-faq-head {
    margin-bottom: 18px;
}

.service-page-corporativa .service-faq-head h2 {
    margin: 0 0 10px;
    font-size: clamp(1.35rem, 1.15rem + 0.72vw, 1.9rem);
}

.service-page-corporativa .service-faq-head p {
    margin: 0;
    color: var(--text-muted);
    max-width: 780px;
}

.service-page-corporativa .service-faq-related-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.9fr);
    gap: 16px;
    align-items: start;
}

.service-page-corporativa .service-faq-item {
    border-radius: 14px;
    border: 1px solid rgba(91, 140, 255, 0.22);
    background: rgba(91, 140, 255, 0.06);
    padding: 0;
    overflow: hidden;
}

.service-page-corporativa .service-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 15px 18px;
    font-size: 1rem;
    font-weight: 600;
    color: #e5ecfb;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.service-page-corporativa .service-faq-item summary:hover {
    background: rgba(91, 140, 255, 0.08);
}

.service-page-corporativa .service-faq-item summary::-webkit-details-marker {
    display: none;
}

.service-page-corporativa .service-faq-item summary::after {
    content: "+";
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #bad0ff;
    font-size: 0.95rem;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.service-page-corporativa .service-faq-item[open] summary::after {
    content: "−";
    transform: rotate(180deg);
    border-color: rgba(102, 224, 208, 0.52);
}

.service-page-corporativa .service-faq-item p {
    padding: 0 18px 16px;
    margin: 0;
}

.service-page-corporativa .service-related-inline {
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 16px;
    background:
        linear-gradient(150deg, rgba(91, 140, 255, 0.12), rgba(102, 224, 208, 0.05) 44%, transparent 90%),
        rgba(14, 20, 30, 0.72);
    padding: 16px;
}

.service-page-corporativa .service-related-inline h3 {
    margin: 0 0 10px;
    font-size: 0.95rem;
    letter-spacing: 0.02em;
}

.service-page-corporativa .service-related-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.service-page-corporativa .service-related-list li {
    list-style: none;
}

.service-page-corporativa .service-related-card a,
.service-page-corporativa .service-related-inline a {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 10px;
    padding: 10px 11px;
    border-radius: 11px;
    border: 1px solid rgba(91, 140, 255, 0.24);
    background: rgba(91, 140, 255, 0.08);
    font-weight: 600;
    line-height: 1.35;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.service-page-corporativa .service-related-card a::before,
.service-page-corporativa .service-related-inline a::before {
    display: none;
}

.service-page-corporativa .service-related-card a::after,
.service-page-corporativa .service-related-inline a::after {
    content: "→";
    font-size: 0.95rem;
    opacity: 0.92;
}

.service-page-corporativa .service-related-card a:hover::before,
.service-page-corporativa .service-related-inline a:hover::before {
    transform: none;
}

.service-page-corporativa .service-related-inline a:hover {
    transform: translateX(2px);
    border-color: rgba(102, 224, 208, 0.45);
    background: rgba(102, 224, 208, 0.14);
}

.service-page-corporativa .service-tail-section {
    padding-bottom: 24px;
}

.service-page-corporativa .service-cta-section {
    padding-top: 10px;
    margin-top: -20px;
}

.service-page-corporativa .service-cta-section .container {
    position: relative;
}

.service-page-corporativa .service-cta-section .container::before {
    content: "";
    position: absolute;
    left: clamp(12px, 3.5vw, 42px);
    right: clamp(12px, 3.5vw, 42px);
    top: -12px;
    height: 24px;
    border-radius: 999px;
    pointer-events: none;
    background: radial-gradient(ellipse at center, rgba(91, 140, 255, 0.34), rgba(91, 140, 255, 0) 72%);
    filter: blur(4px);
    opacity: 0.6;
}

.service-page-corporativa .service-final-cta {
    border-radius: 22px;
    padding: clamp(24px, 2.8vw, 40px);
    background:
        radial-gradient(circle at 18% 24%, rgba(91, 140, 255, 0.2), transparent 44%),
        linear-gradient(138deg, rgba(91, 140, 255, 0.16), rgba(102, 224, 208, 0.1) 52%, transparent 90%),
        rgba(13, 19, 28, 0.86);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.36);
}

.service-page-corporativa .service-final-cta-actions {
    justify-content: center;
}

.service-page-corporativa .service-final-cta .btn {
    min-width: 220px;
}

/* Corporate service page v2: expanded structure and richer UI */
.service-page-corporativa {
    --corporate-primary-rgb: 104, 157, 255;
    --corporate-secondary-rgb: 102, 224, 208;
    --corporate-primary: #7faeff;
    --corporate-secondary: #66e0d0;
}

.service-page-corporativa .corporate-hero-section {
    padding-bottom: 60px;
}

.service-page-corporativa .corporate-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.88fr);
    gap: 20px;
    align-items: stretch;
}

.service-page-corporativa .corporate-hero-main {
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.28);
    border-radius: 22px;
    padding: clamp(22px, 2.4vw, 34px);
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 12%, rgba(var(--corporate-primary-rgb), 0.24), transparent 42%),
        linear-gradient(148deg, rgba(var(--corporate-primary-rgb), 0.16), rgba(var(--corporate-secondary-rgb), 0.08) 52%, transparent 92%),
        rgba(13, 19, 28, 0.84);
    box-shadow: 0 24px 44px rgba(0, 0, 0, 0.34);
}

.service-page-corporativa .corporate-hero-main::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.34;
    background: linear-gradient(124deg, rgba(var(--corporate-primary-rgb), 0.26), transparent 40%, rgba(var(--corporate-secondary-rgb), 0.14) 78%, transparent);
}

.service-page-corporativa .corporate-hero-main>* {
    position: relative;
    z-index: 1;
}

.service-page-corporativa .corporate-hero-main .service-page-title {
    max-width: 18ch;
    margin-top: 0;
    margin-bottom: 14px;
}

.service-page-corporativa .corporate-hero-main .service-page-subtitle {
    max-width: 72ch;
}

.service-page-corporativa .corporate-hero-points {
    margin-top: 22px;
}

.service-page-corporativa .corporate-hero-actions {
    margin-top: 4px;
}

.service-page-corporativa .corporate-hero-side {
    border-radius: 22px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.34);
    padding: clamp(20px, 2.2vw, 28px);
    display: grid;
    gap: 12px;
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(148deg, rgba(var(--corporate-primary-rgb), 0.2), rgba(var(--corporate-secondary-rgb), 0.1) 56%, transparent 90%),
        rgba(13, 19, 28, 0.84);
}

.service-page-corporativa .corporate-hero-side::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(126deg, rgba(var(--corporate-primary-rgb), 0.3), transparent 42%, rgba(var(--corporate-secondary-rgb), 0.2) 76%, transparent);
    transition: opacity 0.3s ease;
}

.service-page-corporativa .corporate-hero-side:hover::before {
    opacity: 1;
}

.service-page-corporativa .corporate-hero-side>* {
    position: relative;
    z-index: 1;
}

.service-page-corporativa .corporate-hero-side h2 {
    margin: 0;
    font-size: clamp(1.22rem, 1.08rem + 0.54vw, 1.56rem);
}

.service-page-corporativa .corporate-side-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 9px;
}

.service-page-corporativa .corporate-side-list li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: #d7e3f8;
    line-height: 1.48;
}

.service-page-corporativa .corporate-side-list li::before {
    content: "→";
    color: #9ac2ff;
    margin-top: 1px;
    font-size: 0.88rem;
}

.service-page-corporativa .corporate-side-note {
    margin: 0;
    color: #c8d7ef;
    font-size: 0.9rem;
}

.service-page-corporativa .corporate-kpi-strip {
    margin-top: 16px;
}

.service-page-corporativa .corporate-kpi-strip .service-proof-item {
    border-color: rgba(var(--corporate-primary-rgb), 0.32);
    background: linear-gradient(140deg, rgba(var(--corporate-primary-rgb), 0.18), rgba(var(--corporate-secondary-rgb), 0.08));
}

.service-page-corporativa .corporate-fit-section {
    padding-top: 30px;
}

.service-page-corporativa .corporate-fit-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.service-page-corporativa .corporate-fit-card {
    border-radius: 18px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.28);
    display: grid;
    gap: 10px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.service-page-corporativa .corporate-fit-card h3 {
    margin: 0;
    font-size: 1.13rem;
    color: #edf3ff;
}

.service-page-corporativa .corporate-fit-card p {
    margin: 0;
    color: #cfdcf0;
}

.service-page-corporativa .corporate-fit-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--corporate-primary-rgb), 0.5);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.34);
}

.service-page-corporativa .corporate-architecture-section {
    padding-top: 16px;
}

.service-page-corporativa .corporate-architecture-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.75fr);
    gap: 16px;
    align-items: start;
}

.service-page-corporativa .corporate-architecture-map,
.service-page-corporativa .corporate-architecture-side {
    border-radius: 20px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.26);
}

.service-page-corporativa .corporate-inline-head {
    margin-bottom: 20px;
    text-align: left;
}

.service-page-corporativa .corporate-inline-head .section-title::after {
    left: 0;
    transform: none;
    width: min(220px, 62%);
}

.service-page-corporativa .corporate-inline-head .section-subtitle {
    margin-left: 0;
    margin-right: 0;
}

.service-page-corporativa .corporate-architecture-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
    position: relative;
}

.service-page-corporativa .corporate-architecture-list::before {
    content: "";
    position: absolute;
    left: 16px;
    top: 14px;
    bottom: 14px;
    width: 1px;
    background: linear-gradient(180deg, rgba(var(--corporate-primary-rgb), 0.5), rgba(var(--corporate-secondary-rgb), 0.5));
    opacity: 0.7;
}

.service-page-corporativa .corporate-architecture-item {
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.24);
    border-radius: 14px;
    padding: 14px 15px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: start;
    background: rgba(var(--corporate-primary-rgb), 0.08);
    transition: transform 0.24s ease, border-color 0.24s ease, background-color 0.24s ease;
}

.service-page-corporativa .corporate-architecture-item:hover {
    transform: translateX(3px);
    border-color: rgba(var(--corporate-secondary-rgb), 0.46);
    background: rgba(var(--corporate-primary-rgb), 0.12);
}

.service-page-corporativa .corporate-architecture-item h3 {
    margin: 1px 0 6px;
    font-size: 1.04rem;
}

.service-page-corporativa .corporate-architecture-item p {
    margin: 0;
    color: #d2ddef;
    line-height: 1.5;
}

.service-page-corporativa .corporate-architecture-side {
    display: grid;
    gap: 12px;
    background:
        linear-gradient(150deg, rgba(var(--corporate-primary-rgb), 0.16), rgba(var(--corporate-secondary-rgb), 0.08) 48%, transparent 90%),
        rgba(13, 19, 28, 0.82);
}

.service-page-corporativa .corporate-architecture-side h3 {
    margin: 0;
    font-size: 1.16rem;
    color: #eff5ff;
}

.service-page-corporativa .corporate-side-checklist {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 9px;
}

.service-page-corporativa .corporate-side-checklist li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d6e2f4;
}

.service-page-corporativa .corporate-side-checklist li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    border-radius: 999px;
    flex: 0 0 8px;
    background: linear-gradient(160deg, #8dbbff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(var(--corporate-primary-rgb), 0.16);
}

.service-page-corporativa .corporate-includes-section {
    padding-top: 28px;
}

.service-page-corporativa .corporate-includes-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.service-page-corporativa .corporate-include-card {
    border-radius: 16px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.22);
    display: grid;
    gap: 10px;
    position: relative;
    overflow: hidden;
}

.service-page-corporativa .corporate-include-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(132deg, rgba(var(--corporate-primary-rgb), 0.24), transparent 40%, rgba(var(--corporate-secondary-rgb), 0.2));
    transition: opacity 0.3s ease;
}

.service-page-corporativa .corporate-include-card:hover::before {
    opacity: 1;
}

.service-page-corporativa .corporate-include-card>* {
    position: relative;
    z-index: 1;
}

.service-page-corporativa .corporate-include-card h3 {
    margin: 0;
    font-size: 1.06rem;
}

.service-page-corporativa .corporate-include-card .link-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.service-page-corporativa .corporate-include-card .link-list li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d4e0f2;
    line-height: 1.45;
}

.service-page-corporativa .corporate-include-card .link-list li::before {
    content: "→";
    color: #9cc3ff;
    font-size: 0.88rem;
    margin-top: 1px;
}

.service-page-corporativa .corporate-scenarios-section {
    padding-top: 26px;
}

.service-page-corporativa .corporate-scenarios-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.service-page-corporativa .corporate-scenario-card {
    border-radius: 17px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.26);
    display: grid;
    gap: 10px;
}

.service-page-corporativa .corporate-scenario-card h3 {
    margin: 0;
    font-size: 1.08rem;
}

.service-page-corporativa .corporate-scenario-card p {
    margin: 0;
    color: #d2deef;
}

.service-page-corporativa .corporate-scenario-tag {
    margin: 0;
    color: #9bb8ea;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-corporativa .corporate-process-section {
    padding-top: 32px;
}

.service-page-corporativa .corporate-process-head {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
    gap: 16px;
    align-items: start;
    margin-bottom: 18px;
}

.service-page-corporativa .corporate-process-header {
    margin-bottom: 0;
    text-align: left;
}

.service-page-corporativa .corporate-process-header .section-title::after {
    left: 0;
    transform: none;
    width: min(214px, 60%);
}

.service-page-corporativa .corporate-process-header .section-subtitle {
    margin-left: 0;
    margin-right: 0;
    max-width: 66ch;
}

.service-page-corporativa .corporate-process-commitment {
    border-radius: 18px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.28);
    display: grid;
    gap: 11px;
    background:
        linear-gradient(148deg, rgba(var(--corporate-primary-rgb), 0.18), rgba(var(--corporate-secondary-rgb), 0.08) 56%, transparent 92%),
        rgba(13, 19, 28, 0.84);
}

.service-page-corporativa .corporate-process-commitment h3 {
    margin: 0;
    font-size: 1.12rem;
    color: #edf4ff;
}

.service-page-corporativa .corporate-process-commitment-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.service-page-corporativa .corporate-process-commitment-list li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: #d4e0f2;
}

.service-page-corporativa .corporate-process-commitment-list li::before {
    content: "→";
    color: #9cc3ff;
    margin-top: 1px;
    font-size: 0.88rem;
}

.service-page-corporativa .corporate-process-timeline {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    position: relative;
}

.service-page-corporativa .corporate-process-timeline::before {
    content: "";
    position: absolute;
    left: calc(50% - 0.5px);
    top: 12px;
    bottom: 12px;
    width: 1px;
    background: linear-gradient(180deg, rgba(var(--corporate-primary-rgb), 0.42), rgba(var(--corporate-secondary-rgb), 0.44));
    opacity: 0.58;
    pointer-events: none;
}

.service-page-corporativa .corporate-process-stage {
    border-radius: 18px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.26);
    display: grid;
    gap: 11px;
    position: relative;
    overflow: hidden;
    transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
}

.service-page-corporativa .corporate-process-stage::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 2px;
    background: linear-gradient(90deg, rgba(var(--corporate-primary-rgb), 0.9), rgba(var(--corporate-secondary-rgb), 0.72));
    opacity: 0.86;
}

.service-page-corporativa .corporate-process-stage:nth-child(even) {
    margin-top: 26px;
}

.service-page-corporativa .corporate-process-stage:last-child {
    grid-column: 1 / -1;
    max-width: min(560px, 100%);
    justify-self: center;
    margin-top: 8px;
}

.service-page-corporativa .corporate-stage-label {
    margin: 0;
    color: #9db9e9;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-corporativa .corporate-stage-head {
    display: flex;
    align-items: center;
    gap: 10px;
}

.service-page-corporativa .corporate-stage-head h3 {
    margin: 0;
    font-size: 1.06rem;
}

.service-page-corporativa .corporate-process-stage p {
    margin: 0;
    color: #d4e0f2;
    font-size: 0.95rem;
    line-height: 1.55;
}

.service-page-corporativa .corporate-stage-points {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.service-page-corporativa .corporate-stage-points li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: #cfdbef;
    line-height: 1.45;
    font-size: 0.92rem;
}

.service-page-corporativa .corporate-stage-points li::before {
    content: "";
    width: 7px;
    height: 7px;
    margin-top: 7px;
    border-radius: 999px;
    flex: 0 0 7px;
    background: linear-gradient(160deg, #8dbbff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(var(--corporate-primary-rgb), 0.14);
}

.service-page-corporativa .corporate-process-stage:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--corporate-primary-rgb), 0.52);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

.service-page-corporativa .corporate-decision-section {
    padding-top: 30px;
}

.service-page-corporativa .corporate-decision-card {
    border-radius: 22px;
    border: 1px solid rgba(var(--corporate-primary-rgb), 0.3);
    background:
        linear-gradient(145deg, rgba(var(--corporate-primary-rgb), 0.16), rgba(var(--corporate-secondary-rgb), 0.08) 52%, transparent 90%),
        rgba(13, 19, 28, 0.84);
}

.service-page-corporativa .corporate-faq-stack {
    margin-top: 0;
}

.service-page-corporativa .corporate-decision-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.9fr);
    gap: 16px;
    align-items: start;
}

.service-page-corporativa .corporate-faq-item {
    position: relative;
    isolation: isolate;
    backdrop-filter: blur(6px);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.service-page-corporativa .corporate-faq-item::before,
.service-page-corporativa .corporate-faq-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.34s ease;
}

.service-page-corporativa .corporate-faq-item::before {
    background: linear-gradient(124deg, rgba(var(--corporate-primary-rgb), 0.34), transparent 38%, rgba(var(--corporate-secondary-rgb), 0.2) 74%, transparent);
}

.service-page-corporativa .corporate-faq-item::after {
    background: radial-gradient(circle at 15% 2%, rgba(255, 255, 255, 0.2), transparent 42%);
}

.service-page-corporativa .corporate-faq-item:hover {
    transform: translateY(-3px);
    border-color: rgba(var(--corporate-primary-rgb), 0.48);
    background: rgba(var(--corporate-primary-rgb), 0.14);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.3);
}

.service-page-corporativa .corporate-faq-item:hover::before,
.service-page-corporativa .corporate-faq-item:hover::after {
    opacity: 1;
}

.service-page-corporativa .corporate-faq-item summary {
    color: #eaf1ff;
}

.service-page-corporativa .corporate-faq-item p {
    color: #d8e4f4;
}

.service-page-corporativa .corporate-related-box {
    border-color: rgba(var(--corporate-primary-rgb), 0.3);
}

.service-page-corporativa .corporate-final-section {
    padding-top: 12px;
}

.service-page-corporativa .corporate-final-cta {
    border-color: rgba(var(--corporate-primary-rgb), 0.36);
    background:
        radial-gradient(circle at 18% 22%, rgba(var(--corporate-primary-rgb), 0.24), transparent 44%),
        radial-gradient(circle at 84% 74%, rgba(var(--corporate-secondary-rgb), 0.2), transparent 48%),
        linear-gradient(138deg, rgba(var(--corporate-primary-rgb), 0.2), rgba(var(--corporate-secondary-rgb), 0.11) 54%, transparent 90%),
        rgba(13, 19, 28, 0.88);
}

.service-page-corporativa .corporate-final-actions {
    justify-content: center;
}

.service-page-corporativa .btn-primary {
    border-color: rgba(var(--corporate-primary-rgb), 0.7);
    background: linear-gradient(132deg, #a5c8ff 0%, #7caeff 46%, #71e3d3 100%);
    color: #0e1d2f;
    box-shadow: 0 12px 28px rgba(var(--corporate-primary-rgb), 0.3);
}

.service-page-corporativa .btn-primary:hover {
    border-color: rgba(var(--corporate-secondary-rgb), 0.68);
    background: linear-gradient(132deg, #bbd5ff 0%, #93bbff 46%, #87ecde 100%);
    color: #0a1a2b;
    box-shadow: 0 16px 34px rgba(var(--corporate-secondary-rgb), 0.3);
}

.service-page-corporativa .btn-secondary {
    border-color: rgba(var(--corporate-primary-rgb), 0.42);
    background: linear-gradient(145deg, rgba(var(--corporate-primary-rgb), 0.12), rgba(var(--corporate-secondary-rgb), 0.08));
    color: #dce8fb;
}

.service-page-corporativa .btn-secondary:hover {
    border-color: rgba(var(--corporate-secondary-rgb), 0.52);
    background: linear-gradient(145deg, rgba(var(--corporate-primary-rgb), 0.2), rgba(var(--corporate-secondary-rgb), 0.16));
}

@media (max-width: 1180px) {
    .service-page-corporativa .corporate-includes-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .service-page-corporativa .corporate-process-head {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1024px) {
    .service-page-corporativa .corporate-hero-shell,
    .service-page-corporativa .corporate-architecture-layout,
    .service-page-corporativa .corporate-fit-grid,
    .service-page-corporativa .corporate-scenarios-grid {
        grid-template-columns: 1fr;
    }

    .service-page-corporativa .service-proof-strip.corporate-kpi-strip,
    .service-page-corporativa .corporate-decision-layout {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .service-page-corporativa .corporate-process-timeline {
        grid-template-columns: 1fr;
    }

    .service-page-corporativa .corporate-process-timeline::before {
        display: none;
    }

    .service-page-corporativa .corporate-process-stage:nth-child(even),
    .service-page-corporativa .corporate-process-stage:last-child {
        margin-top: 0;
        grid-column: auto;
        max-width: 100%;
        justify-self: stretch;
    }
}

@media (max-width: 760px) {
    .service-page-corporativa .corporate-hero-main,
    .service-page-corporativa .corporate-hero-side {
        border-radius: 16px;
        padding: 18px 14px;
    }

    .service-page-corporativa .corporate-kpi-strip {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .service-page-corporativa .corporate-decision-layout {
        grid-template-columns: 1fr;
    }

    .service-page-corporativa .corporate-inline-head .section-title::after {
        width: min(188px, 68%);
    }

    .service-page-corporativa .corporate-process-commitment {
        padding: 16px 14px;
    }

    .service-page-corporativa .corporate-stage-head {
        align-items: flex-start;
    }

    .service-page-corporativa .corporate-stage-head h3 {
        font-size: 1.01rem;
        line-height: 1.35;
    }

    .service-page-corporativa .corporate-architecture-item {
        padding: 12px;
        gap: 10px;
    }

    .service-page-corporativa .corporate-includes-grid {
        grid-template-columns: 1fr;
    }
}

/* Landing service page: conversion-first UI layer */
.service-page-landing {
    --section-accent: #66dccc;
    --landing-primary-rgb: 89, 225, 208;
    --landing-secondary-rgb: 255, 179, 103;
    --landing-primary: #5de3d2;
    --landing-secondary: #ffc179;
}

.service-page-landing .page-hero-landing {
    padding-bottom: 58px;
    position: relative;
    overflow: clip;
}

.service-page-landing .page-hero-landing::before,
.service-page-landing .page-hero-landing::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.service-page-landing .page-hero-landing::before {
    inset: 8% auto auto -8%;
    width: min(48vw, 560px);
    height: min(48vw, 560px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(var(--landing-primary-rgb), 0.26), transparent 67%);
    filter: blur(26px);
    opacity: 0.6;
}

.service-page-landing .page-hero-landing::after {
    inset: auto -10% 4% auto;
    width: min(38vw, 460px);
    height: min(38vw, 460px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(var(--landing-secondary-rgb), 0.2), transparent 70%);
    filter: blur(23px);
    opacity: 0.5;
}

.service-page-landing .page-hero-landing .container {
    position: relative;
    z-index: 1;
}

.service-page-landing .landing-hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 20px;
    align-items: start;
}

.service-page-landing .landing-intent-grid {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.service-page-landing .landing-intent-item {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.23);
    border-radius: 14px;
    padding: 12px 13px;
    background:
        linear-gradient(150deg, rgba(var(--landing-primary-rgb), 0.12), rgba(var(--landing-secondary-rgb), 0.07) 55%, transparent 95%),
        rgba(14, 20, 30, 0.68);
    display: grid;
    gap: 4px;
}

.service-page-landing .landing-intent-item span {
    color: #9ad7d0;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-landing .landing-intent-item strong {
    color: #e8faf7;
    font-size: 0.93rem;
}

.service-page-landing .landing-intent-item p {
    margin: 0;
    color: #c9dced;
    font-size: 0.86rem;
    line-height: 1.48;
}

.service-page-landing .landing-hero-copy {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 20px;
    padding: clamp(20px, 2vw, 30px);
    background:
        linear-gradient(148deg, rgba(var(--landing-primary-rgb), 0.16), rgba(var(--landing-secondary-rgb), 0.08) 46%, transparent 88%),
        rgba(14, 20, 30, 0.8);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.service-page-landing .service-kicker {
    border-color: rgba(var(--landing-primary-rgb), 0.4);
    background: rgba(var(--landing-primary-rgb), 0.12);
    color: #c4f3ec;
}

.service-page-landing .landing-main-title {
    max-width: 15ch;
    margin-bottom: 16px;
    font-size: clamp(2rem, 1.65rem + 1.45vw, 3.05rem);
    color: #eef8f6;
}

.service-page-landing .landing-main-title::after {
    left: 0;
    transform: none;
    width: min(220px, 62%);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .service-page-landing .landing-main-title {
        background: linear-gradient(96deg, #f6fbff 8%, #78e2d6 50%, #ffc179 88%);
        background-size: 190% 190%;
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        -webkit-text-fill-color: transparent;
        animation: title-shift 9s ease-in-out infinite;
    }
}

.service-page-landing .landing-main-subtitle {
    margin: 0;
    max-width: 740px;
    color: var(--text-muted);
    font-size: 1.06rem;
    line-height: 1.7;
}

.service-page-landing .landing-hero-actions {
    margin-top: 24px;
}

.service-page-landing .btn-primary {
    background: linear-gradient(135deg, #5de3d2 0%, #80ebdd 54%, #ffc987 118%);
    border-color: rgba(var(--landing-primary-rgb), 0.78);
    color: #05221e;
    box-shadow: 0 10px 24px rgba(var(--landing-primary-rgb), 0.24);
}

.service-page-landing .btn-primary:hover {
    background: linear-gradient(135deg, #6be8d8 0%, #97f1e6 52%, #ffd59f 118%);
    border-color: rgba(var(--landing-primary-rgb), 0.9);
    color: #041f1c;
    box-shadow: 0 14px 30px rgba(var(--landing-primary-rgb), 0.32);
}

.service-page-landing .btn-secondary {
    border-color: rgba(var(--landing-primary-rgb), 0.42);
    background: linear-gradient(145deg, rgba(var(--landing-primary-rgb), 0.12), rgba(var(--landing-secondary-rgb), 0.07));
    color: #dff8f4;
}

.service-page-landing .btn-secondary:hover {
    background: linear-gradient(145deg, rgba(var(--landing-primary-rgb), 0.2), rgba(var(--landing-secondary-rgb), 0.14));
    border-color: rgba(var(--landing-primary-rgb), 0.68);
    color: #f4fffd;
    box-shadow: 0 10px 24px rgba(var(--landing-primary-rgb), 0.22);
}

.service-page-landing .btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(var(--landing-primary-rgb), 0.34);
}

.service-page-landing .landing-hero-side {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.3);
    border-radius: 18px;
    padding: clamp(18px, 2vw, 24px);
    background:
        linear-gradient(152deg, rgba(var(--landing-primary-rgb), 0.16), rgba(var(--landing-secondary-rgb), 0.09) 50%, transparent 90%),
        rgba(14, 21, 30, 0.75);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.34);
    display: grid;
    gap: 14px;
}

.service-page-landing .landing-side-kicker {
    margin: 0;
    color: #9fddd5;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-landing .landing-hero-side h2,
.service-page-landing .landing-head-compact h2 {
    margin: 0;
    font-size: clamp(1.3rem, 1.1rem + 0.7vw, 1.88rem);
    line-height: 1.28;
}

.service-page-landing .landing-side-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

.service-page-landing .landing-side-list li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d8eaf2;
    line-height: 1.52;
}

.service-page-landing .landing-side-list li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    border-radius: 999px;
    flex: 0 0 8px;
    background: linear-gradient(160deg, #67e0d1, #ffba73);
    box-shadow: 0 0 0 4px rgba(var(--landing-primary-rgb), 0.16);
}

.service-page-landing .landing-side-metrics {
    display: grid;
    gap: 8px;
}

.service-page-landing .landing-metric {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.28);
    border-radius: 11px;
    padding: 10px 11px;
    display: grid;
    gap: 3px;
    background: rgba(var(--landing-primary-rgb), 0.1);
}

.service-page-landing .landing-metric span {
    color: #9edbd4;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.service-page-landing .landing-metric strong {
    color: #e7faf7;
    font-size: 0.93rem;
}

.service-page-landing .landing-rail-section {
    padding-top: 16px;
}

.service-page-landing .landing-rail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: 18px;
    align-items: start;
}

.service-page-landing .landing-rail-map,
.service-page-landing .landing-rail-panel {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.23);
    border-radius: 18px;
    padding: clamp(18px, 2vw, 24px);
    background:
        linear-gradient(150deg, rgba(var(--landing-primary-rgb), 0.11), rgba(var(--landing-secondary-rgb), 0.06) 44%, transparent 90%),
        rgba(14, 20, 30, 0.72);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.3);
}

.service-page-landing .landing-head-compact p {
    margin: 0;
    color: var(--text-muted);
    max-width: 760px;
}

.service-page-landing .landing-head-compact .section-title {
    margin: 0 0 12px;
}

.service-page-landing .landing-head-compact .section-title::after {
    left: 0;
    transform: none;
    width: min(200px, 60%);
}

.service-page-landing .landing-rail-list {
    margin: 18px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 11px;
}

.service-page-landing .landing-rail-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 11px;
    align-items: start;
    border: 1px solid rgba(var(--landing-primary-rgb), 0.22);
    border-radius: 13px;
    padding: 12px 13px;
    background: rgba(var(--landing-primary-rgb), 0.08);
}

.service-page-landing .landing-rail-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid rgba(var(--landing-primary-rgb), 0.54);
    background: linear-gradient(155deg, rgba(var(--landing-primary-rgb), 0.32), rgba(var(--landing-secondary-rgb), 0.25));
    color: #d9f6f1;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.06em;
}

.service-page-landing .landing-rail-item h3 {
    margin: 3px 0 6px;
    font-size: 1.01rem;
}

.service-page-landing .landing-rail-item p {
    margin: 0;
    color: #d6e5f1;
    line-height: 1.48;
}

.service-page-landing .landing-rail-panel h3 {
    margin: 0;
    font-size: clamp(1.15rem, 1.05rem + 0.46vw, 1.45rem);
}

.service-page-landing .landing-benefit-list {
    margin: 14px 0 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

.service-page-landing .landing-benefit-list li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d8e8f2;
    line-height: 1.52;
}

.service-page-landing .landing-benefit-list li::before {
    content: "→";
    color: #8de7dc;
    font-size: 0.9rem;
    margin-top: 1px;
}

.service-page-landing .landing-rail-panel .btn {
    margin-top: 4px;
}

.service-page-landing .landing-pattern-head {
    margin-bottom: 24px;
}

.service-page-landing .landing-pattern-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.service-page-landing .landing-pattern-card {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 16px;
    padding: 16px 15px;
    background:
        linear-gradient(156deg, rgba(var(--landing-primary-rgb), 0.13), rgba(var(--landing-secondary-rgb), 0.07) 46%, transparent 88%),
        rgba(14, 20, 30, 0.7);
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.service-page-landing .landing-pattern-featured {
    border-color: rgba(var(--landing-secondary-rgb), 0.44);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.3);
    position: relative;
    overflow: hidden;
}

.service-page-landing .landing-pattern-featured::before {
    content: "Recomendado";
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #1d1f25;
    background: linear-gradient(135deg, #ffd29f, #f1a95f);
    border-radius: 999px;
    padding: 5px 8px;
}

.service-page-landing .landing-pattern-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--landing-primary-rgb), 0.48);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32);
}

.service-page-landing .landing-pattern-tag {
    margin: 0;
    color: #a0ddd5;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.service-page-landing .landing-pattern-card h3 {
    margin: 0;
    font-size: 1.06rem;
}

.service-page-landing .landing-pattern-card p {
    margin: 0;
    color: #d4e4f1;
    line-height: 1.52;
}

.service-page-landing .landing-pattern-link {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: #dff8f5;
    text-decoration: none;
}

.service-page-landing .landing-pattern-link::after {
    content: "→";
    font-size: 0.92rem;
    transition: transform 0.2s ease;
}

.service-page-landing .landing-pattern-link:hover::after {
    transform: translateX(3px);
}

.service-page-landing .landing-build-shell {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 20px;
    padding: clamp(20px, 2.2vw, 30px);
    background:
        linear-gradient(148deg, rgba(var(--landing-primary-rgb), 0.14), rgba(var(--landing-secondary-rgb), 0.08) 52%, transparent 92%),
        rgba(13, 20, 30, 0.8);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.32);
}

.service-page-landing .landing-build-grid {
    margin-top: 18px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.service-page-landing .landing-build-item {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 14px;
    padding: 13px 13px;
    background: rgba(var(--landing-primary-rgb), 0.08);
    display: grid;
    gap: 7px;
}

.service-page-landing .landing-build-step {
    display: inline-flex;
    width: fit-content;
    padding: 4px 9px;
    border-radius: 999px;
    border: 1px solid rgba(var(--landing-primary-rgb), 0.58);
    background: linear-gradient(150deg, rgba(var(--landing-primary-rgb), 0.3), rgba(var(--landing-secondary-rgb), 0.21));
    color: #d6f4ee;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.service-page-landing .landing-build-item h3 {
    margin: 0;
    font-size: 1rem;
}

.service-page-landing .landing-build-item p {
    margin: 0;
    color: #d5e5f1;
    line-height: 1.5;
}

.service-page-landing .landing-decision-card {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 20px;
    padding: clamp(20px, 2.2vw, 30px);
    background:
        linear-gradient(148deg, rgba(var(--landing-primary-rgb), 0.12), rgba(var(--landing-secondary-rgb), 0.06) 50%, transparent 90%),
        rgba(14, 20, 30, 0.74);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: blur(6px);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.service-page-landing .landing-decision-card::before,
.service-page-landing .landing-decision-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s ease;
}

.service-page-landing .landing-decision-card::before {
    background: linear-gradient(130deg, rgba(var(--landing-primary-rgb), 0.26), transparent 38%, rgba(var(--landing-secondary-rgb), 0.2) 72%, transparent);
}

.service-page-landing .landing-decision-card::after {
    background: radial-gradient(circle at 14% 0%, rgba(255, 255, 255, 0.22), transparent 42%);
}

.service-page-landing .landing-decision-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--landing-primary-rgb), 0.46);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.32);
}

.service-page-landing .landing-decision-card:hover::before,
.service-page-landing .landing-decision-card:hover::after {
    opacity: 1;
}

.service-page-landing .landing-decision-layout {
    margin-top: 16px;
    display: grid;
    grid-template-columns: minmax(0, 1.36fr) minmax(0, 0.9fr);
    gap: 16px;
    align-items: start;
}

.service-page-landing .landing-faq-stack {
    display: grid;
    gap: 11px;
}

.service-page-landing .landing-faq-item {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 14px;
    background: rgba(var(--landing-primary-rgb), 0.08);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: blur(6px);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.service-page-landing .landing-faq-item::before,
.service-page-landing .landing-faq-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s ease;
}

.service-page-landing .landing-faq-item::before {
    background: linear-gradient(126deg, rgba(var(--landing-primary-rgb), 0.32), transparent 38%, rgba(var(--landing-secondary-rgb), 0.24) 74%, transparent);
}

.service-page-landing .landing-faq-item::after {
    background: radial-gradient(circle at 18% 2%, rgba(255, 255, 255, 0.2), transparent 44%);
}

.service-page-landing .landing-faq-item:hover {
    transform: translateY(-3px);
    border-color: rgba(var(--landing-primary-rgb), 0.52);
    background: rgba(var(--landing-primary-rgb), 0.14);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.28);
}

.service-page-landing .landing-faq-item:hover::before,
.service-page-landing .landing-faq-item:hover::after {
    opacity: 1;
}

.service-page-landing .landing-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 16px;
    font-size: 0.98rem;
    font-weight: 600;
    color: #e5f4fa;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.service-page-landing .landing-faq-item summary:hover {
    background: rgba(var(--landing-primary-rgb), 0.12);
}

.service-page-landing .landing-faq-item summary::-webkit-details-marker {
    display: none;
}

.service-page-landing .landing-faq-item summary::after {
    content: "+";
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid rgba(var(--landing-primary-rgb), 0.48);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #c9f4ec;
    font-size: 0.95rem;
    flex: 0 0 auto;
}

.service-page-landing .landing-faq-item[open] summary::after {
    content: "−";
    border-color: rgba(var(--landing-secondary-rgb), 0.52);
}

.service-page-landing .landing-faq-item p {
    margin: 0;
    padding: 0 16px 15px;
    color: #d5e6f1;
}

.service-page-landing .landing-related-box {
    border: 1px solid rgba(var(--landing-primary-rgb), 0.24);
    border-radius: 16px;
    padding: 15px;
    background:
        linear-gradient(150deg, rgba(var(--landing-primary-rgb), 0.12), rgba(var(--landing-secondary-rgb), 0.07) 48%, transparent 92%),
        rgba(14, 20, 30, 0.72);
}

.service-page-landing .landing-related-box h3 {
    margin: 0 0 10px;
    font-size: 0.95rem;
}

.service-page-landing .landing-related-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.service-page-landing .landing-related-list li {
    list-style: none;
}

.service-page-landing .landing-related-list a {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 10px;
    border: 1px solid rgba(var(--landing-primary-rgb), 0.28);
    background: rgba(var(--landing-primary-rgb), 0.1);
    font-weight: 600;
    line-height: 1.35;
}

.service-page-landing .landing-related-list a::after {
    content: "→";
    font-size: 0.95rem;
    opacity: 0.92;
}

.service-page-landing .landing-related-list a:hover {
    border-color: rgba(var(--landing-secondary-rgb), 0.5);
    background: rgba(var(--landing-secondary-rgb), 0.14);
}

.service-page-landing .landing-final-section {
    padding-top: 8px;
}

.service-page-landing .landing-final-cta {
    border-radius: 22px;
    padding: clamp(24px, 2.8vw, 40px);
    text-align: center;
    background:
        radial-gradient(circle at 15% 22%, rgba(var(--landing-primary-rgb), 0.22), transparent 43%),
        radial-gradient(circle at 85% 20%, rgba(var(--landing-secondary-rgb), 0.18), transparent 45%),
        linear-gradient(138deg, rgba(var(--landing-primary-rgb), 0.14), rgba(var(--landing-secondary-rgb), 0.1) 55%, transparent 92%),
        rgba(13, 20, 29, 0.86);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.36);
}

.service-page-landing .landing-final-cta h2 {
    margin: 0 0 10px;
    font-size: clamp(1.38rem, 1.16rem + 0.9vw, 2rem);
    line-height: 1.25;
}

.service-page-landing .landing-final-cta p {
    margin: 0 auto 20px;
    max-width: 760px;
    color: var(--text-muted);
}

.service-page-landing .landing-final-note {
    margin: 14px 0 0;
    color: #c5d9eb;
    font-size: 0.9rem;
}

.service-page-landing .landing-final-actions {
    justify-content: center;
}

.service-page-landing .landing-final-cta .btn {
    min-width: 220px;
}

@media (max-width: 1024px) {
    .service-page-landing .landing-hero-shell,
    .service-page-landing .landing-rail-layout,
    .service-page-landing .landing-decision-layout {
        grid-template-columns: 1fr;
    }

    .service-page-landing .landing-intent-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .service-page-landing .landing-pattern-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .service-page-landing .page-hero-landing {
        padding-bottom: 40px;
    }

    .service-page-landing .landing-hero-copy,
    .service-page-landing .landing-hero-side,
    .service-page-landing .landing-rail-map,
    .service-page-landing .landing-rail-panel,
    .service-page-landing .landing-build-shell,
    .service-page-landing .landing-decision-card {
        border-radius: 16px;
        padding: 15px 13px;
    }

    .service-page-landing .landing-main-subtitle {
        font-size: 0.98rem;
        line-height: 1.62;
    }

    .service-page-landing .landing-intent-grid,
    .service-page-landing .landing-hero-actions .btn,
    .service-page-landing .landing-final-cta .btn {
        min-width: 0;
    }

    .service-page-landing .landing-intent-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .service-page-landing .landing-hero-actions .btn,
    .service-page-landing .landing-final-cta .btn {
        width: 100%;
    }

    .service-page-landing .landing-pattern-grid,
    .service-page-landing .landing-build-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .service-page-landing .landing-rail-item {
        grid-template-columns: 1fr;
        gap: 7px;
        padding: 12px;
    }

    .service-page-landing .landing-rail-step {
        width: fit-content;
    }

    .service-page-landing .landing-faq-item summary {
        padding: 13px 13px;
        font-size: 0.94rem;
    }

    .service-page-landing .landing-faq-item p {
        padding: 0 13px 13px;
        font-size: 0.92rem;
    }

    .service-page-landing .landing-related-box {
        padding: 13px;
    }

    .service-page-landing .landing-related-list a {
        padding: 9px 9px;
        font-size: 0.92rem;
    }

    .service-page-landing .landing-final-cta {
        padding: 22px 16px;
    }

    .service-page-landing .landing-pattern-featured::before {
        font-size: 0.62rem;
        top: 9px;
        right: 9px;
    }
}

/* Budget page: high-end UI layer */
.budget-page {
    --section-accent: #8dbdff;
}

.budget-page-corporativa .page-hero-budget {
    position: relative;
    overflow: clip;
}

.budget-page-corporativa .page-hero-budget::before,
.budget-page-corporativa .page-hero-budget::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.budget-page-corporativa .page-hero-budget::before {
    inset: 9% auto auto -8%;
    width: min(46vw, 540px);
    height: min(46vw, 540px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(91, 140, 255, 0.28), transparent 67%);
    filter: blur(24px);
    opacity: 0.56;
}

.budget-page-corporativa .page-hero-budget::after {
    inset: auto -10% 6% auto;
    width: min(36vw, 420px);
    height: min(36vw, 420px);
    border-radius: 999px;
    background: radial-gradient(circle, rgba(102, 224, 208, 0.2), transparent 72%);
    filter: blur(22px);
    opacity: 0.46;
}

.budget-page-corporativa .page-hero-budget .container {
    position: relative;
    z-index: 1;
}

.budget-page-corporativa .budget-hero-layout {
    display: grid;
    grid-template-columns: 1.16fr 0.84fr;
    gap: 24px;
    align-items: start;
}

.budget-page-corporativa .budget-hero-main {
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 20px;
    padding: clamp(20px, 2vw, 30px);
    background:
        linear-gradient(152deg, rgba(91, 140, 255, 0.14), rgba(102, 224, 208, 0.05) 45%, transparent 86%),
        rgba(14, 20, 30, 0.8);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3);
}

.budget-page-corporativa .budget-page-title {
    display: block;
    max-width: 17ch;
    margin-top: 0;
    margin-bottom: 18px;
    font-size: clamp(2rem, 1.64rem + 1.4vw, 3rem);
    background: linear-gradient(98deg, #f3f8ff 12%, #93b5ff 48%, #66e0d0 86%);
    background-size: 190% 190%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: title-shift 9s ease-in-out infinite;
}

.budget-page-corporativa .budget-page-title::after {
    left: 0;
    transform: none;
    width: min(220px, 58%);
}

.budget-page-corporativa .budget-page-subtitle {
    margin: 0 0 26px;
    color: var(--text-muted);
    font-size: 1.06rem;
    line-height: 1.68;
    max-width: 760px;
}

.budget-page-corporativa .budget-hero-points {
    margin: 24px 0 28px;
    padding: 0;
    display: grid;
    gap: 10px;
}

.budget-page-corporativa .budget-hero-points li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d5def0;
    line-height: 1.55;
}

.budget-page-corporativa .budget-hero-points li::before {
    content: "";
    width: 9px;
    height: 9px;
    margin-top: 7px;
    flex: 0 0 9px;
    border-radius: 999px;
    background: linear-gradient(160deg, #7caeff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(91, 140, 255, 0.18);
}

.budget-page-corporativa .budget-trust-row {
    margin-top: 20px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.budget-page-corporativa .budget-trust-item {
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 14px;
    padding: 12px 13px;
    background: rgba(91, 140, 255, 0.08);
    display: grid;
    gap: 4px;
}

.budget-page-corporativa .budget-trust-label {
    color: #9db7e8;
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.budget-page-corporativa .budget-trust-item strong {
    color: #ecf3ff;
    font-size: 0.92rem;
}

.budget-page-corporativa .budget-hero-card {
    border-radius: 20px;
    border-color: rgba(91, 140, 255, 0.3);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.34);
}

.budget-page-corporativa .budget-hero-list li {
    list-style: none;
    margin-left: 0;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.budget-page-corporativa .budget-hero-list li::before {
    content: "→";
    color: #89b1ff;
    font-size: 0.9rem;
    margin-top: 1px;
}

.budget-page-corporativa .budget-hero-note {
    margin: 18px 0 0;
    color: #bfd0ef;
    font-size: 0.9rem;
}

.budget-page-corporativa .budget-factor-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.budget-page-corporativa .budget-factor-card {
    border-top: 2px solid rgba(91, 140, 255, 0.58);
    border-radius: 16px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.budget-page-corporativa .budget-factor-card h2 {
    font-size: 1.18rem;
    margin-bottom: 10px;
}

.budget-page-corporativa .budget-factor-card:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.46);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

.budget-page-corporativa .budget-section-header {
    margin-bottom: 30px;
}

.budget-page-corporativa .budget-process-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.budget-page-corporativa .budget-process-card {
    border-radius: 16px;
    display: grid;
    gap: 10px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.budget-page-corporativa .budget-process-card:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.46);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

.budget-page-corporativa .budget-step-number {
    display: inline-flex;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.56);
    background: linear-gradient(150deg, rgba(91, 140, 255, 0.3), rgba(102, 224, 208, 0.2));
    color: #c8dcff;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.budget-page-corporativa .budget-process-card h3 {
    margin: 0;
    font-size: 1.1rem;
}

.budget-page-corporativa .budget-process-card p {
    margin: 0;
}

.budget-page-corporativa .budget-table th {
    color: #eaf1ff;
    background: rgba(91, 140, 255, 0.11);
}

.budget-page-corporativa .budget-table td {
    color: #d2dced;
    line-height: 1.55;
}

.budget-page-corporativa .budget-table-note {
    margin-top: 14px;
    font-size: 0.92rem;
    color: #b9cbe8;
}

.budget-page-corporativa .budget-faq-card {
    border-radius: 20px;
    padding: clamp(20px, 2.2vw, 30px);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: blur(6px);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.budget-page-corporativa .budget-faq-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(130deg, rgba(91, 140, 255, 0.24), transparent 38%, rgba(102, 224, 208, 0.18) 72%, transparent);
    transition: opacity 0.35s ease;
}

.budget-page-corporativa .budget-faq-card:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.44);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.34);
}

.budget-page-corporativa .budget-faq-card:hover::before {
    opacity: 1;
}

.budget-page-corporativa .budget-faq-list {
    display: grid;
    gap: 12px;
    margin-top: 12px;
}

.budget-page-corporativa .budget-faq-item {
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 14px;
    background: rgba(91, 140, 255, 0.06);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: blur(6px);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.budget-page-corporativa .budget-faq-item::before,
.budget-page-corporativa .budget-faq-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s ease;
}

.budget-page-corporativa .budget-faq-item::before {
    background: linear-gradient(124deg, rgba(91, 140, 255, 0.3), transparent 38%, rgba(102, 224, 208, 0.24) 74%, transparent);
}

.budget-page-corporativa .budget-faq-item::after {
    background: radial-gradient(circle at 18% 2%, rgba(255, 255, 255, 0.2), transparent 44%);
}

.budget-page-corporativa .budget-faq-item:hover {
    transform: translateY(-3px);
    border-color: rgba(91, 140, 255, 0.5);
    background: rgba(91, 140, 255, 0.12);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.3);
}

.budget-page-corporativa .budget-faq-item:hover::before,
.budget-page-corporativa .budget-faq-item:hover::after {
    opacity: 1;
}

.budget-page-corporativa .budget-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 15px 18px;
    font-size: 1rem;
    font-weight: 600;
    color: #e5ecfb;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.budget-page-corporativa .budget-faq-item summary:hover {
    background: rgba(91, 140, 255, 0.12);
}

.budget-page-corporativa .budget-faq-item summary::-webkit-details-marker {
    display: none;
}

.budget-page-corporativa .budget-faq-item summary::after {
    content: "+";
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #bad0ff;
    font-size: 0.95rem;
}

.budget-page-corporativa .budget-faq-item[open] summary::after {
    content: "−";
    border-color: rgba(102, 224, 208, 0.52);
}

.budget-page-corporativa .budget-faq-item p {
    margin: 0;
    padding: 0 18px 16px;
}

.budget-page-corporativa .budget-related-inline {
    margin-top: 18px;
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 16px;
    background:
        linear-gradient(150deg, rgba(91, 140, 255, 0.12), rgba(102, 224, 208, 0.05) 44%, transparent 90%),
        rgba(14, 20, 30, 0.72);
    padding: 16px;
}

.budget-page-corporativa .budget-related-inline h3 {
    margin: 0 0 10px;
    font-size: 0.95rem;
    letter-spacing: 0.02em;
}

.budget-page-corporativa .budget-related-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.budget-page-corporativa .budget-related-list li {
    list-style: none;
}

.budget-page-corporativa .budget-related-inline a {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 10px;
    padding: 10px 11px;
    border-radius: 11px;
    border: 1px solid rgba(91, 140, 255, 0.24);
    background: rgba(91, 140, 255, 0.08);
    font-weight: 600;
    line-height: 1.35;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.budget-page-corporativa .budget-related-inline a::after {
    content: "→";
    font-size: 0.95rem;
    opacity: 0.92;
}

.budget-page-corporativa .budget-related-inline a:hover {
    transform: translateX(2px);
    border-color: rgba(102, 224, 208, 0.45);
    background: rgba(102, 224, 208, 0.14);
}

.budget-page-corporativa .budget-final-cta {
    border-radius: 22px;
    padding: clamp(24px, 2.8vw, 40px);
    background:
        radial-gradient(circle at 18% 24%, rgba(91, 140, 255, 0.2), transparent 44%),
        linear-gradient(138deg, rgba(91, 140, 255, 0.16), rgba(102, 224, 208, 0.1) 52%, transparent 90%),
        rgba(13, 19, 28, 0.86);
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.36);
}

.budget-page-corporativa .budget-final-actions {
    justify-content: center;
}

.budget-page-corporativa .budget-final-cta .btn {
    min-width: 220px;
}

/* Budget page v2: differentiated layout */
.budget-page-corporativa .budget-hero-unique {
    padding-bottom: 58px;
}

.budget-page-corporativa .budget-hero-actions {
    margin-top: 0;
}

.budget-page-corporativa .budget-snapshot {
    margin-top: 24px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.budget-page-corporativa .budget-snapshot-item {
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 14px;
    padding: 12px 13px;
    background: rgba(91, 140, 255, 0.08);
    display: grid;
    gap: 4px;
}

.budget-page-corporativa .budget-snapshot-label {
    color: #9db7e8;
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.budget-page-corporativa .budget-snapshot-item strong {
    color: #ecf3ff;
    font-size: 0.94rem;
}

.budget-page-corporativa .budget-snapshot-item p {
    margin: 0;
    font-size: 0.88rem;
    color: #bfd0ee;
    line-height: 1.5;
}

.budget-page-corporativa .budget-layout-section {
    padding-top: 20px;
}

.budget-page-corporativa .budget-layout-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 18px;
    align-items: start;
}

.budget-page-corporativa .budget-panel {
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 18px;
    padding: clamp(18px, 2vw, 24px);
    background:
        linear-gradient(150deg, rgba(91, 140, 255, 0.12), rgba(102, 224, 208, 0.05) 46%, transparent 90%),
        rgba(14, 20, 30, 0.72);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.3);
}

.budget-page-corporativa .budget-panel h2 {
    margin: 0 0 12px;
    font-size: clamp(1.25rem, 1.12rem + 0.5vw, 1.56rem);
}

.budget-page-corporativa .budget-driver-list {
    display: grid;
    gap: 10px;
}

.budget-page-corporativa .budget-driver-item {
    border: 1px solid rgba(91, 140, 255, 0.2);
    border-radius: 14px;
    padding: 13px 14px;
    background: rgba(91, 140, 255, 0.06);
}

.budget-page-corporativa .budget-driver-item h3 {
    margin: 0 0 7px;
    font-size: 1.02rem;
}

.budget-page-corporativa .budget-driver-item p {
    margin: 0;
    color: #d2ddee;
    line-height: 1.55;
}

.budget-page-corporativa .budget-checklist {
    margin: 0 0 16px;
    padding: 0;
    display: grid;
    gap: 10px;
}

.budget-page-corporativa .budget-checklist li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #d7e1f2;
    line-height: 1.5;
}

.budget-page-corporativa .budget-checklist li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    border-radius: 999px;
    background: linear-gradient(160deg, #7caeff, #66e0d0);
    box-shadow: 0 0 0 4px rgba(91, 140, 255, 0.16);
    flex: 0 0 8px;
}

.budget-page-corporativa .budget-scenarios-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.budget-page-corporativa .budget-scenario-card {
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 16px;
    padding: 16px 15px;
    background:
        linear-gradient(155deg, rgba(91, 140, 255, 0.12), rgba(102, 224, 208, 0.04) 42%, transparent 85%),
        rgba(14, 20, 30, 0.7);
}

.budget-page-corporativa .budget-scenario-tag {
    margin: 0 0 8px;
    color: #9fb8e8;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.budget-page-corporativa .budget-scenario-card h3 {
    margin: 0 0 10px;
    font-size: 1.04rem;
}

.budget-page-corporativa .budget-scenario-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.budget-page-corporativa .budget-scenario-list li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: #d4deef;
    line-height: 1.45;
    font-size: 0.93rem;
}

.budget-page-corporativa .budget-scenario-list li::before {
    content: "→";
    color: #86b1ff;
    font-size: 0.85rem;
    margin-top: 1px;
}

.budget-page-corporativa .budget-roadmap {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
    position: relative;
}

.budget-page-corporativa .budget-roadmap::before {
    content: "";
    position: absolute;
    left: 16px;
    top: 16px;
    bottom: 16px;
    width: 1px;
    background: linear-gradient(180deg, rgba(91, 140, 255, 0.45), rgba(102, 224, 208, 0.4));
    opacity: 0.65;
}

.budget-page-corporativa .budget-roadmap-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: start;
    border: 1px solid rgba(91, 140, 255, 0.22);
    border-radius: 14px;
    padding: 14px 15px;
    background: rgba(91, 140, 255, 0.06);
    position: relative;
}

.budget-page-corporativa .budget-roadmap-item h3 {
    margin: 1px 0 6px;
    font-size: 1.04rem;
}

.budget-page-corporativa .budget-roadmap-item p {
    margin: 0;
    color: #d5deef;
    line-height: 1.5;
}

.budget-page-corporativa .budget-hero-orbit {
    display: grid;
    gap: 14px;
    padding: clamp(18px, 2vw, 24px);
    position: relative;
    overflow: hidden;
}

.budget-page-corporativa .budget-hero-orbit::before {
    content: "";
    position: absolute;
    inset: auto -28% -38% auto;
    width: 220px;
    height: 220px;
    border-radius: 999px;
    pointer-events: none;
    background: radial-gradient(circle, rgba(102, 224, 208, 0.28), transparent 72%);
    filter: blur(8px);
    opacity: 0.55;
}

.budget-page-corporativa .budget-hero-orbit>* {
    position: relative;
    z-index: 1;
}

.budget-page-corporativa .budget-hero-orbit h2 {
    margin: -2px 0 2px;
    font-size: clamp(1.18rem, 1.04rem + 0.6vw, 1.52rem);
    line-height: 1.28;
}

.budget-page-corporativa .budget-hero-pulse {
    border: 1px solid rgba(102, 224, 208, 0.36);
    border-radius: 12px;
    padding: 11px 12px;
    display: grid;
    gap: 4px;
    background: rgba(102, 224, 208, 0.08);
}

.budget-page-corporativa .budget-hero-pulse span {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #9ecfdf;
}

.budget-page-corporativa .budget-hero-pulse strong {
    color: #e8f7f3;
    font-size: 0.95rem;
}

.budget-page-corporativa .budget-side-micro {
    margin: 0 0 16px;
}

.budget-page-corporativa .budget-side-tags {
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.budget-page-corporativa .budget-side-tags li {
    list-style: none;
    padding: 7px 10px;
    border-radius: 999px;
    border: 1px solid rgba(91, 140, 255, 0.28);
    background: rgba(91, 140, 255, 0.1);
    color: #d6e4f9;
    font-size: 0.82rem;
    line-height: 1.35;
}

.budget-page-corporativa .budget-scenario-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.budget-page-corporativa .budget-scenario-card:hover {
    transform: translateY(-4px);
    border-color: rgba(91, 140, 255, 0.44);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32);
}

.budget-page-corporativa .budget-scenario-link {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: #d9e7ff;
    text-decoration: none;
}

.budget-page-corporativa .budget-scenario-link::after {
    content: "→";
    font-size: 0.92rem;
    transition: transform 0.2s ease;
}

.budget-page-corporativa .budget-scenario-link:hover::after {
    transform: translateX(3px);
}

.budget-page-corporativa .budget-roadmap-section {
    padding-top: 8px;
}

.budget-page-corporativa .budget-roadmap-shell {
    border: 1px solid rgba(91, 140, 255, 0.24);
    border-radius: 18px;
    padding: clamp(16px, 2vw, 24px);
    background:
        linear-gradient(145deg, rgba(91, 140, 255, 0.11), rgba(102, 224, 208, 0.04) 44%, transparent 90%),
        rgba(14, 20, 30, 0.66);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.28);
}

.budget-page-corporativa .budget-roadmap {
    gap: 14px;
}

.budget-page-corporativa .budget-roadmap-item {
    transition: transform 0.24s ease, border-color 0.24s ease, background-color 0.24s ease;
}

.budget-page-corporativa .budget-roadmap-item:hover {
    transform: translateX(3px);
    border-color: rgba(102, 224, 208, 0.4);
    background: rgba(91, 140, 255, 0.1);
}

.budget-page-corporativa .budget-faq-head {
    margin-bottom: 16px;
}

.budget-page-corporativa .budget-faq-head h2 {
    margin: 0 0 8px;
    font-size: clamp(1.32rem, 1.14rem + 0.7vw, 1.9rem);
}

.budget-page-corporativa .budget-faq-head p {
    margin: 0;
    color: var(--text-muted);
    max-width: 760px;
}

.budget-page-corporativa .budget-faq-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.36fr) minmax(0, 0.9fr);
    gap: 16px;
    align-items: start;
}

.budget-page-corporativa .budget-faq-layout .budget-faq-list {
    margin-top: 0;
}

.budget-page-corporativa .budget-faq-layout .budget-related-inline {
    margin-top: 0;
}

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

.basic-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 520px;
}

.basic-table th,
.basic-table td {
    border: 1px solid var(--border-dark);
    padding: 12px 14px;
    text-align: left;
    color: var(--text-muted);
}

.basic-table th {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.02);
}

@media (max-width: 1024px) {
    .service-hero-layout {
        grid-template-columns: 1fr;
    }

    .service-value-grid {
        grid-template-columns: 1fr 1fr;
    }

    .service-page-corporativa .service-proof-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .budget-page-corporativa .budget-hero-layout {
        grid-template-columns: 1fr;
    }

    .budget-page-corporativa .budget-factor-grid {
        grid-template-columns: 1fr 1fr;
    }

    .budget-page-corporativa .budget-snapshot {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .budget-page-corporativa .budget-layout-grid {
        grid-template-columns: 1fr;
    }

    .budget-page-corporativa .budget-scenarios-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .budget-page-corporativa .budget-hero-orbit {
        padding: 18px 16px;
    }

    .budget-page-corporativa .budget-faq-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .page-hero-service {
        padding-bottom: 38px;
    }

    .service-page-subtitle {
        font-size: 0.98rem;
        line-height: 1.62;
    }

    .service-hero-points {
        margin: 20px 0 24px;
    }

    .service-hero-points li {
        font-size: 0.92rem;
    }

    .service-grid-2,
    .service-steps-grid,
    .service-value-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .service-value-card h2,
    .service-grid-2 h3,
    .service-step-card h3 {
        font-size: 1.04rem;
    }

    .service-faq-item {
        padding: 14px;
    }

    .service-final-cta {
        padding: 22px 16px;
    }

    .service-page-corporativa .service-hero-main {
        border-radius: 16px;
        padding: 18px 16px;
    }

    .service-page-corporativa .service-proof-strip {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .service-page-corporativa .service-proof-item {
        padding: 11px 12px;
    }

    .service-page-corporativa .service-faq-item summary {
        padding: 14px 14px;
        font-size: 0.95rem;
    }

    .service-page-corporativa .service-faq-item p {
        padding: 0 14px 14px;
        font-size: 0.92rem;
    }

    .service-page-corporativa .service-faq-related-card {
        padding: 16px 14px;
    }

    .service-page-corporativa .service-faq-head {
        margin-bottom: 14px;
    }

    .service-page-corporativa .service-faq-related-layout {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .service-page-corporativa .service-related-inline {
        padding: 13px;
    }

    .service-page-corporativa .service-related-inline a {
        padding: 9px 10px;
        font-size: 0.92rem;
    }

    .service-page-corporativa .service-tail-section {
        padding-bottom: 16px;
    }

    .service-page-corporativa .service-cta-section {
        padding-top: 6px;
        margin-top: -12px;
    }

    .service-page-corporativa .service-cta-section .container::before {
        top: -9px;
        height: 18px;
        opacity: 0.5;
    }

    .service-page-corporativa .service-final-cta .btn {
        min-width: 0;
        width: 100%;
    }

    .budget-page-corporativa .budget-hero-main {
        border-radius: 16px;
        padding: 18px 16px;
    }

    .budget-page-corporativa .budget-page-subtitle {
        font-size: 0.98rem;
        line-height: 1.62;
    }

    .budget-page-corporativa .budget-snapshot {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .budget-page-corporativa .budget-layout-section {
        padding-top: 12px;
    }

    .budget-page-corporativa .budget-panel {
        border-radius: 15px;
        padding: 15px 13px;
    }

    .budget-page-corporativa .budget-driver-item {
        padding: 12px;
    }

    .budget-page-corporativa .budget-driver-item h3 {
        font-size: 0.99rem;
    }

    .budget-page-corporativa .budget-scenarios-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .budget-page-corporativa .budget-scenario-card {
        padding: 14px 13px;
    }

    .budget-page-corporativa .budget-scenario-link {
        font-size: 0.9rem;
    }

    .budget-page-corporativa .budget-roadmap::before {
        display: none;
    }

    .budget-page-corporativa .budget-roadmap-item {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 13px;
    }

    .budget-page-corporativa .budget-roadmap-item:hover {
        transform: none;
    }

    .budget-page-corporativa .budget-step-number {
        margin-bottom: 2px;
    }

    .budget-page-corporativa .budget-hero-points {
        margin: 20px 0 24px;
    }

    .budget-page-corporativa .budget-hero-points li {
        font-size: 0.92rem;
    }

    .budget-page-corporativa .budget-trust-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .budget-page-corporativa .budget-hero-orbit {
        padding: 15px 13px;
        gap: 12px;
    }

    .budget-page-corporativa .budget-hero-pulse {
        padding: 10px 11px;
    }

    .budget-page-corporativa .budget-side-tags {
        gap: 6px;
    }

    .budget-page-corporativa .budget-side-tags li {
        font-size: 0.79rem;
        padding: 6px 9px;
    }

    .budget-page-corporativa .budget-factor-grid,
    .budget-page-corporativa .budget-process-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .budget-page-corporativa .budget-factor-card h2,
    .budget-page-corporativa .budget-process-card h3 {
        font-size: 1.04rem;
    }

    .budget-page-corporativa .budget-faq-card {
        padding: 16px 14px;
    }

    .budget-page-corporativa .budget-faq-item summary {
        padding: 14px 14px;
        font-size: 0.95rem;
    }

    .budget-page-corporativa .budget-faq-item p {
        padding: 0 14px 14px;
        font-size: 0.92rem;
    }

    .budget-page-corporativa .budget-faq-layout {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .budget-page-corporativa .budget-faq-head p {
        font-size: 0.92rem;
    }

    .budget-page-corporativa .budget-related-inline {
        padding: 13px;
    }

    .budget-page-corporativa .budget-roadmap-shell {
        border-radius: 15px;
        padding: 13px;
    }

    .budget-page-corporativa .budget-related-inline a {
        padding: 9px 10px;
        font-size: 0.92rem;
    }

    .budget-page-corporativa .budget-final-cta .btn {
        min-width: 0;
        width: 100%;
    }
}

/* Budget page v3: guide palette UI refresh */
.budget-page-guide {
    --budget-guide-primary-rgb: 255, 179, 103;
    --budget-guide-secondary-rgb: 116, 181, 255;
    --budget-guide-primary: #ffc179;
    --budget-guide-secondary: #74b5ff;
    --budget-guide-text-soft: #e8ddcf;
    --budget-guide-surface: rgba(15, 21, 32, 0.82);
    --budget-guide-panel:
        linear-gradient(152deg, rgba(var(--budget-guide-primary-rgb), 0.24), rgba(var(--budget-guide-secondary-rgb), 0.08) 48%, transparent 92%),
        var(--budget-guide-surface);
    position: relative;
    isolation: isolate;
}

.budget-page-guide::before,
.budget-page-guide::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    filter: blur(28px);
    z-index: -1;
}

.budget-page-guide::before {
    inset: 12% auto auto -8%;
    width: min(42vw, 420px);
    height: min(42vw, 420px);
    background: radial-gradient(circle, rgba(var(--budget-guide-primary-rgb), 0.2), transparent 68%);
}

.budget-page-guide::after {
    inset: auto -7% 18% auto;
    width: min(38vw, 380px);
    height: min(38vw, 380px);
    background: radial-gradient(circle, rgba(var(--budget-guide-secondary-rgb), 0.18), transparent 70%);
}

.budget-page-guide .page-hero-budget::before {
    background: radial-gradient(circle, rgba(var(--budget-guide-primary-rgb), 0.25), transparent 66%);
}

.budget-page-guide .page-hero-budget::after {
    background: radial-gradient(circle, rgba(var(--budget-guide-secondary-rgb), 0.2), transparent 70%);
}

.budget-page-guide .service-kicker {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.44);
    background: linear-gradient(135deg, rgba(var(--budget-guide-primary-rgb), 0.2), rgba(var(--budget-guide-secondary-rgb), 0.12));
    color: #ffe5be;
}

.budget-page-guide .budget-page-title {
    max-width: 23ch;
    color: #fff1dd;
    -webkit-text-fill-color: currentColor;
    text-shadow: 0 10px 28px rgba(var(--budget-guide-primary-rgb), 0.22);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .budget-page-guide .budget-page-title {
        background: linear-gradient(98deg, #fff6e7 10%, var(--budget-guide-primary) 44%, var(--budget-guide-secondary) 88%);
        background-size: 190% 190%;
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        -webkit-text-fill-color: transparent;
    }
}

.budget-page-guide .budget-page-subtitle,
.budget-page-guide .budget-driver-item p,
.budget-page-guide .budget-roadmap-item p,
.budget-page-guide .budget-faq-item p,
.budget-page-guide .budget-table-note,
.budget-page-guide .budget-faq-head p,
.budget-page-guide .budget-hero-note {
    color: var(--budget-guide-text-soft);
}

.budget-page-guide .budget-hero-main,
.budget-page-guide .budget-panel,
.budget-page-guide .budget-scenario-card,
.budget-page-guide .budget-roadmap-shell,
.budget-page-guide .budget-faq-card,
.budget-page-guide .budget-related-inline,
.budget-page-guide .budget-faq-item {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.3);
    background: var(--budget-guide-panel);
    box-shadow: 0 20px 38px rgba(0, 0, 0, 0.34);
}

.budget-page-guide .budget-hero-card,
.budget-page-guide .budget-hero-orbit {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.48);
    background:
        linear-gradient(152deg, rgba(var(--budget-guide-primary-rgb), 0.3), rgba(var(--budget-guide-secondary-rgb), 0.1) 50%, transparent 90%),
        rgba(14, 20, 30, 0.88);
}

.budget-page-guide .budget-hero-main,
.budget-page-guide .budget-panel,
.budget-page-guide .budget-roadmap-shell,
.budget-page-guide .budget-faq-card {
    backdrop-filter: blur(3px);
}

.budget-page-guide .budget-panel:hover,
.budget-page-guide .budget-scenario-card:hover,
.budget-page-guide .budget-roadmap-item:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--budget-guide-primary-rgb), 0.58);
    box-shadow: 0 24px 42px rgba(0, 0, 0, 0.38);
}

.budget-page-guide .budget-panel,
.budget-page-guide .budget-scenario-card,
.budget-page-guide .budget-roadmap-item,
.budget-page-guide .budget-faq-item,
.budget-page-guide .budget-related-inline a {
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.budget-page-guide .budget-hero-main,
.budget-page-guide .budget-panel,
.budget-page-guide .budget-hero-card,
.budget-page-guide .budget-scenario-card,
.budget-page-guide .budget-roadmap-shell,
.budget-page-guide .budget-faq-card {
    position: relative;
    overflow: hidden;
}

.budget-page-guide .budget-hero-main::after,
.budget-page-guide .budget-panel::after,
.budget-page-guide .budget-hero-card::after,
.budget-page-guide .budget-scenario-card::after,
.budget-page-guide .budget-roadmap-shell::after,
.budget-page-guide .budget-faq-card::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, rgba(var(--budget-guide-primary-rgb), 0.9), rgba(var(--budget-guide-secondary-rgb), 0.7), rgba(var(--budget-guide-primary-rgb), 0.8));
    opacity: 0.85;
    pointer-events: none;
}

.budget-page-guide .budget-snapshot-item {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.35);
    background: linear-gradient(140deg, rgba(var(--budget-guide-primary-rgb), 0.2), rgba(var(--budget-guide-secondary-rgb), 0.11));
}

.budget-page-guide .budget-snapshot-label {
    color: #ffd9ab;
}

.budget-page-guide .budget-snapshot-item strong {
    color: #fff4e4;
}

.budget-page-guide .budget-snapshot-item p {
    color: #ecdcc7;
}

.budget-page-guide .budget-checklist li::before {
    background: linear-gradient(165deg, var(--budget-guide-primary), var(--budget-guide-secondary));
    box-shadow: 0 0 0 4px rgba(var(--budget-guide-primary-rgb), 0.16);
}

.budget-page-guide .budget-driver-item .service-mini-kicker,
.budget-page-guide .budget-service-card .service-mini-kicker {
    color: #ffd8aa;
}

.budget-page-guide .budget-panel h2,
.budget-page-guide .budget-hero-orbit h2,
.budget-page-guide .budget-roadmap-item h3,
.budget-page-guide .budget-scenario-card h3,
.budget-page-guide .budget-faq-head h2 {
    color: #fff2df;
}

.budget-page-guide .budget-hero-list li {
    color: #f2e4cf;
}

.budget-page-guide .budget-hero-orbit::before {
    background: radial-gradient(circle, rgba(var(--budget-guide-primary-rgb), 0.35), transparent 72%);
    opacity: 0.62;
}

.budget-page-guide .budget-hero-pulse {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.56);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.24), rgba(var(--budget-guide-secondary-rgb), 0.12));
}

.budget-page-guide .budget-hero-pulse span {
    color: #ffd4a0;
}

.budget-page-guide .budget-hero-pulse strong {
    color: #fff1dc;
}

.budget-page-guide .budget-hero-list li::before,
.budget-page-guide .budget-scenario-list li::before,
.budget-page-guide .budget-scenario-link,
.budget-page-guide .budget-related-inline a::after {
    color: var(--budget-guide-primary);
}

.budget-page-guide .budget-scenario-link {
    font-weight: 700;
    letter-spacing: 0.01em;
}

.budget-page-guide .budget-side-tags li {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.42);
    background: linear-gradient(140deg, rgba(var(--budget-guide-primary-rgb), 0.22), rgba(var(--budget-guide-secondary-rgb), 0.1));
    color: #f3e4cf;
}

.budget-page-guide .budget-services-section .budget-services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.budget-page-guide .budget-service-card {
    position: relative;
    overflow: hidden;
    min-height: 100%;
}

.budget-page-guide .budget-service-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.42;
}

.budget-page-guide .budget-service-corporativa::before {
    background: linear-gradient(125deg, rgba(var(--budget-guide-primary-rgb), 0.3), rgba(var(--budget-guide-secondary-rgb), 0.1) 58%, transparent 82%);
}

.budget-page-guide .budget-service-landing::before {
    background: linear-gradient(125deg, rgba(var(--budget-guide-primary-rgb), 0.38), rgba(var(--budget-guide-secondary-rgb), 0.14) 58%, transparent 82%);
}

.budget-page-guide .budget-service-card > * {
    position: relative;
    z-index: 1;
}

.budget-page-guide .budget-service-card h2::after {
    display: inline-flex;
    align-items: center;
    margin-left: 10px;
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid rgba(var(--budget-guide-primary-rgb), 0.42);
    background: rgba(var(--budget-guide-primary-rgb), 0.16);
    color: #ffe0b6;
    font-size: 0.68rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    vertical-align: middle;
}

.budget-page-guide .budget-service-corporativa h2::after {
    content: "Corporativa";
}

.budget-page-guide .budget-service-landing h2::after {
    content: "Landing";
}

.budget-page-guide .budget-scenarios-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.budget-page-guide .budget-scenario-card {
    position: relative;
    overflow: hidden;
}

.budget-page-guide .budget-scenario-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.28;
    background: linear-gradient(130deg, rgba(var(--budget-guide-primary-rgb), 0.3), rgba(var(--budget-guide-secondary-rgb), 0.18) 48%, transparent 78%);
}

.budget-page-guide .budget-scenario-card > * {
    position: relative;
    z-index: 1;
}

.budget-page-guide .budget-scenario-tag {
    color: #ffd8aa;
}

.budget-page-guide .budget-roadmap::before {
    background: linear-gradient(180deg, rgba(var(--budget-guide-primary-rgb), 0.56), rgba(var(--budget-guide-secondary-rgb), 0.56));
}

.budget-page-guide .budget-roadmap-item {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.36);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.2), rgba(var(--budget-guide-secondary-rgb), 0.1));
}

.budget-page-guide .budget-step-number {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.66);
    background: linear-gradient(150deg, rgba(var(--budget-guide-primary-rgb), 0.3), rgba(var(--budget-guide-secondary-rgb), 0.24));
    color: #fff2df;
}

.budget-page-guide .budget-faq-item {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.38);
}

.budget-page-guide .budget-faq-item::before {
    background: linear-gradient(124deg, rgba(var(--budget-guide-primary-rgb), 0.34), transparent 40%, rgba(var(--budget-guide-secondary-rgb), 0.2) 78%, transparent);
}

.budget-page-guide .budget-faq-item:hover {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.62);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.24), rgba(var(--budget-guide-secondary-rgb), 0.1));
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.34);
}

.budget-page-guide .budget-faq-card::before {
    background: linear-gradient(130deg, rgba(var(--budget-guide-primary-rgb), 0.3), transparent 40%, rgba(var(--budget-guide-secondary-rgb), 0.18) 74%, transparent);
}

.budget-page-guide .budget-faq-card:hover {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.54);
}

.budget-page-guide .budget-faq-item summary {
    color: #f5ecde;
}

.budget-page-guide .budget-faq-item summary:hover {
    background: rgba(var(--budget-guide-primary-rgb), 0.18);
}

.budget-page-guide .budget-faq-item summary::after {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.5);
    color: #ffd4a2;
}

.budget-page-guide .budget-faq-item[open] summary::after {
    border-color: rgba(var(--budget-guide-secondary-rgb), 0.56);
}

.budget-page-guide .budget-related-inline a {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.36);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.22), rgba(var(--budget-guide-secondary-rgb), 0.08));
    color: #f6e9d4;
}

.budget-page-guide .budget-related-inline a:hover {
    transform: translateX(4px);
    border-color: rgba(var(--budget-guide-secondary-rgb), 0.52);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.24), rgba(var(--budget-guide-secondary-rgb), 0.2));
}

.budget-page-guide .budget-final-cta {
    border: 1px solid rgba(var(--budget-guide-primary-rgb), 0.32);
    background:
        radial-gradient(circle at 18% 20%, rgba(var(--budget-guide-primary-rgb), 0.34), transparent 44%),
        radial-gradient(circle at 83% 72%, rgba(var(--budget-guide-secondary-rgb), 0.26), transparent 46%),
        linear-gradient(138deg, rgba(var(--budget-guide-primary-rgb), 0.2), rgba(var(--budget-guide-secondary-rgb), 0.15) 52%, transparent 90%),
        rgba(14, 20, 30, 0.9);
}

.budget-page-guide .btn-primary {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.72);
    background: linear-gradient(133deg, #ffd194 0%, #ffbe77 42%, #8ec0ff 100%);
    color: #102033;
    box-shadow: 0 12px 28px rgba(var(--budget-guide-primary-rgb), 0.3);
}

.budget-page-guide .btn-primary:hover {
    border-color: rgba(var(--budget-guide-secondary-rgb), 0.72);
    background: linear-gradient(133deg, #ffe0b8 0%, #ffc887 44%, #a2cbff 100%);
    color: #0c1a2b;
    box-shadow: 0 16px 34px rgba(var(--budget-guide-secondary-rgb), 0.28);
}

.budget-page-guide .btn-secondary {
    border-color: rgba(var(--budget-guide-primary-rgb), 0.46);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.16), rgba(var(--budget-guide-secondary-rgb), 0.09));
    color: #f0e0c8;
}

.budget-page-guide .btn-secondary:hover {
    border-color: rgba(var(--budget-guide-secondary-rgb), 0.56);
    background: linear-gradient(145deg, rgba(var(--budget-guide-primary-rgb), 0.24), rgba(var(--budget-guide-secondary-rgb), 0.18));
    color: #fff0da;
}

@media (max-width: 1024px) {
    .budget-page-guide .budget-services-section .budget-services-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .budget-page-guide .budget-page-title {
        max-width: 100%;
    }

    .budget-page-guide .budget-scenarios-grid {
        grid-template-columns: 1fr;
    }

    .budget-page-guide .budget-service-card h2::after {
        margin-left: 0;
        margin-top: 8px;
    }
}

/* Budget page v5: simplified premium UI for non-technical visitors */
.budget-simple-page {
    --budget-simple-primary-rgb: 156, 225, 143;
    --budget-simple-secondary-rgb: 112, 192, 126;
    --budget-simple-primary: #a6e89b;
    --budget-simple-secondary: #7fce8f;
    --budget-simple-title: #eff8ea;
    --budget-simple-text: #d3e4d2;
    --budget-simple-text-soft: #c7d9c6;
    --budget-simple-kicker: #d8f2d3;
    --budget-simple-label: #cae9c4;
    --budget-simple-link: #c7efbf;
    --budget-simple-link-hover: #f3fbf1;
    --budget-simple-cta-text: #102314;
    --budget-simple-cta-text-hover: #0c1b10;
    --budget-simple-surface: rgba(14, 20, 30, 0.84);
    --budget-simple-panel:
        linear-gradient(152deg, rgba(var(--budget-simple-primary-rgb), 0.22), rgba(var(--budget-simple-secondary-rgb), 0.09) 52%, transparent 90%),
        var(--budget-simple-surface);
    position: relative;
    isolation: isolate;
}

.budget-simple-page::before,
.budget-simple-page::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    z-index: -1;
    filter: blur(28px);
}

.budget-simple-page::before {
    inset: 8% auto auto -8%;
    width: min(44vw, 430px);
    height: min(44vw, 430px);
    background: radial-gradient(circle, rgba(var(--budget-simple-primary-rgb), 0.2), transparent 66%);
}

.budget-simple-page::after {
    inset: auto -7% 14% auto;
    width: min(38vw, 360px);
    height: min(38vw, 360px);
    background: radial-gradient(circle, rgba(var(--budget-simple-secondary-rgb), 0.18), transparent 70%);
}

.budget-simple-page .section-title {
    color: var(--budget-simple-title);
    text-shadow: 0 10px 30px rgba(var(--budget-simple-primary-rgb), 0.2);
}

.budget-simple-page .section-subtitle {
    color: var(--budget-simple-text-soft);
}

.budget-simple-page .service-kicker {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.46);
    background: linear-gradient(140deg, rgba(var(--budget-simple-primary-rgb), 0.2), rgba(var(--budget-simple-secondary-rgb), 0.11));
    color: var(--budget-simple-kicker);
}

.budget-simple-page .service-mini-kicker {
    color: var(--budget-simple-label);
}

.budget-simple-page .budget-simple-hero {
    position: relative;
    overflow: clip;
    padding-bottom: 40px;
}

.budget-simple-page .budget-simple-hero::before {
    content: "";
    position: absolute;
    inset: 10% auto auto 58%;
    width: min(36vw, 300px);
    height: min(36vw, 300px);
    border-radius: 999px;
    pointer-events: none;
    background: radial-gradient(circle, rgba(var(--budget-simple-secondary-rgb), 0.24), transparent 72%);
    opacity: 0.6;
    filter: blur(18px);
}

.budget-simple-page .budget-simple-hero-box {
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.38);
    border-radius: 24px;
    padding: clamp(28px, 3.4vw, 52px);
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(4px);
    background:
        radial-gradient(circle at 12% 12%, rgba(var(--budget-simple-primary-rgb), 0.24), transparent 42%),
        linear-gradient(145deg, rgba(var(--budget-simple-primary-rgb), 0.2), rgba(var(--budget-simple-secondary-rgb), 0.1) 54%, transparent 92%),
        rgba(13, 19, 28, 0.88);
    box-shadow: 0 22px 46px rgba(0, 0, 0, 0.37);
}

.budget-simple-page .budget-simple-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.16fr) minmax(260px, 0.84fr);
    gap: clamp(20px, 2.6vw, 40px);
    align-items: start;
}

.budget-simple-page .budget-simple-hero-copy {
    display: grid;
    gap: 16px;
    align-content: start;
}

.budget-simple-page .budget-simple-hero-copy .service-kicker {
    margin-bottom: 0;
}

.budget-simple-page .budget-simple-hero-aside {
    display: grid;
    gap: 14px;
    align-content: start;
    padding-left: clamp(14px, 2vw, 24px);
    border-left: 1px solid rgba(var(--budget-simple-primary-rgb), 0.3);
}

.budget-simple-page .budget-simple-aside-title {
    margin: 0;
    color: var(--budget-simple-label);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    line-height: 1.45;
}

.budget-simple-page .budget-simple-hero-box::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.35;
    background: linear-gradient(124deg, rgba(var(--budget-simple-primary-rgb), 0.3), transparent 42%, rgba(var(--budget-simple-secondary-rgb), 0.14) 75%, transparent);
}

.budget-simple-page .budget-simple-hero-box>* {
    position: relative;
    z-index: 1;
}

.budget-simple-page .budget-simple-hero-box .section-title {
    margin-top: 0;
    margin-bottom: 0;
    max-width: 23ch;
    display: block;
    color: var(--budget-simple-title);
    text-shadow: 0 10px 34px rgba(var(--budget-simple-primary-rgb), 0.22);
}

.budget-simple-page .budget-simple-hero-box .section-title::after {
    left: 0;
    transform: none;
    width: min(228px, 62%);
}

.budget-simple-page .budget-simple-hero-box .section-subtitle {
    margin: 0;
    max-width: 60ch;
}

.budget-simple-page .budget-simple-section {
    padding-top: 44px;
    padding-bottom: 44px;
}

.budget-simple-page .budget-quick-trust {
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.budget-simple-page .budget-quick-item {
    list-style: none;
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.32);
    border-radius: 14px;
    padding: 12px 14px;
    background: linear-gradient(142deg, rgba(var(--budget-simple-primary-rgb), 0.14), rgba(var(--budget-simple-secondary-rgb), 0.08));
    color: var(--budget-simple-text);
    font-size: 0.9rem;
    line-height: 1.45;
}

.budget-simple-page .budget-quick-item span {
    margin-right: 6px;
    color: var(--budget-simple-title);
    font-size: 0.9rem;
    font-weight: 700;
}

.budget-simple-page .budget-simple-actions {
    margin-top: 6px;
}

.budget-simple-page .budget-simple-actions .btn {
    min-width: 220px;
}

.budget-simple-page .project-card {
    border-radius: 18px;
    border-color: rgba(var(--budget-simple-primary-rgb), 0.3);
    background: var(--budget-simple-panel);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.3);
}

.budget-simple-page .project-card::before {
    background: linear-gradient(124deg,
            rgba(var(--budget-simple-primary-rgb), 0.34),
            transparent 36%,
            rgba(var(--budget-simple-secondary-rgb), 0.2) 76%,
            transparent);
}

.budget-simple-page .project-card::after {
    background: radial-gradient(circle at var(--spot-x) var(--spot-y),
            rgba(var(--budget-simple-primary-rgb), 0.24),
            transparent 46%);
}

.budget-simple-page .project-card:hover {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.58);
    box-shadow: 0 24px 44px rgba(0, 0, 0, 0.38);
}

.budget-simple-page .project-card-link {
    font-weight: 600;
    letter-spacing: 0.01em;
    color: var(--budget-simple-link);
}

.budget-simple-page .project-card-link:hover {
    color: var(--budget-simple-link-hover);
}

.budget-simple-page .budget-choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.budget-simple-page .budget-choice-card {
    display: grid;
    gap: 12px;
}

.budget-simple-page .budget-choice-card h3 {
    margin: 0;
    font-size: clamp(1.3rem, 1.14rem + 0.42vw, 1.54rem);
}

.budget-simple-page .budget-choice-card p {
    margin: 0;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-choice-card .link-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.budget-simple-page .budget-choice-card .link-list li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-choice-card .link-list li::before {
    content: "→";
    color: var(--budget-simple-primary);
    font-size: 0.86rem;
    margin-top: 1px;
}

.budget-simple-page .budget-choice-landing {
    background:
        linear-gradient(138deg, rgba(var(--budget-simple-primary-rgb), 0.24), rgba(var(--budget-simple-secondary-rgb), 0.08) 52%, transparent 88%),
        var(--budget-simple-surface);
}

.budget-simple-page .budget-choice-corporate {
    background:
        linear-gradient(138deg, rgba(var(--budget-simple-secondary-rgb), 0.18), rgba(var(--budget-simple-primary-rgb), 0.13) 52%, transparent 88%),
        var(--budget-simple-surface);
}

.budget-simple-page .budget-includes-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.budget-simple-page .budget-include-card {
    display: grid;
    gap: 10px;
    border-color: rgba(var(--budget-simple-primary-rgb), 0.34);
}

.budget-simple-page .budget-include-card h3 {
    margin: 0;
    font-size: 1.08rem;
    color: var(--budget-simple-title);
}

.budget-simple-page .budget-include-card p {
    margin: 0;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-range-card {
    border-radius: 20px;
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.36);
    padding: 8px;
}

.budget-simple-page .budget-range-card .basic-table {
    min-width: 620px;
}

.budget-simple-page .budget-range-card .basic-table th,
.budget-simple-page .budget-range-card .basic-table td {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.24);
}

.budget-simple-page .budget-range-card .basic-table th {
    color: var(--budget-simple-title);
    background: rgba(var(--budget-simple-primary-rgb), 0.16);
}

.budget-simple-page .budget-range-card .basic-table tbody tr:nth-child(even) td {
    background: rgba(var(--budget-simple-primary-rgb), 0.06);
}

.budget-simple-page .budget-range-card .basic-table td {
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-simple-note {
    margin-top: 12px;
    color: var(--budget-simple-text-soft);
    font-size: 0.94rem;
}

.budget-simple-page .budget-factor-grid-simple {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.budget-simple-page .budget-factor-panel {
    display: grid;
    gap: 12px;
}

.budget-simple-page .budget-factor-title {
    margin: 0;
    font-size: 1.06rem;
    color: var(--budget-simple-title);
}

.budget-simple-page .budget-factor-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.budget-simple-page .budget-factor-list li {
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: var(--budget-simple-text);
    line-height: 1.45;
}

.budget-simple-page .budget-factor-list li::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-top: 7px;
    border-radius: 999px;
    background: linear-gradient(160deg, #c9f0bf, #7dcd8d);
    box-shadow: 0 0 0 4px rgba(var(--budget-simple-primary-rgb), 0.16);
    flex: 0 0 8px;
}

.budget-simple-page .budget-factor-panel.is-up {
    border-top: 2px solid rgba(var(--budget-simple-primary-rgb), 0.7);
}

.budget-simple-page .budget-factor-panel.is-down {
    border-top: 2px solid rgba(var(--budget-simple-secondary-rgb), 0.6);
}

.budget-simple-page .budget-example-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.budget-simple-page .budget-example-card {
    display: grid;
    gap: 10px;
}

.budget-simple-page .budget-example-card h3 {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.32;
    color: var(--budget-simple-title);
}

.budget-simple-page .budget-example-card p {
    margin: 0;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-price-pill {
    margin-top: auto;
    width: fit-content;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.54);
    background: linear-gradient(140deg, rgba(var(--budget-simple-primary-rgb), 0.24), rgba(var(--budget-simple-secondary-rgb), 0.12));
    color: var(--budget-simple-title);
    font-size: 0.83rem;
    font-weight: 600;
}

.budget-simple-page .budget-steps-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.budget-simple-page .budget-step-card {
    display: grid;
    gap: 10px;
}

.budget-simple-page .budget-step-card h3 {
    margin: 0;
    color: var(--budget-simple-title);
    font-size: 1.07rem;
}

.budget-simple-page .budget-step-card p {
    margin: 0;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-step-card .service-step-number {
    width: fit-content;
    border-color: rgba(var(--budget-simple-primary-rgb), 0.64);
    background: linear-gradient(150deg, rgba(var(--budget-simple-primary-rgb), 0.28), rgba(var(--budget-simple-secondary-rgb), 0.2));
    color: var(--budget-simple-title);
}

.budget-simple-page .budget-simple-faq-card {
    border-radius: 22px;
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.36);
    padding: clamp(20px, 2.2vw, 30px);
    position: relative;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: blur(6px);
    background:
        linear-gradient(146deg, rgba(var(--budget-simple-primary-rgb), 0.2), rgba(var(--budget-simple-secondary-rgb), 0.1) 50%, transparent 90%),
        rgba(13, 19, 28, 0.86);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

.budget-simple-page .budget-simple-faq-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(130deg, rgba(var(--budget-simple-primary-rgb), 0.34), transparent 38%, rgba(var(--budget-simple-secondary-rgb), 0.2) 72%, transparent);
    transition: opacity 0.35s ease;
}

.budget-simple-page .budget-simple-faq-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--budget-simple-primary-rgb), 0.56);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.35);
}

.budget-simple-page .budget-simple-faq-card:hover::before {
    opacity: 1;
}

.budget-simple-page .budget-simple-faq-card>* {
    position: relative;
    z-index: 1;
}

.budget-simple-page .budget-faq-head {
    margin-bottom: 14px;
}

.budget-simple-page .budget-faq-head h2 {
    margin: 0 0 8px;
    color: var(--budget-simple-title);
    font-size: clamp(1.32rem, 1.14rem + 0.7vw, 1.9rem);
}

.budget-simple-page .budget-faq-head p {
    margin: 0;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-faq-list {
    display: grid;
    gap: 12px;
    margin-top: 12px;
}

.budget-simple-page .budget-faq-item {
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.32);
    border-radius: 14px;
    background: linear-gradient(145deg, rgba(var(--budget-simple-primary-rgb), 0.14), rgba(var(--budget-simple-secondary-rgb), 0.06));
    position: relative;
    isolation: isolate;
    overflow: hidden;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.budget-simple-page .budget-faq-item::before,
.budget-simple-page .budget-faq-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.budget-simple-page .budget-faq-item::before {
    background: linear-gradient(124deg, rgba(var(--budget-simple-primary-rgb), 0.34), transparent 40%, rgba(var(--budget-simple-secondary-rgb), 0.2) 78%, transparent);
}

.budget-simple-page .budget-faq-item::after {
    background: radial-gradient(circle at 14% 4%, rgba(255, 255, 255, 0.2), transparent 44%);
}

.budget-simple-page .budget-faq-item:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--budget-simple-primary-rgb), 0.58);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.3);
    background: linear-gradient(145deg, rgba(var(--budget-simple-primary-rgb), 0.22), rgba(var(--budget-simple-secondary-rgb), 0.1));
}

.budget-simple-page .budget-faq-item:hover::before,
.budget-simple-page .budget-faq-item:hover::after {
    opacity: 1;
}

.budget-simple-page .budget-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 15px 18px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--budget-simple-title);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.budget-simple-page .budget-faq-item summary::-webkit-details-marker {
    display: none;
}

.budget-simple-page .budget-faq-item summary::after {
    content: "+";
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    border-radius: 999px;
    border: 1px solid rgba(var(--budget-simple-primary-rgb), 0.56);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--budget-simple-primary);
    font-size: 0.94rem;
}

.budget-simple-page .budget-faq-item[open] summary::after {
    content: "−";
    border-color: rgba(var(--budget-simple-secondary-rgb), 0.56);
}

.budget-simple-page .budget-faq-item p {
    margin: 0;
    padding: 0 18px 16px;
    color: var(--budget-simple-text);
}

.budget-simple-page .budget-simple-cta {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.36);
    border-radius: 22px;
    background:
        radial-gradient(circle at 16% 22%, rgba(var(--budget-simple-primary-rgb), 0.34), transparent 44%),
        radial-gradient(circle at 86% 72%, rgba(var(--budget-simple-secondary-rgb), 0.24), transparent 46%),
        linear-gradient(138deg, rgba(var(--budget-simple-primary-rgb), 0.2), rgba(var(--budget-simple-secondary-rgb), 0.12) 52%, transparent 90%),
        rgba(13, 19, 28, 0.86);
}

.budget-simple-page .budget-final-actions {
    justify-content: center;
}

.budget-simple-page .btn-primary {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.74);
    background: linear-gradient(132deg, #c4f0b8 0%, #9bde8f 44%, #76c784 100%);
    color: var(--budget-simple-cta-text);
    box-shadow: 0 12px 28px rgba(var(--budget-simple-primary-rgb), 0.3);
}

.budget-simple-page .btn-primary:hover {
    border-color: rgba(var(--budget-simple-secondary-rgb), 0.72);
    background: linear-gradient(132deg, #d7f5cf 0%, #abe59f 44%, #86d595 100%);
    color: var(--budget-simple-cta-text-hover);
    box-shadow: 0 16px 34px rgba(var(--budget-simple-secondary-rgb), 0.28);
}

.budget-simple-page .btn-secondary {
    border-color: rgba(var(--budget-simple-primary-rgb), 0.48);
    background: linear-gradient(145deg, rgba(var(--budget-simple-primary-rgb), 0.16), rgba(var(--budget-simple-secondary-rgb), 0.08));
    color: var(--budget-simple-kicker);
}

.budget-simple-page .btn-secondary:hover {
    border-color: rgba(var(--budget-simple-secondary-rgb), 0.58);
    background: linear-gradient(145deg, rgba(var(--budget-simple-primary-rgb), 0.24), rgba(var(--budget-simple-secondary-rgb), 0.18));
}

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

@media (max-width: 1024px) {
    .budget-simple-page .budget-simple-hero-layout {
        grid-template-columns: 1fr;
    }

    .budget-simple-page .budget-simple-hero-aside {
        padding-left: 0;
        padding-top: 18px;
        border-left: 0;
        border-top: 1px solid rgba(var(--budget-simple-primary-rgb), 0.28);
    }

    .budget-simple-page .budget-quick-trust {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .budget-simple-page .budget-choice-grid,
    .budget-simple-page .budget-factor-grid-simple,
    .budget-simple-page .budget-steps-grid {
        grid-template-columns: 1fr;
    }

    .budget-simple-page .budget-includes-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .budget-simple-page .budget-simple-hero-box {
        padding: 24px 20px;
    }

    .budget-simple-page .budget-simple-hero-layout {
        gap: 18px;
    }

    .budget-simple-page .budget-simple-hero-copy {
        gap: 14px;
    }

    .budget-simple-page .budget-simple-hero-aside {
        padding-top: 14px;
    }

    .budget-simple-page .budget-simple-hero-box .section-title {
        font-size: clamp(1.84rem, 8vw, 2.3rem);
    }

    .budget-simple-page .budget-quick-trust,
    .budget-simple-page .budget-includes-grid,
    .budget-simple-page .budget-example-grid {
        grid-template-columns: 1fr;
    }

    .budget-simple-page .budget-simple-actions .btn,
    .budget-simple-page .budget-final-actions .btn {
        width: 100%;
    }

    .budget-simple-page .budget-range-card .basic-table {
        min-width: 540px;
    }

    .budget-simple-page .budget-faq-item summary {
        font-size: 0.96rem;
        line-height: 1.4;
    }
}

/* Guide page v2: premium editorial layout aligned with Home guide card palette */
.guide-page-comparativa {
    --guide-primary-rgb: 255, 186, 102;
    --guide-secondary-rgb: 240, 209, 166;
    --guide-accent-rgb: 255, 231, 199;
    --guide-title: #fff6e9;
    --guide-text: #e8ddcf;
    --guide-text-soft: #f0d1a6;
    --guide-kicker: #ffe8ca;
    --guide-link: #ffe7c7;
    --guide-link-hover: #fff6e9;
    --guide-cta-text: #2f2318;
    --guide-cta-text-hover: #241a12;
    --guide-surface: rgba(13, 19, 28, 0.84);
    --guide-panel:
        linear-gradient(150deg, rgba(var(--guide-primary-rgb), 0.2), rgba(var(--guide-secondary-rgb), 0.1) 52%, transparent 90%),
        var(--guide-surface);
    --section-accent: #ffc987;
    position: relative;
    isolation: isolate;
}

.guide-page-comparativa .section-title {
    color: var(--guide-title);
}

.guide-page-comparativa .section-subtitle {
    color: var(--guide-text);
}

.guide-page-comparativa::before,
.guide-page-comparativa::after {
    content: "";
    position: absolute;
    border-radius: 999px;
    pointer-events: none;
    z-index: -1;
    filter: blur(28px);
}

.guide-page-comparativa::before {
    inset: 9% auto auto -8%;
    width: min(42vw, 420px);
    height: min(42vw, 420px);
    background: radial-gradient(circle, rgba(var(--guide-primary-rgb), 0.24), transparent 68%);
}

.guide-page-comparativa::after {
    inset: auto -7% 18% auto;
    width: min(36vw, 360px);
    height: min(36vw, 360px);
    background: radial-gradient(circle, rgba(var(--guide-secondary-rgb), 0.2), transparent 72%);
}

.guide-page-comparativa .guide-hero {
    position: relative;
    overflow: clip;
}

.guide-page-comparativa .guide-hero-head {
    margin: 0 auto clamp(24px, 3vw, 34px) auto;
    text-align: left;
    max-width: 1080px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.4);
    border-radius: 24px;
    padding: clamp(28px, 3.2vw, 48px);
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(4px);
    background:
        radial-gradient(circle at 12% 12%, rgba(var(--guide-primary-rgb), 0.24), transparent 44%),
        linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.2), rgba(var(--guide-secondary-rgb), 0.12) 54%, transparent 92%),
        rgba(13, 19, 28, 0.88);
    box-shadow: 0 24px 46px rgba(0, 0, 0, 0.36);
}

.guide-page-comparativa .guide-hero-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
    gap: clamp(20px, 2.7vw, 38px);
    align-items: start;
}

.guide-page-comparativa .guide-hero-main {
    display: grid;
    gap: 14px;
    align-content: start;
}

.guide-page-comparativa .guide-hero-main .service-kicker {
    margin-bottom: 0;
}

.guide-page-comparativa .guide-hero-support {
    display: grid;
    gap: 14px;
    align-content: start;
    padding-left: clamp(14px, 2vw, 24px);
    border-left: 1px solid rgba(var(--guide-primary-rgb), 0.28);
}

.guide-page-comparativa .guide-hero-head::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.36;
    background: linear-gradient(126deg, rgba(var(--guide-primary-rgb), 0.3), transparent 42%, rgba(var(--guide-secondary-rgb), 0.14) 76%, transparent);
}

.guide-page-comparativa .guide-hero-head>* {
    position: relative;
    z-index: 1;
}

.guide-page-comparativa .service-kicker {
    border-color: rgba(var(--guide-primary-rgb), 0.54);
    background: linear-gradient(138deg, rgba(var(--guide-primary-rgb), 0.22), rgba(var(--guide-secondary-rgb), 0.14));
    color: var(--guide-kicker);
}

.guide-page-comparativa .guide-hero-head .section-title {
    margin-top: 0;
    margin-bottom: 0;
    max-width: 24ch;
    display: block;
    background: linear-gradient(98deg, #fff6e9 8%, #ffc987 42%, #f0d1a6 90%);
    background-size: 190% 190%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

.guide-page-comparativa .guide-hero-head .section-title::after {
    left: 0;
    transform: none;
    width: min(230px, 62%);
}

.guide-page-comparativa .guide-hero-head .section-subtitle {
    margin: 0;
    max-width: 56ch;
    color: var(--guide-text-soft);
}

.guide-page-comparativa .guide-hero-tags {
    margin-top: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.guide-page-comparativa .guide-hero-tags span {
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.46);
    background: linear-gradient(140deg, rgba(var(--guide-primary-rgb), 0.2), rgba(var(--guide-secondary-rgb), 0.1));
    color: var(--guide-kicker);
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.35;
}

.guide-page-comparativa .guide-hero-actions {
    margin-top: 0;
    display: grid;
    gap: 10px;
}

.guide-page-comparativa .guide-hero-actions .btn {
    width: 100%;
}

.guide-page-comparativa .guide-snapshot-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 8px;
}

.guide-page-comparativa .guide-snapshot-item {
    border: 1px solid rgba(var(--guide-primary-rgb), 0.34);
    border-radius: 14px;
    padding: 14px 16px;
    display: grid;
    gap: 7px;
    align-content: start;
    min-height: 102px;
    background: linear-gradient(142deg, rgba(var(--guide-primary-rgb), 0.18), rgba(var(--guide-secondary-rgb), 0.1));
}

.guide-page-comparativa .guide-snapshot-item span {
    color: var(--guide-text-soft);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.guide-page-comparativa .guide-snapshot-item strong {
    color: var(--guide-title);
    font-size: 0.96rem;
}

.guide-page-comparativa .guide-section {
    padding-top: 30px;
}

.guide-page-comparativa .guide-head-left {
    text-align: left;
    margin-bottom: 24px;
}

.guide-page-comparativa .guide-head-left .section-title::after {
    left: 0;
    transform: none;
    width: min(212px, 64%);
}

.guide-page-comparativa .guide-head-left .section-subtitle {
    margin-left: 0;
    margin-right: 0;
    max-width: 72ch;
}

.guide-page-comparativa .guide-mini-kicker {
    margin: 0;
    color: var(--guide-text-soft);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.guide-page-comparativa .guide-dual-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.guide-page-comparativa .guide-card {
    border-radius: 18px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.28);
    background: var(--guide-panel);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.3);
    display: grid;
    gap: 12px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.guide-page-comparativa .project-card::before {
    background: linear-gradient(122deg,
            rgba(var(--guide-primary-rgb), 0.34),
            transparent 36%,
            rgba(var(--guide-secondary-rgb), 0.24) 76%,
            transparent);
}

.guide-page-comparativa .project-card::after {
    background: radial-gradient(circle at var(--spot-x) var(--spot-y),
            rgba(var(--guide-primary-rgb), 0.24),
            transparent 46%);
}

.guide-page-comparativa .project-card:hover {
    border-color: rgba(var(--guide-primary-rgb), 0.5);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.34);
}

.guide-page-comparativa .guide-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--guide-primary-rgb), 0.56);
    box-shadow: 0 20px 38px rgba(0, 0, 0, 0.34);
}

.guide-page-comparativa .guide-choice-card h3 {
    margin: 0;
    color: var(--guide-title);
    font-size: 1.24rem;
}

.guide-page-comparativa .guide-choice-card p {
    margin: 0;
    color: var(--guide-text);
}

.guide-page-comparativa .guide-card .link-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.guide-page-comparativa .guide-card .link-list li {
    margin-left: 0;
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: var(--guide-text);
}

.guide-page-comparativa .guide-card .link-list li::before {
    content: "→";
    color: rgb(var(--guide-primary-rgb));
    font-size: 0.86rem;
    margin-top: 1px;
}

.guide-page-comparativa .guide-card a,
.guide-page-comparativa .project-card-link {
    color: var(--guide-link);
    font-weight: 600;
    text-decoration: none;
}

.guide-page-comparativa .guide-card a:hover,
.guide-page-comparativa .project-card-link:hover {
    color: var(--guide-link-hover);
}

.guide-page-comparativa .guide-card-corporate {
    background:
        linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.24), rgba(var(--guide-secondary-rgb), 0.08) 58%, transparent 90%),
        rgba(13, 19, 28, 0.84);
}

.guide-page-comparativa .guide-card-landing {
    background:
        linear-gradient(145deg, rgba(var(--guide-secondary-rgb), 0.2), rgba(var(--guide-primary-rgb), 0.12) 58%, transparent 90%),
        rgba(13, 19, 28, 0.84);
}

.guide-page-comparativa .guide-matrix-card {
    border-radius: 18px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.34);
    padding: 8px;
    transition: border-color 0.26s ease, box-shadow 0.26s ease, transform 0.26s ease;
}

.guide-page-comparativa .guide-matrix-card::before,
.guide-page-comparativa .guide-matrix-card::after {
    display: none;
}

.guide-page-comparativa .guide-matrix-card:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--guide-accent-rgb), 0.62);
    box-shadow:
        0 18px 34px rgba(0, 0, 0, 0.32),
        inset 0 0 0 1px rgba(var(--guide-accent-rgb), 0.2);
}

.guide-page-comparativa .guide-matrix-table th,
.guide-page-comparativa .guide-matrix-table td {
    border-color: rgba(var(--guide-primary-rgb), 0.25);
}

.guide-page-comparativa .guide-matrix-table th {
    color: var(--guide-title);
    background: rgba(var(--guide-primary-rgb), 0.16);
}

.guide-page-comparativa .guide-matrix-table td {
    color: var(--guide-text);
}

.guide-page-comparativa .guide-matrix-table tbody tr:nth-child(even) td {
    background: rgba(var(--guide-primary-rgb), 0.06);
}

.guide-page-comparativa .guide-note {
    margin-top: 12px;
    color: var(--guide-text);
    font-size: 0.93rem;
}

.guide-page-comparativa .guide-scenarios-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.guide-page-comparativa .guide-scenario-card {
    display: grid;
    gap: 10px;
}

.guide-page-comparativa .guide-scenario-tag {
    margin: 0;
    color: var(--guide-text-soft);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.guide-page-comparativa .guide-scenario-card h3 {
    margin: 0;
    color: var(--guide-title);
    font-size: 1.08rem;
}

.guide-page-comparativa .guide-scenario-card p {
    margin: 0;
    color: var(--guide-text);
}

.guide-page-comparativa .guide-scenario-answer {
    margin-top: auto;
    width: fit-content;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(var(--guide-accent-rgb), 0.5);
    background: linear-gradient(140deg, rgba(var(--guide-accent-rgb), 0.26), rgba(var(--guide-secondary-rgb), 0.12));
    color: var(--guide-title);
    font-size: 0.82rem;
    font-weight: 600;
}

.guide-page-comparativa .guide-risk-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.guide-page-comparativa .guide-risk-card {
    display: grid;
    gap: 10px;
}

.guide-page-comparativa .guide-risk-card h3 {
    margin: 0;
    color: var(--guide-title);
    font-size: 1.08rem;
}

.guide-page-comparativa .guide-risk-card p {
    margin: 0;
    color: var(--guide-text);
}

.guide-page-comparativa .guide-risk-fix {
    color: var(--guide-text-soft);
    font-weight: 600;
}

.guide-page-comparativa .guide-roadmap-section {
    padding-top: 20px;
}

.guide-page-comparativa .guide-roadmap-shell {
    border-radius: 22px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.34);
    background:
        linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.18), rgba(var(--guide-secondary-rgb), 0.1) 54%, transparent 90%),
        rgba(13, 19, 28, 0.86);
    transition: border-color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease;
}

.guide-page-comparativa .guide-roadmap-shell::before,
.guide-page-comparativa .guide-roadmap-shell::after {
    display: none;
}

.guide-page-comparativa .guide-roadmap-shell:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--guide-secondary-rgb), 0.54);
    box-shadow:
        0 20px 36px rgba(0, 0, 0, 0.34),
        inset 0 0 0 1px rgba(var(--guide-secondary-rgb), 0.16);
}

.guide-page-comparativa .guide-roadmap-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 12px;
    position: relative;
}

.guide-page-comparativa .guide-roadmap-list::before {
    content: "";
    position: absolute;
    left: 16px;
    top: 14px;
    bottom: 14px;
    width: 1px;
    background: linear-gradient(180deg, rgba(var(--guide-primary-rgb), 0.5), rgba(var(--guide-secondary-rgb), 0.5));
    opacity: 0.72;
}

.guide-page-comparativa .guide-roadmap-item {
    border: 1px solid rgba(var(--guide-primary-rgb), 0.25);
    border-radius: 14px;
    padding: 14px 15px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 12px;
    align-items: start;
    background: rgba(var(--guide-primary-rgb), 0.1);
    transition: transform 0.24s ease, border-color 0.24s ease, background-color 0.24s ease;
}

.guide-page-comparativa .guide-roadmap-item:hover {
    transform: translateX(3px);
    border-color: rgba(var(--guide-secondary-rgb), 0.46);
    background: rgba(var(--guide-primary-rgb), 0.14);
}

.guide-page-comparativa .guide-roadmap-item h3 {
    margin: 1px 0 6px;
    font-size: 1.04rem;
    color: var(--guide-title);
}

.guide-page-comparativa .guide-roadmap-item p {
    margin: 0;
    color: var(--guide-text);
    line-height: 1.5;
}

.guide-page-comparativa .guide-roadmap-step {
    display: inline-flex;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.66);
    background: linear-gradient(150deg, rgba(var(--guide-primary-rgb), 0.3), rgba(var(--guide-secondary-rgb), 0.2));
    color: var(--guide-title);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.guide-page-comparativa .guide-faq-section {
    padding-top: 24px;
}

.guide-page-comparativa .guide-faq-card {
    border-radius: 22px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.34);
    padding: clamp(20px, 2.3vw, 30px);
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(6px);
    background:
        linear-gradient(146deg, rgba(var(--guide-primary-rgb), 0.2), rgba(var(--guide-secondary-rgb), 0.1) 50%, transparent 90%),
        rgba(13, 19, 28, 0.86);
}

.guide-page-comparativa .guide-faq-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.34fr) minmax(0, 0.9fr);
    gap: 16px;
    align-items: start;
}

.guide-page-comparativa .guide-faq-list {
    display: grid;
    gap: 12px;
}

.guide-page-comparativa .guide-faq-item {
    border: 1px solid rgba(var(--guide-primary-rgb), 0.32);
    border-radius: 14px;
    background: linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.14), rgba(var(--guide-secondary-rgb), 0.06));
    position: relative;
    overflow: hidden;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.guide-page-comparativa .guide-faq-item::before,
.guide-page-comparativa .guide-faq-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.guide-page-comparativa .guide-faq-item::before {
    background: linear-gradient(124deg, rgba(var(--guide-primary-rgb), 0.34), transparent 40%, rgba(var(--guide-secondary-rgb), 0.2) 78%, transparent);
}

.guide-page-comparativa .guide-faq-item::after {
    background: radial-gradient(circle at 14% 4%, rgba(255, 255, 255, 0.2), transparent 44%);
}

.guide-page-comparativa .guide-faq-item:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--guide-primary-rgb), 0.58);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.3);
    background: linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.22), rgba(var(--guide-secondary-rgb), 0.1));
}

.guide-page-comparativa .guide-faq-item:hover::before,
.guide-page-comparativa .guide-faq-item:hover::after {
    opacity: 1;
}

.guide-page-comparativa .guide-faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 15px 18px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--guide-title);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.guide-page-comparativa .guide-faq-item summary::-webkit-details-marker {
    display: none;
}

.guide-page-comparativa .guide-faq-item summary::after {
    content: "+";
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
    border-radius: 999px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.56);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgb(var(--guide-primary-rgb));
    font-size: 0.94rem;
}

.guide-page-comparativa .guide-faq-item[open] summary::after {
    content: "−";
    border-color: rgba(var(--guide-secondary-rgb), 0.56);
}

.guide-page-comparativa .guide-faq-item p {
    margin: 0;
    padding: 0 18px 16px;
    color: var(--guide-text);
}

.guide-page-comparativa .guide-related-box {
    border: 1px solid rgba(var(--guide-primary-rgb), 0.3);
    border-radius: 16px;
    padding: 16px;
    background:
        linear-gradient(150deg, rgba(var(--guide-primary-rgb), 0.14), rgba(var(--guide-secondary-rgb), 0.06) 44%, transparent 90%),
        rgba(14, 20, 30, 0.74);
}

.guide-page-comparativa .guide-related-box h3 {
    margin: 0 0 10px;
    font-size: 0.95rem;
    color: var(--guide-kicker);
    letter-spacing: 0.02em;
}

.guide-page-comparativa .guide-related-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.guide-page-comparativa .guide-related-list li {
    list-style: none;
}

.guide-page-comparativa .guide-related-list a {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 10px;
    padding: 10px 11px;
    border-radius: 11px;
    border: 1px solid rgba(var(--guide-primary-rgb), 0.26);
    background: rgba(var(--guide-primary-rgb), 0.09);
    color: var(--guide-title);
    font-weight: 600;
    line-height: 1.35;
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.guide-page-comparativa .guide-related-list a::after {
    content: "→";
    font-size: 0.94rem;
    opacity: 0.92;
}

.guide-page-comparativa .guide-related-list a:hover {
    transform: translateX(2px);
    border-color: rgba(var(--guide-secondary-rgb), 0.46);
    background: rgba(var(--guide-secondary-rgb), 0.14);
}

.guide-page-comparativa .guide-final-section {
    padding-top: 12px;
}

.guide-page-comparativa .guide-final-cta {
    border: 1px solid rgba(var(--guide-primary-rgb), 0.36);
    border-radius: 22px;
    background:
        radial-gradient(circle at 18% 22%, rgba(var(--guide-primary-rgb), 0.34), transparent 44%),
        radial-gradient(circle at 84% 72%, rgba(var(--guide-secondary-rgb), 0.24), transparent 46%),
        linear-gradient(138deg, rgba(var(--guide-primary-rgb), 0.2), rgba(var(--guide-secondary-rgb), 0.12) 52%, transparent 90%),
        rgba(13, 19, 28, 0.88);
}

.guide-page-comparativa .guide-final-actions {
    justify-content: center;
}

.guide-page-comparativa .btn-primary {
    border-color: rgba(var(--guide-primary-rgb), 0.72);
    background: linear-gradient(132deg, #ffd194 0%, #ffbe77 44%, #f0d1a6 100%);
    color: var(--guide-cta-text);
    box-shadow: 0 12px 28px rgba(var(--guide-primary-rgb), 0.3);
}

.guide-page-comparativa .btn-primary:hover {
    border-color: rgba(var(--guide-secondary-rgb), 0.72);
    background: linear-gradient(132deg, #ffe0b8 0%, #ffc887 44%, #f5ddba 100%);
    color: var(--guide-cta-text-hover);
    box-shadow: 0 16px 34px rgba(var(--guide-secondary-rgb), 0.28);
}

.guide-page-comparativa .btn-secondary {
    border-color: rgba(var(--guide-primary-rgb), 0.46);
    background: linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.16), rgba(var(--guide-secondary-rgb), 0.08));
    color: var(--guide-kicker);
}

.guide-page-comparativa .btn-secondary:hover {
    border-color: rgba(var(--guide-secondary-rgb), 0.58);
    background: linear-gradient(145deg, rgba(var(--guide-primary-rgb), 0.24), rgba(var(--guide-secondary-rgb), 0.18));
}

@media (max-width: 1180px) {
    .guide-page-comparativa .guide-scenarios-grid,
    .guide-page-comparativa .guide-risk-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1024px) {
    .guide-page-comparativa .guide-hero-layout {
        grid-template-columns: 1fr;
    }

    .guide-page-comparativa .guide-hero-support {
        padding-left: 0;
        padding-top: 16px;
        border-left: 0;
        border-top: 1px solid rgba(var(--guide-primary-rgb), 0.28);
    }

    .guide-page-comparativa .guide-hero-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .guide-page-comparativa .guide-snapshot-grid,
    .guide-page-comparativa .guide-dual-grid,
    .guide-page-comparativa .guide-faq-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .guide-page-comparativa .guide-hero-head {
        padding: 22px 18px;
        border-radius: 18px;
    }

    .guide-page-comparativa .guide-hero-layout {
        gap: 16px;
    }

    .guide-page-comparativa .guide-hero-support {
        padding-top: 12px;
    }

    .guide-page-comparativa .guide-hero-head .section-title {
        max-width: 100%;
        font-size: clamp(1.75rem, 8vw, 2.24rem);
    }

    .guide-page-comparativa .guide-hero-tags span {
        font-size: 0.76rem;
    }

    .guide-page-comparativa .guide-scenarios-grid,
    .guide-page-comparativa .guide-risk-grid {
        grid-template-columns: 1fr;
    }

    .guide-page-comparativa .guide-hero-actions .btn,
    .guide-page-comparativa .guide-final-actions .btn {
        width: 100%;
    }

    .guide-page-comparativa .guide-hero-actions {
        grid-template-columns: 1fr;
    }

    .guide-page-comparativa .guide-matrix-table {
        min-width: 560px;
    }

    .guide-page-comparativa .guide-roadmap-item {
        padding: 12px;
    }
}


/* =========================================================
   BLOG ARTICLES & FOOTER NAV
   ========================================================= */

/* Footer nav */
.footer-nav {
    margin-bottom: 20px;
}

.footer-nav ul {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 20px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-nav a {
    color: var(--text-muted, #8892a4);
    text-decoration: none;
    font-size: 0.85rem;
    transition: color 0.2s;
}

.footer-nav a:hover {
    color: var(--primary, #5B8CFF);
}

/* Breadcrumb */
.breadcrumb {
    margin-bottom: 32px;
}

.breadcrumb ol {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 8px;
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-muted, #8892a4);
}

.breadcrumb li:not(:last-child)::after {
    content: '/';
    margin-left: 8px;
    color: var(--text-muted, #8892a4);
}

.breadcrumb a {
    color: var(--text-muted, #8892a4);
    text-decoration: none;
}

.breadcrumb a:hover {
    color: var(--primary, #5B8CFF);
}

/* Article layout */
.article-layout {
    padding: 60px 0 80px;
}

.article-header {
    max-width: 720px;
    margin-bottom: 48px;
}

.article-header h1 {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.2;
    margin-bottom: 16px;
}

.article-lead {
    font-size: 1.1rem;
    line-height: 1.7;
    color: var(--text-secondary, #c5cdd9);
    margin-bottom: 12px;
}

.article-meta {
    font-size: 0.85rem;
    color: var(--text-muted, #8892a4);
}

.article-body {
    max-width: 720px;
    line-height: 1.8;
}

.article-body h2 {
    font-size: 1.4rem;
    margin-top: 48px;
    margin-bottom: 16px;
    color: var(--text-primary, #e8edf5);
}

.article-body h3 {
    font-size: 1.1rem;
    margin-top: 32px;
    margin-bottom: 12px;
    color: var(--text-primary, #e8edf5);
}

.article-body p {
    margin-bottom: 16px;
    color: var(--text-secondary, #c5cdd9);
}

.article-body ul,
.article-body ol {
    margin-bottom: 20px;
    padding-left: 20px;
    color: var(--text-secondary, #c5cdd9);
}

.article-body li {
    margin-bottom: 8px;
    line-height: 1.7;
}

.article-body strong {
    color: var(--text-primary, #e8edf5);
}

.article-body em {
    color: var(--primary, #5B8CFF);
    font-style: normal;
}

/* Article CTA block */
.article-cta {
    background: var(--bg-card, #161b24);
    border: 1px solid var(--border, #232a36);
    border-radius: 12px;
    padding: 32px;
    margin-top: 48px;
    margin-bottom: 48px;
}

.article-cta h2 {
    margin-top: 0 !important;
    font-size: 1.3rem;
    margin-bottom: 12px;
}

.article-cta p {
    margin-bottom: 20px;
}

.article-cta .btn {
    margin-right: 12px;
    margin-bottom: 8px;
}

/* Article related links */
.article-related {
    max-width: 720px;
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid var(--border, #232a36);
}

.article-related h2 {
    font-size: 1.1rem;
    margin-bottom: 16px;
    color: var(--text-primary, #e8edf5);
}

.article-related ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.article-related li {
    margin-bottom: 10px;
}

.article-related a {
    color: var(--primary, #5B8CFF);
    text-decoration: none;
    font-size: 0.95rem;
}

.article-related a:hover {
    text-decoration: underline;
}

@media (max-width: 640px) {
    .article-cta {
        padding: 20px;
    }

    .footer-nav ul {
        flex-direction: column;
        gap: 8px;
    }
}
