/* =========================================================
   HEADER OVERRIDE
   El body tiene .page-servicios (fuerza header en negro para el listado claro)
   pero las páginas individuales tienen hero OSCURO → texto debe ser BLANCO.
   ========================================================= */
.page-servicio-individual .site-header--transparent .site-nav__link {
    color: var(--zander-white-hi);
}

.page-servicio-individual .site-header--transparent .site-nav__link::after {
    background: var(--zander-yellow);
}

.page-servicio-individual .site-header--transparent .site-nav__link.is-active {
    color: var(--zander-yellow) !important;
}

.page-servicio-individual .site-header--transparent .ham .line {
    stroke: var(--zander-white-hi);
}

.page-servicio-individual .site-header--transparent .site-header__burger span {
    background: var(--zander-white-hi);
}

/* Header scrolled en páginas individuales → fondo negro + texto blanco
   (revierte el blanco/negro forzado por .page-servicios) */
.page-servicio-individual .site-header--scrolled {
    background-color: var(--zander-black) !important;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3) !important;
}

.page-servicio-individual .site-header--scrolled .site-nav__link {
    color: var(--zander-white-hi) !important;
}

.page-servicio-individual .site-header--scrolled .ham .line {
    stroke: var(--zander-white-hi) !important;
}

.page-servicio-individual .site-header--scrolled .site-header__burger span {
    background: var(--zander-white-hi) !important;
}

/* =========================================================
   Páginas de servicio individual · /servicios/<slug>.php
   Estructura tipo landing (hero → promesa → beneficios → incluye → proceso
   → proyectos → equipo → precios → faq → formulario)
   Todo scope: .page-servicio-individual
   ========================================================= */

.page-servicio-individual {
    --svc-y: var(--zander-yellow);
    --svc-y-soft: rgba(252, 198, 28, .10);
    --svc-y-soft-2: rgba(252, 198, 28, .25);
    --svc-dark: var(--zander-black);
    --svc-dark-2: #222220;
    --svc-paper: var(--zander-white-soft);
    --svc-paper-2: #f4f4ee;
    --svc-paper-3: #e8e7df;

    --svc-card-bg: rgba(255, 255, 255, .05);
    --svc-card-bg-hover: rgba(255, 255, 255, .09);
    --svc-card-bd: rgba(255, 255, 255, .10);
    --svc-card-bd-hover: rgba(255, 255, 255, .20);
    --svc-paper-soft: rgba(251, 251, 251, .55);
    --svc-paper-mid: rgba(251, 251, 251, .75);
    --svc-card-light-bd: rgba(29, 29, 27, .12);

    --svc-container: 1290px;
    --svc-pad: 28px;
    --svc-t-base: .35s cubic-bezier(.3, 1, .8, 1);
    --svc-t-fast: .2s ease;

    --svc-r-sm: 12px;
    --svc-r-md: 20px;
    --svc-r-lg: 24px;
    --svc-r-xl: 32px;
}

/* =========================================================
   PALETA ADAPTATIVA AL TEMA (para el morph)
   Las variables de arriba ("paper" = tinta clara, superficies de tarjeta
   translúcidas en blanco) están pensadas para fondo OSCURO. Durante el morph
   el fondo del body pasa por claro: si no adaptamos, el texto e tarjetas de
   una sección oscura quedan invisibles mientras el body aún está claro.
   Cuando body[data-theme="light"], invertimos SOLO la paleta "paper" y las
   superficies de tarjeta para que sigan legibles. --svc-dark y los acentos
   (amarillo) NO se tocan: son fijos a propósito. Los usos de --svc-paper como
   FONDO de sección ya están neutralizados por la regla transparente del morph,
   así que esto solo afecta a texto y tarjetas. */
body[data-theme="light"]:not([data-theme-mode="solid"]) .page-servicio-individual,
body:not([data-theme-mode="solid"])[data-theme="light"].page-servicio-individual {
    --svc-paper:         var(--zander-black);
    --svc-paper-soft:    rgba(29, 29, 27, .55);
    --svc-paper-mid:     rgba(29, 29, 27, .75);
    --svc-card-bg:       rgba(0, 0, 0, .04);
    --svc-card-bg-hover: rgba(0, 0, 0, .07);
    --svc-card-bd:       rgba(29, 29, 27, .12);
    --svc-card-bd-hover: rgba(29, 29, 27, .22);
}

/* MODO FIJO (solid): cada sección lleva su propio tema, así que la paleta
   "paper"/tarjeta sigue el tema de la SECCIÓN (lee --theme-ink de su atributo),
   no el del body. Las superficies de tarjeta usan un velo del color de tinta,
   válido sobre cualquier fondo. */
body[data-theme-mode="solid"].page-servicio-individual [data-theme] {
    --svc-paper:         var(--theme-ink);
    --svc-paper-soft:    var(--theme-ink-soft);
    --svc-paper-mid:     var(--theme-ink-soft);
    --svc-card-bg:       color-mix(in srgb, var(--theme-ink) 5%, transparent);
    --svc-card-bg-hover: color-mix(in srgb, var(--theme-ink) 9%, transparent);
    --svc-card-bd:       color-mix(in srgb, var(--theme-ink) 12%, transparent);
    --svc-card-bd-hover: color-mix(in srgb, var(--theme-ink) 22%, transparent);
}

/* Texto de precio (div) e IVA (span): la regla :where global de global.css
   coordina h*/p/li con el morph, pero no div/span. Estos consumen --svc-paper
   (ahora adaptativo), así que deben cruzar su color junto al fondo. */
body[data-theme] .page-servicio-individual :where(.zw-price__amount, .zw-price__iva) {
    transition: color var(--theme-fade);
}


/* ============== Layout shells ============== */
.page-servicio-individual .zw-container {
    max-width: var(--svc-container);
    margin: 0 auto;
    padding: 0 var(--svc-pad);
}

.page-servicio-individual .zw-section {
    padding: 100px 0;
    position: relative
}

.page-servicio-individual .zw-section--dark {
    background: var(--svc-dark);
    color: var(--svc-paper)
}

.page-servicio-individual .zw-section--light {
    background: var(--svc-paper);
    color: var(--svc-dark)
}

@media (max-width:760px) {
    .page-servicio-individual .zw-section {
        padding: 72px 0
    }
}

/* ============== Tipografía compartida ============== */
.page-servicio-individual .zw-eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .4em;
    text-transform: uppercase;
    color: var(--svc-y);
    margin-bottom: 18px;
}

.page-servicio-individual .zw-eyebrow--dark {
    color: #9a7d00
}

.page-servicio-individual .zw-tag {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 6px 14px;
    border-radius: 100px;
    background: var(--svc-y-soft);
    color: var(--svc-y);
    border: 1px solid var(--svc-y-soft-2);
    margin-bottom: 24px;
}

.page-servicio-individual .zw-section__header {
    margin-bottom: 56px;
    max-width: 680px
}

.page-servicio-individual .zw-section__header--center {
    margin-left: auto;
    margin-right: auto;
    text-align: center
}

.page-servicio-individual .zw-section__title {
    font-weight: 700;
    font-size: var(--fs-h2);
    line-height: 1.1;
    letter-spacing: -.01em;
    text-wrap: balance;
    margin-bottom: 14px;
    color: var(--svc-paper);
}

.page-servicio-individual .zw-section__title em {
    color: var(--svc-y);
    font-style: normal;
}

.page-servicio-individual .zw-section__title--dark {
    color: var(--svc-dark)
}

.page-servicio-individual .zw-section__title--dark em {
    color: var(--svc-dark);
    background: var(--svc-y);
    padding: 0 16px;
    border-radius: 100px;
}

.page-servicio-individual .zw-section__subtitle {
    font-size: var(--fs-body);
    line-height: 1.6;
    color: var(--svc-paper-soft);
    max-width: 560px;
}

.page-servicio-individual .zw-section__subtitle--dark {
    color: rgba(29, 29, 27, .6)
}

.page-servicio-individual .zw-section__header--center .zw-section__subtitle {
    margin-left: auto;
    margin-right: auto
}

/* ============== Glass card compartida ============== */
.page-servicio-individual .sc {
    background-color: var(--svc-card-bg);
    border: 1px solid var(--svc-card-bd);
    border-radius: var(--svc-r-lg);
    padding: 36px 32px;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    transition: border-color var(--svc-t-base), transform var(--svc-t-base), box-shadow var(--svc-t-base), background-color var(--svc-t-base);
}

.page-servicio-individual .sc:hover {
    border-color: var(--svc-card-bd-hover);
    background-color: var(--svc-card-bg-hover);
    transform: translateY(-4px);
    box-shadow: 0 20px 56px rgba(0, 0, 0, .5);
}

.page-servicio-individual .sc .ico {
    width: 48px;
    height: 48px;
    margin-bottom: 20px;
    display: block;
    flex-shrink: 0;
}

.page-servicio-individual .sc .ico svg {
    width: 100%;
    height: 100%;
    stroke: var(--svc-y);
    stroke-width: 2;
    fill: none;
    display: block;
}

.page-servicio-individual .sc h3 {
    font-size: var(--fs-h3);
    font-weight: 700;
    margin: 0 0 10px;
    color: var(--svc-paper);
    line-height: 1.3;
    letter-spacing: -.005em;
}

.page-servicio-individual .sc p {
    font-size: var(--fs-body);
    color: var(--svc-paper-soft);
    line-height: 1.6;
    margin: 0;
}

.page-servicio-individual .sc .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
    position: relative;
    z-index: 2
}

.page-servicio-individual .sc .tag {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .04em;
    padding: 5px 12px;
    border-radius: 100px;
    background: var(--svc-y-soft);
    color: var(--svc-y);
    border: 1px solid var(--svc-y-soft-2);
}

/* =========================================================
   1. HERO
   ========================================================= */
.page-servicio-individual .zw-hero {
    position: relative;
    background: var(--svc-dark);
    padding: 140px 0 100px;
    overflow: hidden;
    color: var(--svc-paper);
}

.page-servicio-individual .zw-hero__bg {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(252, 198, 28, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(252, 198, 28, 0.06) 1px, transparent 1px);
    background-size: 40px 40px;
    mask-image: radial-gradient(ellipse at center, #000 0%, rgba(0, 0, 0, .45) 60%, transparent 95%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, rgba(0, 0, 0, .45) 60%, transparent 95%);
    z-index: 1;
}

.page-servicio-individual .zw-hero__inner {
    position: relative;
    z-index: 3;
    max-width: 1580px;
    margin: 0 auto;
    padding: 0 var(--svc-pad);
}

/* breadcrumb (sobreescribe el del header) */
.page-servicio-individual .zw-hero .zw-breadcrumb {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--svc-paper-soft);
    font-weight: 600;
    margin-bottom: 48px;
}

.page-servicio-individual .zw-hero .zw-breadcrumb a {
    color: var(--svc-paper-soft);
    transition: color var(--svc-t-fast)
}

.page-servicio-individual .zw-hero .zw-breadcrumb a:hover {
    color: var(--svc-y)
}

.page-servicio-individual .zw-hero .zw-breadcrumb [aria-current] {
    color: var(--svc-y)
}

/* hero grid */
.page-servicio-individual .zw-hero__grid {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 64px;
    align-items: center;
}

.page-servicio-individual .zw-hero__title {
    font-weight: 700;
    font-size: var(--fs-h1);
    line-height: 1.05;
    letter-spacing: -.015em;
    margin-bottom: 24px;
    text-wrap: balance;
}

/* H1: palabra clave en amarillo, sin fondo/subrayado */
.page-servicio-individual .zw-hero__title em {
    color: var(--svc-y);
    font-style: normal;
    background: none;
    padding: 0;
    border-radius: 0;
    display: inline;
}

.page-servicio-individual .zw-hero__lead {
    font-size: var(--fs-body);
    line-height: 1.6;
    color: var(--svc-paper-mid);
    max-width: 520px;
    margin-bottom: 36px;
}

.page-servicio-individual .zw-hero__cta {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 48px
}

.page-servicio-individual .zw-hero__trust {
    display: flex;
    align-items: center;
    gap: 28px;
    padding-top: 32px;
    border-top: 1px solid rgba(255, 255, 255, .08);
}

.page-servicio-individual .zw-hero__trust-item {
    display: flex;
    flex-direction: column;
    gap: 2px
}

.page-servicio-individual .zw-hero__trust-item strong {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--svc-paper);
    letter-spacing: -.01em;
    line-height: 1;
}

.page-servicio-individual .zw-hero__trust-item span {
    font-size: 12px;
    color: var(--svc-paper-soft);
    font-weight: 600
}

.page-servicio-individual .zw-hero__trust-divider {
    width: 1px;
    height: 32px;
    background: rgba(255, 255, 255, .1)
}

/* hero visual — browser + phone mockups */
.page-servicio-individual .zw-hero__visual {
    position: relative;
    height: 690px;
    z-index: 2
}

.page-servicio-individual .zw-hero-mock {
    position: absolute;
    background: linear-gradient(180deg, #2a2a26 0%, #1f1f1c 100%);
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 14px;
    box-shadow: 0 30px 70px rgba(0, 0, 0, .5);
    overflow: hidden;
}

.page-servicio-individual .zw-hero-mock--main {
    right: 0;
    top: 0;
    width: 88%;
    height: 300px;
    transform: rotate(-2deg);
}

.page-servicio-individual .zw-hero-mock__bar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 11px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.page-servicio-individual .zw-hero-mock__bar span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .16);
}

.page-servicio-individual .zw-hero-mock__bar span:first-child {
    background: rgba(252, 198, 28, .7)
}

.page-servicio-individual .zw-hero-mock__url {
    margin-left: 14px;
    height: 20px;
    width: 50%;
    border-radius: 6px;
    background: rgba(255, 255, 255, .06);
    display: flex;
    align-items: center;
    padding: 0 10px;
    font-family: monospace;
    font-size: 11px;
    color: rgba(255, 255, 255, .5);
}

.page-servicio-individual .zw-hero-mock__body {
    padding: 24px
}

.page-servicio-individual .zw-hero-mock__hero {
    height: 80px;
    border-radius: 8px;
    margin-bottom: 16px;
    background:
        radial-gradient(circle at 80% 50%, rgba(252, 198, 28, .18), transparent 60%),
        linear-gradient(135deg, #2c2c28, #1d1d1b);
    position: relative;
}

.page-servicio-individual .zw-hero-mock__hero::after {
    content: "";
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: 60%;
    height: 8px;
    border-radius: 4px;
    background: rgba(252, 198, 28, .55);
    box-shadow: 0 14px 0 rgba(255, 255, 255, .4), 26px 14px 0 rgba(255, 255, 255, .4);
}

.page-servicio-individual .zw-hero-mock__cols {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 14px
}

.page-servicio-individual .zw-hero-mock__col {
    height: 70px;
    border-radius: 8px;
    background: rgba(255, 255, 255, .05);
    border: 1px solid rgba(255, 255, 255, .08);
    position: relative;
}

.page-servicio-individual .zw-hero-mock__col::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 10px;
    width: 18px;
    height: 18px;
    border-radius: 5px;
    background: var(--svc-y);
    opacity: .7;
}

.page-servicio-individual .zw-hero-mock__col::after {
    content: "";
    position: absolute;
    left: 10px;
    bottom: 10px;
    right: 10px;
    height: 4px;
    border-radius: 2px;
    background: rgba(255, 255, 255, .2);
    box-shadow: 0 8px 0 rgba(255, 255, 255, .1);
}

.page-servicio-individual .zw-hero-mock__line {
    height: 5px;
    border-radius: 2px;
    background: rgba(255, 255, 255, .1);
    margin-bottom: 6px
}

.page-servicio-individual .zw-hero-mock__line.s {
    width: 60%
}

.page-servicio-individual .zw-hero-mock__line.m {
    width: 80%
}

.page-servicio-individual .zw-hero-mock__line.l {
    width: 45%
}

.page-servicio-individual .zw-hero-mock--phone {
    left: 0;
    bottom: 0;
    width: 148px;
    height: 280px;
    border-radius: 24px;
    transform: rotate(4deg);
    z-index: 2;
    background: linear-gradient(180deg, #15151200 0%, #1a1a18 100%), #1a1a18;
    border: 1.5px solid rgba(255, 255, 255, .12);
}

.page-servicio-individual .zw-hero-mock__notch {
    position: absolute;
    top: 9px;
    left: 50%;
    transform: translateX(-50%);
    width: 46px;
    height: 5px;
    border-radius: 5px;
    background: rgba(255, 255, 255, .18);
}

.page-servicio-individual .zw-hero-mock__phone-body {
    padding: 30px 14px 14px
}

.page-servicio-individual .zw-hero-mock__phone-hero {
    height: 120px;
    border-radius: 10px;
    margin-bottom: 14px;
    background:
        radial-gradient(circle at 70% 70%, rgba(252, 198, 28, .3), transparent 60%),
        linear-gradient(180deg, #2a2a26, #1d1d1b);
    position: relative;
}

.page-servicio-individual .zw-hero-mock__phone-hero::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 14px;
    height: 8px;
    border-radius: 4px;
    background: var(--svc-y);
}

.page-servicio-individual .zw-hero-mock__phone-line {
    height: 6px;
    border-radius: 3px;
    background: rgba(255, 255, 255, .12);
    margin-bottom: 6px
}

.page-servicio-individual .zw-hero-mock__phone-line.short {
    width: 60%
}

.page-servicio-individual .zw-hero-mock__phone-btn {
    height: 30px;
    border-radius: 9px;
    background: var(--svc-y);
    margin-top: 16px;
    position: relative;
}

.page-servicio-individual .zw-hero-mock__phone-btn::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 50%;
    height: 6px;
    border-radius: 3px;
    background: rgba(29, 29, 27, .8);
}

/* sticker plazo */
.page-servicio-individual .zw-hero__sticker {
    position: absolute;
    right: -12px;
    bottom: -12px;
    background: var(--svc-y);
    border-radius: 16px;
    padding: 14px 18px;
    box-shadow: 0 14px 32px rgba(252, 198, 28, .25), 0 0 0 2px var(--svc-dark);
    display: flex;
    align-items: center;
    gap: 12px;
    transform: rotate(-5deg);
    z-index: 3;
    animation: zw-svc-sticker-wiggle 4.5s ease-in-out infinite;
}

@keyframes zw-svc-sticker-wiggle {

    0%,
    100% {
        transform: rotate(-5deg) translateY(0)
    }

    50% {
        transform: rotate(-4deg) translateY(-4px)
    }
}

.page-servicio-individual .zw-hero__sticker .lh {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--svc-dark)
}

.page-servicio-individual .zw-hero__sticker svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: var(--svc-dark);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.page-servicio-individual .zw-hero__sticker span {
    font-size: 12.5px;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -.005em
}

/* embers en hero (capa por encima del bg) */
.page-servicio-individual .zw-hero .wp-embers-container {
    z-index: 2
}

/* =========================================================
   2. PROMESA
   ========================================================= */
.page-servicio-individual .zw-promise {
    padding: 120px 0;
}

.page-servicio-individual .zw-promise .zw-container {
    max-width: 920px;
    text-align: center;
}

.page-servicio-individual .zw-promise__quote {
    font-weight: 700;
    font-size: var(--fs-h2);
    line-height: 1.05;
    letter-spacing: -.015em;
    color: var(--section-text);
    margin: 0 auto 40px;
    text-wrap: balance;
    max-width: 760px;
}

/* "que venden": subrayado fino solo en la parte inferior */
.page-servicio-individual .zw-promise__quote em {
    color: inherit;
    font-style: normal;
    background: none;
    padding: 0;
}

.page-servicio-individual .zw-promise__quote .zw-mark {
    background: var(--svc-y);
    color: var(--svc-dark);
    padding: 0 10px;
    border-radius: 100px;
    display: inline;
    line-height: 1.1;
}

.page-servicio-individual .zw-promise__body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    text-align: left;
    max-width: 780px;
    margin: 0 auto;
}

.page-servicio-individual .zw-promise__body p {
    font-size: var(--fs-body);
    line-height: 1.65;
    color: rgba(29, 29, 27, .7);
}

.page-servicio-individual .zw-promise__body strong {
    color: var(--svc-dark);
    font-weight: 800
}

/* Párrafo que ocupa el ancho completo de la rejilla (las 2 columnas) */
.page-servicio-individual .zw-promise__body p.zw-promise__full {
    grid-column: 1 / -1;
}

@media (max-width:760px) {
    .page-servicio-individual .zw-promise__body {
        grid-template-columns: 1fr;
        gap: 20px
    }
}

/* =========================================================
   3. BENEFICIOS — bento glass cards
   ========================================================= */
.page-servicio-individual .zw-bento {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(180px, auto);
    gap: 20px;
}

.page-servicio-individual .zw-bento .sc {
    padding: 30px
}

.page-servicio-individual .zw-bento .b-hero {
    grid-column: span 7;
    grid-row: span 2;
    padding: 40px;
    background:
        radial-gradient(circle at 100% 0%, rgba(252, 198, 28, .08), transparent 50%),
        var(--svc-card-bg);
}

.page-servicio-individual .zw-bento .b-hero .ico {
    width: 56px;
    height: 56px
}

.page-servicio-individual .zw-bento .b-hero h3 {
    font-size: var(--fs-h3);
    letter-spacing: -.01em;
    margin-bottom: 14px;
    max-width: 380px
}

.page-servicio-individual .zw-bento .b-hero p {
    font-size: var(--fs-body);
    color: var(--svc-paper-mid);
    max-width: 440px;
    margin-bottom: 0
}

.page-servicio-individual .zw-bento .b-hero .preview {
    position: absolute;
    right: -30px;
    bottom: -30px;
    width: 340px;
    height: 200px;
    border-radius: 14px;
    background: linear-gradient(135deg, #2a2a26 0%, #1a1a18 100%);
    border: 1px solid rgba(255, 255, 255, .08);
    transform: rotate(-4deg);
    box-shadow: 0 24px 60px rgba(0, 0, 0, .5);
    overflow: hidden;
}

.page-servicio-individual .zw-bento .b-hero .preview::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 28px;
    background: rgba(0, 0, 0, .3);
    border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.page-servicio-individual .zw-bento .b-hero .preview::after {
    content: "";
    position: absolute;
    top: 8px;
    left: 12px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(252, 198, 28, .5);
    box-shadow: 14px 0 0 rgba(255, 255, 255, .15), 28px 0 0 rgba(255, 255, 255, .15);
}

.page-servicio-individual .zw-bento .b-hero .preview .lines {
    position: absolute;
    top: 48px;
    left: 18px;
    right: 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.page-servicio-individual .zw-bento .b-hero .preview .lines i {
    display: block;
    height: 8px;
    border-radius: 4px;
    background: rgba(255, 255, 255, .08);
}

.page-servicio-individual .zw-bento .b-hero .preview .lines i:nth-child(1) {
    width: 60%;
    background: rgba(252, 198, 28, .4)
}

.page-servicio-individual .zw-bento .b-hero .preview .lines i:nth-child(2) {
    width: 90%
}

.page-servicio-individual .zw-bento .b-hero .preview .lines i:nth-child(3) {
    width: 75%
}

.page-servicio-individual .zw-bento .b-hero .preview .lines i:nth-child(4) {
    width: 85%
}

.page-servicio-individual .zw-bento .b-medium {
    grid-column: span 5;
    grid-row: span 2;
    padding: 36px;
    background: linear-gradient(180deg, var(--svc-card-bg) 0%, rgba(252, 198, 28, .04) 100%);
}

.page-servicio-individual .zw-bento .b-medium .ico {
    width: 56px;
    height: 56px
}

.page-servicio-individual .zw-bento .b-medium h3 {
    font-size: var(--fs-h3);
    margin-bottom: 12px
}

.page-servicio-individual .zw-bento .b-medium p {
    font-size: var(--fs-body);
    color: var(--svc-paper-mid);
    margin-bottom: 20px
}

.page-servicio-individual .zw-bento .b-medium .stat {
    margin-top: auto;
    display: flex;
    align-items: baseline;
    gap: 8px;
    padding-top: 20px;
    border-top: 1px solid var(--svc-card-bd);
}

.page-servicio-individual .zw-bento .b-medium .stat b {
    font-size: 36px;
    font-weight: 700;
    color: var(--svc-y);
    letter-spacing: -.02em;
    line-height: 1
}

.page-servicio-individual .zw-bento .b-medium .stat span {
    color: var(--svc-paper-soft);
    font-size: 13px;
    line-height: 1.3
}

.page-servicio-individual .zw-bento .sc:not(.b-hero):not(.b-medium) {
    grid-column: span 4
}

/* =========================================================
   4. QUÉ INCLUYE
   ========================================================= */
.page-servicio-individual .zw-includes__title .zw-mark {
    background: var(--svc-y);
    color: var(--svc-dark);
    padding: 0 10px;
    border-radius: 100px;
    display: inline;
    line-height: 1.1;
}

@media (min-width: 641px) {
    .page-servicio-individual .zw-includes__title {
        text-wrap: balance;
    }
}

.page-servicio-individual .zw-includes__grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 80px;
    align-items: center;
}

.page-servicio-individual .zw-includes__intro {
    font-size: var(--fs-body);
    line-height: 1.65;
    color: rgba(29, 29, 27, .65);
    margin: 24px 0 32px;
    max-width: 540px;
}

.page-servicio-individual .zw-checklist {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 0;
    margin: 0;
}

.page-servicio-individual .zw-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-size: var(--fs-body);
    line-height: 1.5;
    color: var(--svc-dark);
    font-weight: 600;
}

.page-servicio-individual .zw-checklist li svg {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    background: var(--svc-y);
    border-radius: 50%;
    padding: 5px;
    margin-top: 1px;
}

/* mock paper "propuesta" */
.page-servicio-individual .zw-includes__visual {
    position: relative
}

.page-servicio-individual .zw-mock-paper {
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 30px 60px rgba(29, 29, 27, .12), 0 0 0 1px rgba(29, 29, 27, .06);
    overflow: hidden;
    max-width: 480px;
    min-width: 350px;
    margin-left: auto;
}

.page-servicio-individual .zw-mock-paper__header {
    display: flex;
    background: var(--svc-paper-2);
    border-bottom: 1px solid rgba(29, 29, 27, .06);
}

.page-servicio-individual .zw-mock-paper__tab {
    flex: 1;
    padding: 14px;
    text-align: center;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: rgba(29, 29, 27, .4);
    border-bottom: 2px solid transparent;
}

.page-servicio-individual .zw-mock-paper__tab.active {
    background: #fff;
    color: var(--svc-dark);
    border-bottom-color: var(--svc-y);
}

.page-servicio-individual .zw-mock-paper__body {
    padding: 24px 26px 26px
}

.page-servicio-individual .zw-mock-paper__row {
    display: flex;
    justify-content: space-between;
    padding: 11px 0;
    border-bottom: 1px dashed rgba(29, 29, 27, .08);
    font-size: .9375rem;
}

.page-servicio-individual .zw-mock-paper__label {
    color: rgba(29, 29, 27, .55);
    font-weight: 600
}

.page-servicio-individual .zw-mock-paper__value {
    color: var(--svc-dark);
    font-weight: 700
}

.page-servicio-individual .zw-mock-paper__value--check {
    color: #15803d
}

.page-servicio-individual .zw-mock-paper__total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 18px 0 4px;
    margin-top: 6px;
    border-top: 2px solid var(--svc-dark);
}

.page-servicio-individual .zw-mock-paper__total span {
    font-size: 13px;
    color: rgba(29, 29, 27, .5);
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase
}

.page-servicio-individual .zw-mock-paper__total strong {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--svc-dark);
    letter-spacing: -.01em
}

.page-servicio-individual .zw-mock-paper__cta {
    margin-top: 18px;
    text-align: center;
    background: var(--svc-y);
    color: var(--svc-dark);
    font-weight: 800;
    padding: 12px 18px;
    border-radius: 100px;
    font-size: 14px;
    letter-spacing: .02em;
}

.page-servicio-individual .zw-includes__stamp {
    position: absolute;
    top: -8px;
    left: -12px;
    width: 110px;
    height: 110px;
    border-radius: 50%;
    background: var(--svc-dark);
    color: var(--svc-y);
    display: grid;
    place-items: center;
    text-align: center;
    font-weight: 800;
    font-size: 13px;
    line-height: 1.2;
    letter-spacing: .05em;
    text-transform: uppercase;
    transform: rotate(-12deg);
    box-shadow: 0 14px 30px rgba(0, 0, 0, .18);
    border: 2px solid var(--svc-y);
}

/* =========================================================
   5. PROCESO  —  Rail animado por scroll
   ========================================================= */
.page-servicio-individual .zw-process__steps {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    position: relative;
    padding: 0;
    margin: 0;
}

.page-servicio-individual .zw-process__rail {
    position: absolute;
    top: 63px;
    left: 60px;
    right: 60px;
    height: 2px;
    background: rgba(255, 255, 255, .06);
    border-radius: 2px;
    overflow: hidden;
    z-index: 0;
}

.page-servicio-individual .zw-process__rail-fill {
    --p: 0;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: calc(var(--p, 0) * 100%);
    background: linear-gradient(90deg, var(--svc-y) 0%, var(--svc-y) 60%, rgba(252, 198, 28, .4) 100%);
    box-shadow: 0 0 16px rgba(252, 198, 28, .6);
    transition: width .25s ease-out;
    border-radius: 2px;
}

.page-servicio-individual .zw-process__rail-fill::after {
    content: "";
    position: absolute;
    right: -3px;
    top: 50%;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--svc-y);
    transform: translateY(-50%);
    box-shadow: 0 0 14px var(--svc-y), 0 0 4px var(--svc-y);
}

.page-servicio-individual .zw-process__step {
    background: var(--svc-card-bg);
    border: 1px solid var(--svc-card-bd);
    border-radius: var(--svc-r-lg);
    padding: 40px 36px 36px;
    position: relative;
    z-index: 1;
    transition: all var(--svc-t-base);
    display: flex;
    flex-direction: column;
}

.page-servicio-individual .zw-process__step:hover {
    border-color: var(--svc-card-bd-hover);
    background: var(--svc-card-bg-hover);
    transform: translateY(-4px);
}

.page-servicio-individual .zw-process__num {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, .06);
    color: var(--svc-paper-soft);
    border-radius: 50%;
    font-weight: 800;
    font-size: 15px;
    letter-spacing: -.02em;
    margin: 0 auto 22px;
    box-shadow: 0 0 0 6px var(--svc-dark);
    border: 1.5px solid var(--svc-card-bd);
    transition: all .5s cubic-bezier(.3, 1, .8, 1);
    opacity: 0.3;
}

.page-servicio-individual .zw-process__step.is-active .zw-process__num {
    opacity: 1;
}

.page-servicio-individual .zw-process__step.is-active .zw-process__num {
    background: var(--svc-y);
    color: var(--svc-dark);
    border-color: var(--svc-y);
    box-shadow: 0 0 0 6px var(--svc-dark), 0 14px 24px rgba(252, 198, 28, .35);
    transform: scale(1.06);
}

.page-servicio-individual .zw-process__body {
    text-align: center;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.page-servicio-individual .zw-process__ico {
    display: none;
}

.page-servicio-individual .zw-process__step.is-active .zw-process__ico {
    opacity: 1
}

.page-servicio-individual .zw-process__ico svg {
    width: 100%;
    height: 100%;
    stroke: var(--svc-y);
    stroke-width: 1.8;
    fill: none
}

.page-servicio-individual .zw-process__step h3 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 10px;
    color: var(--svc-paper);
    letter-spacing: -.005em;
}

.page-servicio-individual .zw-process__step p {
    font-size: 1.125rem;
    line-height: 1.55;
    color: var(--svc-paper-soft);
    margin-bottom: 15px;
}

.page-servicio-individual .zw-process__time {
    display: inline-block;
    margin-top: auto;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: var(--svc-y);
    padding: 5px 12px;
    border-radius: 100px;
    background: var(--svc-y-soft);
    border: 1px solid var(--svc-y-soft-2);
}

/* =========================================================
   6. PROYECTOS — Conceptos Zander
   ========================================================= */
.page-servicio-individual .zw-projects__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.page-servicio-individual .zw-project {
    background: #fff;
    border-radius: var(--svc-r-lg);
    box-shadow: 0 14px 40px rgba(29, 29, 27, .07);
    border: 1px solid var(--svc-card-light-bd);
    overflow: hidden;
    transition: transform var(--svc-t-base), box-shadow var(--svc-t-base);
}

.page-servicio-individual .zw-project:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 50px rgba(29, 29, 27, .12)
}

.page-servicio-individual .zw-project__mock {
    aspect-ratio: 4/3;
    overflow: hidden;
    position: relative;
    border-bottom: 1px solid rgba(29, 29, 27, .06);
}

.page-servicio-individual .zw-project__meta {
    padding: 24px 26px 26px
}

.page-servicio-individual .zw-project__tag {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: #9a7d00;
    background: var(--svc-y-soft);
    padding: 4px 10px;
    border-radius: 100px;
    margin-bottom: 12px;
}

.page-servicio-individual .zw-project__meta h3 {
    font-size: var(--fs-h4);
    font-weight: 800;
    margin-bottom: 8px;
    color: var(--svc-dark)
}

.page-servicio-individual .zw-project__meta p {
    font-size: var(--fs-body);
    color: rgba(29, 29, 27, .6);
    line-height: 1.5
}

.page-servicio-individual .zw-project-mock__bar {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 10px 14px;
    background: #f4f4ee;
    border-bottom: 1px solid rgba(29, 29, 27, .06);
}

.page-servicio-individual .zw-project-mock__bar span {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(29, 29, 27, .12);
}

.page-servicio-individual .zw-project-mock__bar span:first-child {
    background: #FCC61C
}

.page-servicio-individual .zw-project-mock__url {
    margin-left: 10px;
    flex: 1;
    height: 18px;
    border-radius: 5px;
    background: #fff;
    border: 1px solid rgba(29, 29, 27, .06);
    display: flex;
    align-items: center;
    padding: 0 10px;
    font-family: monospace;
    font-size: 10px;
    color: rgba(29, 29, 27, .45);
}

.page-servicio-individual .zw-project-mock--rest .zw-project-mock__hero {
    position: relative;
    padding: 18px 20px;
    background:
        radial-gradient(circle at 70% 50%, rgba(252, 198, 28, .18), transparent 60%),
        linear-gradient(180deg, #3a2a1f 0%, #1f150c 100%);
    color: #fff;
    height: calc(100% - 60px);
}

.page-servicio-individual .zw-project-mock__nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px
}

.page-servicio-individual .zw-project-mock__logo {
    font-family: 'Nunito';
    font-size: 13px;
    font-weight: 900;
    color: #FCC61C;
    letter-spacing: .01em;
    font-style: italic;
}

.page-servicio-individual .zw-project-mock__logo.dark {
    color: #1D1D1B;
    font-style: normal;
    letter-spacing: -.02em
}

.page-servicio-individual .zw-project-mock__nav-links {
    display: flex;
    gap: 8px
}

.page-servicio-individual .zw-project-mock__nav-links i {
    width: 24px;
    height: 3px;
    border-radius: 2px;
    background: rgba(255, 255, 255, .4)
}

.page-servicio-individual .zw-project-mock__h1 {
    font-family: 'Nunito';
    font-size: 22px;
    font-weight: 900;
    letter-spacing: -.02em;
    line-height: 1;
    margin-bottom: 14px;
    color: #fff;
}

.page-servicio-individual .zw-project-mock__cta {
    display: inline-block;
    background: #FCC61C;
    color: #1D1D1B;
    padding: 7px 14px;
    border-radius: 100px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .04em;
}

.page-servicio-individual .zw-project-mock__cta.yellow {
    background: #FCC61C;
    color: #1D1D1B
}

.page-servicio-individual .zw-project-mock__strip {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 60px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2px;
    background: #1D1D1B;
}

.page-servicio-individual .zw-project-mock__plate {
    background: radial-gradient(circle at 50% 50%, #ffc66c 0%, #cc7a00 50%, #6b3a00 100%);
    position: relative;
}

.page-servicio-individual .zw-project-mock__plate.alt {
    background: radial-gradient(circle at 50% 50%, #cc4500 0%, #6b1500 60%, #2a0500 100%)
}

.page-servicio-individual .zw-project-mock__plate::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid rgba(0, 0, 0, .18);
}

.page-servicio-individual .zw-project-mock--clinic .zw-project-mock__clinic {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    padding: 18px 20px;
    background: #fff;
    height: calc(100% - 38px);
}

.page-servicio-individual .zw-project-mock__clinic-side {
    display: flex;
    flex-direction: column
}

.page-servicio-individual .zw-project-mock__h2 {
    font-family: 'Nunito';
    font-size: 18px;
    font-weight: 900;
    color: #1D1D1B;
    letter-spacing: -.02em;
    line-height: 1.05;
    margin: 8px 0 14px;
}

.page-servicio-individual .zw-project-mock__clinic-cal {
    background: #f4f4ee;
    border-radius: 8px;
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 3px;
    border: 1px solid rgba(29, 29, 27, .06);
}

.page-servicio-individual .zw-project-mock__clinic-cal .cal-row {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px
}

.page-servicio-individual .zw-project-mock__clinic-cal .cal-row i {
    height: 11px;
    border-radius: 2px;
    background: #fff;
}

.page-servicio-individual .zw-project-mock__clinic-cal .cal-row i.on {
    background: #FCC61C
}

.page-servicio-individual .zw-project-mock--shop .zw-project-mock__shop {
    padding: 14px 16px;
    background: #fbfbfb;
    height: calc(100% - 38px);
}

.page-servicio-individual .zw-project-mock__shop-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px
}

.page-servicio-individual .zw-project-mock__cart {
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .04em;
    padding: 4px 10px;
    border-radius: 100px;
    background: #1D1D1B;
    color: #FCC61C;
}

.page-servicio-individual .zw-project-mock__shop-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px
}

.page-servicio-individual .zw-project-mock__shop-grid .prod {
    background: #fff;
    border-radius: 7px;
    padding: 8px;
    border: 1px solid rgba(29, 29, 27, .06);
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.page-servicio-individual .zw-project-mock__shop-grid .prod .img {
    height: 36px;
    border-radius: 5px;
    background: linear-gradient(135deg, #FCC61C, #cc9a00);
}

.page-servicio-individual .zw-project-mock__shop-grid .prod .img.alt {
    background: linear-gradient(135deg, #3a3a36, #1d1d1b)
}

.page-servicio-individual .zw-project-mock__shop-grid .prod .ln {
    height: 4px;
    border-radius: 2px;
    background: rgba(29, 29, 27, .12);
    width: 70%
}

.page-servicio-individual .zw-project-mock__shop-grid .prod .pr {
    font-family: 'Nunito';
    font-size: 11px;
    font-weight: 800;
    color: #1D1D1B;
    letter-spacing: -.01em
}

/* =========================================================
   7. EQUIPO — fix 9: oculto en todos los dispositivos
   ========================================================= */
.page-servicio-individual .zw-team {
    display: none !important
}

.page-servicio-individual .zw-team__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1080px;
    margin: 0 auto;
}

.page-servicio-individual .zw-team__card {
    text-align: center;
    padding: 40px 32px;
    align-items: center
}

.page-servicio-individual .zw-team__avatar {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--svc-y) 0%, #e2a900 100%);
    color: var(--svc-dark);
    display: grid;
    place-items: center;
    font-family: 'Nunito';
    font-size: 32px;
    font-weight: 900;
    letter-spacing: -.02em;
    margin-bottom: 22px;
    box-shadow: 0 14px 32px rgba(252, 198, 28, .25), 0 0 0 2px rgba(252, 198, 28, .15);
}

.page-servicio-individual .zw-team__avatar--alt {
    background: linear-gradient(135deg, #fbfbfb 0%, #cfcfc7 100%);
    color: var(--svc-dark);
    box-shadow: 0 14px 32px rgba(0, 0, 0, .25), 0 0 0 2px rgba(255, 255, 255, .10);
}

.page-servicio-individual .zw-team__card h3 {
    font-size: var(--fs-h4);
    font-weight: 800;
    letter-spacing: -.01em;
    margin-bottom: 4px;
    color: var(--svc-paper);
}

.page-servicio-individual .zw-team__role {
    display: block;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .04em;
    color: var(--svc-y);
    text-transform: uppercase;
    margin-bottom: 14px;
}

.page-servicio-individual .zw-team__card p {
    font-size: var(--fs-body);
    color: var(--svc-paper-soft);
    line-height: 1.5;
    margin-bottom: 20px
}

.page-servicio-individual .zw-team__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--svc-paper-mid);
    padding: 9px 16px;
    border-radius: 100px;
    border: 1px solid var(--svc-card-bd);
    transition: all var(--svc-t-fast);
    text-decoration: none;
}

.page-servicio-individual .zw-team__link svg {
    width: 14px;
    height: 14px;
    stroke: currentColor;
    stroke-width: 1.8;
    fill: none
}

.page-servicio-individual .zw-team__link:hover {
    background: var(--svc-y);
    color: var(--svc-dark);
    border-color: var(--svc-y)
}

/* =========================================================
   8. PRECIOS
   ========================================================= */
.page-servicio-individual .zw-pricing .zw-container {
    max-width: 1672px;
}

.page-servicio-individual .zw-pricing__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: stretch;
}

.page-servicio-individual .zw-pricing__grid--3col {
    grid-template-columns: repeat(3, 1fr);
}

.page-servicio-individual .zw-pricing__note {
    text-align: center;
    margin-top: 24px;
    font-size: 14px;
    color: var(--svc-dark, #1d1d1b);
    opacity: .7;
}

.page-servicio-individual .zw-price {
    background: var(--svc-card-bg);
    border: 1px solid var(--svc-card-bd);
    border-radius: var(--svc-r-xl);
    padding: 36px 30px;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: all var(--svc-t-base);
}

.page-servicio-individual .zw-price:hover {
    border-color: var(--svc-card-bd-hover);
    transform: translateY(-4px);
    box-shadow: 0 20px 56px rgba(0, 0, 0, .5)
}

.page-servicio-individual .zw-price__name {
    font-size: var(--fs-h4);
    font-weight: 700;
    letter-spacing: -.005em;
    margin-bottom: 8px;
    color: var(--svc-paper)
}

.page-servicio-individual .zw-price__amount {
    font-size: var(--fs-h2);
    font-weight: 800;
    line-height: 1;
    color: var(--svc-paper);
    letter-spacing: -.02em;
    margin-bottom: 6px;
}

/* Importe descriptivo (servicios sin precio público) */
.page-servicio-individual .zw-price__amount--quote {
    font-size: var(--fs-h4);
    color: var(--svc-yellow, #FCC61C);
}

.page-servicio-individual .zw-price__iva {
    font-size: var(--fs-small);
    color: var(--svc-paper-soft);
    margin-bottom: 18px;
    display: block
}

.page-servicio-individual .zw-price__desc {
    font-size: var(--fs-body);
    line-height: 1.55;
    color: var(--svc-paper-soft);
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--svc-card-bd);
}

.page-servicio-individual .zw-price__features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 28px;
    padding: 0;
    flex: 1;
}

.page-servicio-individual .zw-price__features li {
    display: flex;
    align-items: flex-start;
    gap: 11px;
    font-size: var(--fs-body);
    line-height: 1.4;
    color: var(--svc-paper);
    font-weight: 600;
}

.page-servicio-individual .zw-price__features svg {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    margin-top: 1px
}

.page-servicio-individual .zw-price__cta {
    display: block;
    text-align: center;
    padding: 14px 22px;
    border-radius: 100px;
    background: transparent;
    border: 1.5px solid var(--svc-card-bd-hover);
    color: var(--svc-paper);
    font-size: 14px;
    font-weight: 800;
    letter-spacing: .02em;
    transition: all var(--svc-t-fast);
    text-decoration: none;
}

.page-servicio-individual .zw-price__cta:hover {
    background: var(--svc-y);
    color: var(--svc-dark);
    border-color: var(--svc-y)
}

.page-servicio-individual .zw-price__cta--dark {
    background: var(--svc-dark);
    color: var(--svc-paper);
    border-color: var(--svc-dark)
}

.page-servicio-individual .zw-price__cta--dark:hover {
    background: var(--svc-paper);
    color: var(--svc-dark);
    border-color: var(--svc-paper)
}

.page-servicio-individual .zw-price--popular {
    background: var(--svc-y);
    border-color: var(--svc-y);
    color: var(--svc-dark);
    transform: scale(1.02);
    box-shadow: 0 20px 56px rgba(252, 198, 28, .2);
}

.page-servicio-individual .zw-price--popular:hover {
    transform: scale(1.02) translateY(-4px);
    box-shadow: 0 26px 70px rgba(252, 198, 28, .3)
}

.page-servicio-individual .zw-price--popular .zw-price__name,
.page-servicio-individual .zw-price--popular .zw-price__amount {
    color: #1D1D1B !important;
}

.page-servicio-individual .zw-price--popular .zw-price__iva,
.page-servicio-individual .zw-price--popular .zw-price__desc {
    color: #1D1D1B !important;
}

.page-servicio-individual .zw-price--popular .zw-price__features li {
    color: var(--svc-dark)
}

.page-servicio-individual .zw-price--popular .zw-price__desc {
    border-bottom-color: rgba(29, 29, 27, .15)
}

.page-servicio-individual .zw-price__badge {
    position: absolute;
    top: -12px;
    right: 24px;
    background: #fff;
    color: var(--svc-dark);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 100px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .35), 0 0 0 1.5px var(--svc-dark);
}

.page-servicio-individual .zw-pricing__note {
    text-align: center;
    margin-top: 36px;
    color: var(--svc-paper-soft);
    font-size: var(--fs-body);
}

.page-servicio-individual .zw-pricing__note a {
    color: var(--svc-y);
    font-weight: 700;
    border-bottom: 1px solid currentColor
}

/* =========================================================
   9. FAQ — scoped fuerte para no chocar con precios.css
   ========================================================= */
.page-servicio-individual .zw-faq {
    padding: 100px 0;
    background: var(--svc-paper);
}

/* fix 13: en móvil, padding inferior del FAQ máximo 40px */
@media (max-width: 768px) {
    .page-servicio-individual .zw-faq {
        padding-bottom: 40px
    }
}

.page-servicio-individual .zw-faq__inner {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 80px;
    align-items: flex-start;
}

.page-servicio-individual .zw-faq__intro {
    position: sticky;
    top: 96px
}

.page-servicio-individual .zw-faq__intro p {
    font-size: var(--fs-body);
    color: rgba(29, 29, 27, .6);
    line-height: 1.65;
    margin: 14px 0 28px;
}

.page-servicio-individual .zw-faq__list {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.page-servicio-individual .zw-faq__item {
    background: #fff;
    border: 1px solid rgba(29, 29, 27, .08);
    border-radius: var(--svc-r-md);
    overflow: hidden;
    transition: border-color var(--svc-t-fast), box-shadow var(--svc-t-fast);
}

.page-servicio-individual .zw-faq__item:hover {
    border-color: rgba(29, 29, 27, .18)
}

.page-servicio-individual .zw-faq__item[open] {
    border-color: var(--svc-y-soft-2);
    box-shadow: 0 14px 32px rgba(29, 29, 27, .06);
}

.page-servicio-individual .zw-faq__item summary {
    list-style: none;
    cursor: pointer;
    padding: 22px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    font-weight: 700;
    font-size: var(--fs-body);
    color: var(--svc-dark);
    letter-spacing: -.005em;
}

.page-servicio-individual .zw-faq__item summary::-webkit-details-marker {
    display: none
}

.page-servicio-individual .zw-faq__arrow {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border-radius: 50%;
    border: 1px solid rgba(29, 29, 27, .12);
    display: grid;
    place-items: center;
    transition: all var(--svc-t-fast);
}

.page-servicio-individual .zw-faq__arrow::before {
    content: "";
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--svc-dark);
    border-bottom: 2px solid var(--svc-dark);
    transform: rotate(45deg) translate(-2px, -2px);
}

.page-servicio-individual .zw-faq__item[open] .zw-faq__arrow {
    background: var(--svc-y);
    border-color: var(--svc-y);
    transform: rotate(180deg)
}

.page-servicio-individual .zw-faq__item p {
    padding: 0 24px 22px;
    font-size: var(--fs-body);
    line-height: 1.6;
    color: rgba(29, 29, 27, .7);
}

/* =========================================================
   10. FORMULARIO  —  CTA final
   ========================================================= */
.page-servicio-individual .zw-form {
    padding: 120px 0 140px;
    position: relative;
    overflow: hidden
}

.page-servicio-individual .zw-form__halo {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 80% 60% at 30% 40%, rgba(252, 198, 28, .10), transparent 60%),
        radial-gradient(ellipse 60% 50% at 75% 80%, rgba(252, 198, 28, .06), transparent 65%);
}

.page-servicio-individual .zw-section__title--xl {
    font-size: var(--fs-h2) !important;
    line-height: 1 !important;
    letter-spacing: -.02em !important;
}

.page-servicio-individual .zw-form__inner {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 80px;
    align-items: flex-start;
    position: relative;
    z-index: 1;
}

.page-servicio-individual .zw-form__bullets {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin: 32px 0 36px;
    padding: 0;
}

.page-servicio-individual .zw-form__bullets li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-size: var(--fs-body);
    line-height: 1.45;
    color: var(--svc-paper);
    font-weight: 600;
}

.page-servicio-individual .zw-form__bullets svg {
    flex-shrink: 0;
    width: 22px;
    height: 22px
}

.page-servicio-individual .zw-form__direct {
    padding-top: 28px;
    border-top: 1px solid rgba(255, 255, 255, .08);
}

.page-servicio-individual .zw-form__direct>span {
    display: block;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--svc-paper-soft);
    margin-bottom: 14px;
}

.page-servicio-individual .zw-form__direct-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px
}

.page-servicio-individual .zw-direct-link {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 11px 18px;
    background: var(--svc-card-bg);
    border: 1px solid var(--svc-card-bd);
    border-radius: 100px;
    font-size: 14px;
    font-weight: 700;
    color: var(--svc-paper);
    transition: all var(--svc-t-fast);
    text-decoration: none;
}

.page-servicio-individual .zw-direct-link svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round
}

.page-servicio-individual .zw-direct-link:hover {
    background: var(--svc-y);
    color: var(--svc-dark);
    border-color: var(--svc-y)
}

.page-servicio-individual .zw-direct-link--whatsapp {
    background: #25D366;
    border-color: #25D366;
    color: #fff
}

.page-servicio-individual .zw-direct-link--whatsapp:hover {
    background: #1fb558;
    border-color: #1fb558;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(37, 211, 102, .32)
}

.page-servicio-individual .zw-direct-link--whatsapp svg {
    fill: #fff;
    stroke: none
}

/* form embed real (iframe a tools.zanderwebs.com) */
.page-servicio-individual .zw-form__embed {
    position: relative;
    background: #fff;
    border-radius: var(--svc-r-xl);
    padding: 36px;
    padding-top: 48px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .55), 0 0 0 1px rgba(252, 198, 28, .08);
    overflow: visible;
}

.page-servicio-individual .zw-form__embed-tag {
    position: absolute;
    top: -14px;
    left: 32px;
    background: var(--svc-y);
    color: var(--svc-dark);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 7px 14px;
    border-radius: 100px;
    box-shadow: 0 6px 16px rgba(252, 198, 28, .4);
    z-index: 999;
}

.page-servicio-individual .zw-form__iframe {
    width: 100%;
    height: 770px;
    border: none;
    border-radius: 14px;
    display: block;
    overflow: hidden;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:960px) {
    .page-servicio-individual .zw-hero__grid {
        grid-template-columns: 1fr;
        gap: 48px
    }

    .page-servicio-individual .zw-hero__visual {
        height: 380px;
        max-width: 520px;
        margin: 0 auto;
        width: 100%
    }

    .page-servicio-individual .zw-bento {
        grid-template-columns: repeat(6, 1fr);
        grid-auto-rows: auto
    }

    .page-servicio-individual .zw-bento .b-hero {
        grid-column: span 6;
        grid-row: auto;
        min-height: 280px
    }

    .page-servicio-individual .zw-bento .b-medium {
        grid-column: span 6;
        grid-row: auto
    }

    .page-servicio-individual .zw-bento .sc:not(.b-hero):not(.b-medium) {
        grid-column: span 3
    }

    .page-servicio-individual .zw-includes__grid {
        grid-template-columns: 1fr;
        gap: 48px
    }

    .page-servicio-individual .zw-includes__visual {
        max-width: 100%;
        margin: 0 auto
    }

    .page-servicio-individual .zw-mock-paper {
        margin: 0 auto;
        max-width: 480px;
        width: 100%
    }

    .page-servicio-individual .zw-process__steps {
        grid-template-columns: 1fr 1fr;
        gap: 20px
    }

    .page-servicio-individual .zw-process__rail {
        display: none
    }

    .page-servicio-individual .zw-projects__grid {
        grid-template-columns: 1fr 1fr;
        gap: 20px
    }

    .page-servicio-individual .zw-projects__grid .zw-project:nth-child(3) {
        grid-column: span 2;
        max-width: 50%;
        margin: 0 auto
    }

    .page-servicio-individual .zw-team__grid {
        grid-template-columns: 1fr 1fr;
        gap: 20px
    }

    .page-servicio-individual .zw-team__grid .zw-team__card:nth-child(3) {
        grid-column: span 2;
        max-width: 50%;
        margin: 0 auto
    }

    .page-servicio-individual .zw-pricing__grid {
        grid-template-columns: 1fr 1fr;
        gap: 20px
    }

    .page-servicio-individual .zw-faq__inner {
        grid-template-columns: 1fr;
        gap: 48px
    }

    .page-servicio-individual .zw-faq__intro {
        position: static
    }

    .page-servicio-individual .zw-form__inner {
        grid-template-columns: 1fr;
        gap: 48px
    }
}

@media (max-width:640px) {
    .page-servicio-individual .zw-hero {
        padding: 100px 0 72px
    }

    /* hero title ya fluido via fs-h1 */
    .page-servicio-individual .zw-hero__cta {
        flex-direction: column;
        align-items: stretch
    }

    .page-servicio-individual .zw-hero__trust {
        flex-wrap: wrap;
        gap: 16px
    }

    .page-servicio-individual .zw-hero__trust-divider {
        display: none
    }

    /* Hero: ocultar ilustración solo en móvil */
    .page-servicio-individual .zw-hero__visual {
        display: none
    }

    .page-servicio-individual .zw-hero-mock--main {
        width: 100%
    }

    .page-servicio-individual .zw-hero-mock--phone {
        width: 120px;
        height: 240px;
        left: 8px
    }

    /* promise quote ya fluido via fs-h2 */

    .page-servicio-individual .zw-bento {
        grid-template-columns: 1fr;
        gap: 14px
    }

    .page-servicio-individual .zw-bento .b-hero,
    .page-servicio-individual .zw-bento .b-medium,
    .page-servicio-individual .zw-bento .sc:not(.b-hero):not(.b-medium) {
        grid-column: 1/-1;
        min-height: auto
    }

    .page-servicio-individual .zw-bento .b-hero .preview {
        display: none
    }

    .page-servicio-individual .zw-includes__stamp {
        width: 88px;
        height: 88px;
        font-size: 11px;
        top: -10px;
        left: auto;
        right: 0
    }

    .page-servicio-individual .zw-mock-paper {
        width: 100%;
        max-width: none;
        margin: 0
    }

    .page-servicio-individual .zw-process__steps {
        grid-template-columns: 1fr;
        gap: 14px
    }

    .page-servicio-individual .zw-projects__grid {
        grid-template-columns: 1fr;
        gap: 18px
    }

    .page-servicio-individual .zw-projects__grid .zw-project:nth-child(3) {
        grid-column: auto;
        max-width: none
    }

    .page-servicio-individual .zw-team__grid {
        grid-template-columns: 1fr;
        gap: 14px
    }

    .page-servicio-individual .zw-team__grid .zw-team__card:nth-child(3) {
        grid-column: auto;
        max-width: none
    }

    .page-servicio-individual .zw-pricing__grid {
        grid-template-columns: 1fr;
        gap: 16px
    }

    .page-servicio-individual .zw-price--popular {
        transform: none
    }

    .page-servicio-individual .zw-price--popular:hover {
        transform: translateY(-4px)
    }

    .page-servicio-individual .zw-form__embed {
        padding: 24px
    }

    .page-servicio-individual .zw-form__iframe {
        height: 860px
    }
}

/* ============================================================
   Conceptos · Diseño Gráfico (mocks brand / papelería / evento)
   ============================================================ */
.page-servicio-individual .zw-project-mock--brand,
.page-servicio-individual .zw-project-mock--stationery,
.page-servicio-individual .zw-project-mock--event {
    height: 100%;
}

/* Marca / manual */
.page-servicio-individual .zw-project-mock__brand {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    padding: 20px;
    background:
        radial-gradient(circle at 30% 30%, rgba(252, 198, 28, .14), transparent 60%),
        linear-gradient(160deg, #fbfbf7 0%, #f0ede5 100%);
}
.page-servicio-individual .zw-project-mock__brand-mark {
    width: 70px;
    height: 70px;
    border-radius: 16px;
    background: #1D1D1B;
    color: #FCC61C;
    display: grid;
    place-items: center;
    font-family: 'Nunito';
    font-size: 38px;
    font-weight: 900;
    box-shadow: 0 14px 30px -10px rgba(0, 0, 0, .35);
}
.page-servicio-individual .zw-project-mock__brand-pal {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.page-servicio-individual .zw-project-mock__brand-pal i {
    width: 30px;
    height: 16px;
    border-radius: 5px;
    box-shadow: 0 3px 8px rgba(0, 0, 0, .12);
}
.page-servicio-individual .zw-project-mock__brand-type {
    font-family: 'Nunito';
    font-size: 44px;
    font-weight: 900;
    color: #1D1D1B;
    letter-spacing: -.03em;
}

/* Papelería */
.page-servicio-individual .zw-project-mock__stat {
    position: relative;
    height: calc(100% - 39px);
    padding: 20px;
    background: linear-gradient(160deg, #f4f2ec 0%, #e6e2d8 100%);
}
.page-servicio-individual .zw-project-mock__card-y {
    position: absolute;
    left: 26px;
    top: 30px;
    width: 130px;
    height: 78px;
    border-radius: 9px;
    background: linear-gradient(135deg, #FCC61C, #e2a900);
    transform: rotate(-5deg);
    box-shadow: 0 14px 28px -8px rgba(0, 0, 0, .3);
    display: grid;
    place-items: center;
    color: #1D1D1B;
    font-family: 'Nunito';
    font-size: 26px;
    font-weight: 900;
}
.page-servicio-individual .zw-project-mock__card-d {
    position: absolute;
    right: 30px;
    top: 22px;
    width: 120px;
    height: 72px;
    border-radius: 9px;
    background: #1D1D1B;
    transform: rotate(6deg);
    box-shadow: 0 14px 28px -8px rgba(0, 0, 0, .35);
}
.page-servicio-individual .zw-project-mock__env {
    position: absolute;
    left: 50%;
    bottom: 20px;
    transform: translateX(-50%);
    width: 150px;
    height: 56px;
    border-radius: 8px;
    background: #fbfbfb;
    border: 1px solid rgba(29, 29, 27, .1);
    box-shadow: 0 12px 24px -10px rgba(0, 0, 0, .25);
}
.page-servicio-individual .zw-project-mock__env::after {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 28px;
    border-bottom: 1px solid rgba(29, 29, 27, .1);
    background: linear-gradient(180deg, #f4f2ec, #fbfbfb);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
}

/* Evento */
.page-servicio-individual .zw-project-mock__event {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 18px;
    background: linear-gradient(160deg, #2a2620 0%, #16140f 100%);
}
.page-servicio-individual .zw-project-mock__poster {
    position: relative;
    width: 96px;
    height: 132px;
    border-radius: 8px;
    overflow: hidden;
    background: linear-gradient(150deg, #1f1d16, #131210);
    border: 1px solid rgba(252, 198, 28, .25);
    box-shadow: 0 18px 36px -10px rgba(0, 0, 0, .55);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 12px;
}
.page-servicio-individual .zw-project-mock__poster::before {
    content: "";
    position: absolute;
    right: -20px;
    top: -16px;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(252, 198, 28, .9), rgba(252, 198, 28, .1) 70%);
}
.page-servicio-individual .zw-project-mock__poster-big {
    position: relative;
    font-family: 'Nunito';
    font-size: 26px;
    font-weight: 900;
    color: #FCC61C;
    letter-spacing: -.03em;
    line-height: 1;
}
.page-servicio-individual .zw-project-mock__poster-sm {
    position: relative;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .2em;
    color: rgba(255, 255, 255, .6);
    margin-top: 4px;
}
.page-servicio-individual .zw-project-mock__tickets {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.page-servicio-individual .zw-project-mock__tickets i {
    width: 64px;
    height: 26px;
    border-radius: 6px;
    background: rgba(255, 255, 255, .08);
    border: 1px dashed rgba(252, 198, 28, .4);
    position: relative;
}
.page-servicio-individual .zw-project-mock__tickets i::after {
    content: "";
    position: absolute;
    left: 42px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #16140f;
    box-shadow: 0 -10px 0 #16140f, 0 10px 0 #16140f;
}

/* ============================================================
   Conceptos · Redes Sociales (mocks reel / shoot / plan)
   ============================================================ */
.page-servicio-individual .zw-project-mock--reel,
.page-servicio-individual .zw-project-mock--shoot,
.page-servicio-individual .zw-project-mock--plan {
    height: 100%;
}

/* Reel */
.page-servicio-individual .zw-project-mock__reel-wrap {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(160deg, #2a2026 0%, #16121a 100%);
}
.page-servicio-individual .zw-project-mock__reel-screen {
    position: relative;
    width: 110px;
    height: 158px;
    border-radius: 14px;
    background: radial-gradient(120% 80% at 50% 25%, rgba(252, 198, 28, .35), rgba(241, 0, 105, .28) 60%, #1a141f 100%);
    border: 1px solid rgba(255, 255, 255, .14);
    box-shadow: 0 18px 36px -10px rgba(0, 0, 0, .5);
}
.page-servicio-individual .zw-project-mock__reel-play {
    position: absolute;
    left: 50%;
    top: 45%;
    transform: translate(-50%, -50%);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .18);
    border: 1px solid rgba(255, 255, 255, .3);
}
.page-servicio-individual .zw-project-mock__reel-play::after {
    content: "";
    position: absolute;
    left: 54%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-style: solid;
    border-width: 7px 0 7px 12px;
    border-color: transparent transparent transparent #fbfbfb;
}
.page-servicio-individual .zw-project-mock__reel-side {
    position: absolute;
    right: 8px;
    bottom: 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.page-servicio-individual .zw-project-mock__reel-side i {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .16);
}
.page-servicio-individual .zw-project-mock__reel-side i:first-child {
    background: rgba(241, 0, 105, .7);
}

/* Shoot / fotografía */
.page-servicio-individual .zw-project-mock__shoot {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    background: linear-gradient(160deg, #f4f2ec 0%, #e6e2d8 100%);
}
.page-servicio-individual .zw-project-mock__cam {
    position: relative;
    width: 80px;
    height: 56px;
    border-radius: 10px;
    background: #1D1D1B;
    box-shadow: 0 12px 24px -8px rgba(0, 0, 0, .35);
}
.page-servicio-individual .zw-project-mock__cam::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 35%, #FCC61C, #2a2620 70%);
    border: 2px solid #3a352a;
}
.page-servicio-individual .zw-project-mock__cam::after {
    content: "";
    position: absolute;
    right: 10px;
    top: -5px;
    width: 16px;
    height: 8px;
    border-radius: 3px 3px 0 0;
    background: #1D1D1B;
}
.page-servicio-individual .zw-project-mock__shots {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}
.page-servicio-individual .zw-project-mock__shots i {
    width: 34px;
    height: 34px;
    border-radius: 6px;
    background: #fbfbfb;
    border: 1px solid rgba(29, 29, 27, .1);
    box-shadow: 0 6px 14px -6px rgba(0, 0, 0, .25);
}
.page-servicio-individual .zw-project-mock__shots i.alt {
    background: linear-gradient(135deg, #FCC61C, #e2a900);
}

/* Plan de contenido */
.page-servicio-individual .zw-project-mock--plan .zw-project-mock__plan {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 22px;
    background: linear-gradient(160deg, #fbfbf7 0%, #efece4 100%);
}
.page-servicio-individual .zw-project-mock__plan-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 7px;
    width: 100%;
    max-width: 230px;
}
.page-servicio-individual .zw-project-mock__plan-grid i {
    aspect-ratio: 1;
    border-radius: 5px;
    background: rgba(29, 29, 27, .07);
}
.page-servicio-individual .zw-project-mock__plan-grid i.on {
    background: #FCC61C;
}
.page-servicio-individual .zw-project-mock__plan-grid i.alt {
    background: #f00069;
}

/* ============================================================
   Conceptos · Ilustración (mocks illust / logogrid / pattern)
   ============================================================ */
.page-servicio-individual .zw-project-mock--illust,
.page-servicio-individual .zw-project-mock--logogrid,
.page-servicio-individual .zw-project-mock--pattern {
    height: 100%;
}

/* Mascota / personaje ilustrado */
.page-servicio-individual .zw-project-mock__illust {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at 50% 40%, rgba(252, 198, 28, .16), transparent 60%),
        linear-gradient(160deg, #fbfbf7 0%, #efece4 100%);
}
.page-servicio-individual .zw-project-mock__face {
    position: relative;
    width: 84px;
    height: 84px;
    border-radius: 42% 58% 54% 46% / 52% 48% 52% 48%;
    background: linear-gradient(140deg, #FCC61C, #e2a900);
    box-shadow: 0 14px 30px -10px rgba(252, 198, 28, .55);
}
.page-servicio-individual .zw-project-mock__eye {
    position: absolute;
    top: 30px;
    width: 11px;
    height: 13px;
    border-radius: 50%;
    background: #1D1D1B;
}
.page-servicio-individual .zw-project-mock__eye.l { left: 22px; }
.page-servicio-individual .zw-project-mock__eye.r { right: 22px; }
.page-servicio-individual .zw-project-mock__smile {
    position: absolute;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    width: 34px;
    height: 16px;
    border-bottom: 4px solid #1D1D1B;
    border-radius: 0 0 34px 34px;
}

/* Construcción del logo */
.page-servicio-individual .zw-project-mock__logogrid {
    position: relative;
    height: calc(100% - 39px);
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at 50% 40%, rgba(252, 198, 28, .12), transparent 60%),
        linear-gradient(160deg, #232019 0%, #16130f 100%);
}
.page-servicio-individual .zw-project-mock__guide {
    position: absolute;
    border: 1px dashed rgba(252, 198, 28, .3);
    border-radius: 50%;
}
.page-servicio-individual .zw-project-mock__guide.g1 { width: 100px; height: 100px; }
.page-servicio-individual .zw-project-mock__guide.g2 { width: 64px; height: 64px; }
.page-servicio-individual .zw-project-mock__logo-mark {
    position: relative;
    width: 64px;
    height: 64px;
    border-radius: 36% 64% 58% 42% / 50% 42% 58% 50%;
    background: linear-gradient(135deg, #FCC61C, #e2a900);
    box-shadow: 0 12px 26px -8px rgba(252, 198, 28, .5);
}

/* Patrón / aplicaciones */
.page-servicio-individual .zw-project-mock__pattern {
    height: calc(100% - 39px);
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    align-content: center;
    gap: 10px;
    padding: 22px;
    background: linear-gradient(160deg, #fbfbf7 0%, #efece4 100%);
}
.page-servicio-individual .zw-project-mock__pattern i {
    aspect-ratio: 1;
    border-radius: 50%;
    background: rgba(29, 29, 27, .12);
}
.page-servicio-individual .zw-project-mock__pattern i.alt {
    background: #FCC61C;
    border-radius: 30% 70% 62% 38% / 42% 38% 62% 58%;
}
.page-servicio-individual .zw-project-mock__pattern i.p3 {
    background: #f00069;
    border-radius: 4px;
}