/* ============================================================
   ZIPWEB — servicios.css
   Estilos específicos de la página servicios.html
   ============================================================ */

/* PAGE HERO */
.page-hero {
    padding: 8.5rem 6% 4rem;
    border-bottom: 1px solid var(--border);
}

.page-hero h1 {
    font-size: clamp(2.1rem, 5vw, 3.6rem);
    font-weight: 900;
    letter-spacing: -1.5px;
    color: var(--white);
}

.page-hero h1 em {
    font-style: normal;
    background: linear-gradient(90deg, var(--orange), var(--orange2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.page-hero p {
    color: var(--muted);
    font-size: 1rem;
    max-width: 580px;
    margin-top: 0.9rem;
    line-height: 1.8;
}

.trow {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
    margin-top: 1.8rem;
}

.tc2 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 0.45rem 1rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text);
}

/* SERVICES BLOCKS */
.services-wrapper {
    padding: 4.5rem 6%;
}

.service-box {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 2.8rem;
    margin-bottom: 1.8rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: start;
    transition: border-color 0.3s;
}

.service-box:hover {
    border-color: rgba(255, 92, 0, .35);
}

.service-box.rv {
    direction: rtl;
}

.service-box.rv>* {
    direction: ltr;
}

@media(max-width:768px) {

    .service-box,
    .service-box.rv {
        grid-template-columns: 1fr;
        direction: ltr;
    }
}

.bi {
    font-size: 2.6rem;
    margin-bottom: 1rem;
    display: block;
}

.stag {
    font-size: 0.73rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--orange);
    margin-bottom: 0.7rem;
    display: block;
}

.service-box h2 {
    font-size: 1.6rem;
    font-weight: 900;
    color: var(--white);
    margin-bottom: 0.7rem;
}

.sd {
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.8;
    margin-bottom: 1.4rem;
}

.pills {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-bottom: 1.4rem;
}

.p2 {
    background: var(--dark);
    border: 1px solid var(--border);
    border-radius: 100px;
    padding: 0.2rem 0.65rem;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--muted);
}

.p2.wp {
    background: rgba(33, 117, 155, .1);
    border-color: rgba(33, 117, 155, .25);
    color: #5bc0de;
}

.p2.fig {
    background: rgba(162, 89, 255, .1);
    border-color: rgba(162, 89, 255, .25);
    color: #a259ff;
}

.p2.or {
    background: var(--orange-soft);
    border-color: rgba(255, 92, 0, .25);
    color: var(--orange);
}

.fl {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.fl li {
    font-size: 0.85rem;
    color: var(--muted);
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
}

.fl li::before {
    content: '→';
    color: var(--orange);
    font-weight: 700;
    flex-shrink: 0;
}

/* SERVICE RIGHT BOX */
.srb {
    background: var(--dark);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 1.8rem;
}

.srb h4 {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--muted);
    margin-bottom: 1.2rem;
}

.dl {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.9rem;
}

.di {
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.dt strong {
    color: var(--white);
    font-size: 0.85rem;
    display: block;
}

.dt span {
    color: var(--muted);
    font-size: 0.75rem;
}

.pb {
    margin-top: 1.6rem;
    padding-top: 1.4rem;
    border-top: 1px solid var(--border);
}

.pb .fr {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--muted);
}

.pb .am {
    font-size: 2.1rem;
    font-weight: 900;
    color: var(--orange);
    line-height: 1.1;
}

.pb .tm {
    font-size: 0.74rem;
    color: var(--muted);
    margin-top: 0.2rem;
}

/* MAINTENANCE MINI GRID */
.mant-g {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.8rem;
    margin-top: 0.2rem;
}

@media(max-width:420px) {
    .mant-g {
        grid-template-columns: 1fr;
    }
}

.mg {
    background: var(--black);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1rem;
}

.mg.pro {
    border-color: rgba(255, 92, 0, .35);
    background: var(--orange-soft);
}

.mg h5 {
    font-size: 0.83rem;
    font-weight: 800;
    color: var(--white);
    margin-bottom: 0.2rem;
}

.mg .mp {
    font-size: 1.1rem;
    font-weight: 900;
    color: var(--orange);
}

.mg .ms {
    font-size: 0.7rem;
    color: var(--muted);
    margin-bottom: 0.5rem;
}

.mg ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.mg ul li {
    font-size: 0.73rem;
    color: var(--muted);
    display: flex;
    gap: 0.4rem;
}

.mg ul li::before {
    content: '✓';
    color: var(--success);
    font-weight: 700;
    flex-shrink: 0;
}

/* CTA BOTTOM BANNER */
.cta-banner {
    margin: 2rem 6% 4rem;
    background: linear-gradient(135deg, rgba(255, 92, 0, .13), rgba(255, 138, 0, .06));
    border: 1px solid rgba(255, 92, 0, .2);
    border-radius: 20px;
    padding: 3rem;
    text-align: center;
}

.cta-banner h2 {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
}

.cta-banner p {
    color: var(--muted);
    margin-bottom: 2rem;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   RESPONSIVE - SERVICIOS.CSS
   Sistema completo para la página de servicios
   ============================================================ */

/* ─── TABLET (≤1024px) ───────────────────────────────────── */
@media (max-width: 1024px) {
    .service-box {
        gap: 2.5rem;
        padding: 2.5rem;
    }

    .mant-g {
        grid-template-columns: 1fr 1fr;
    }
}

/* ─── MOBILE LARGE (≤768px) ──────────────────────────────── */
@media (max-width: 768px) {
    /* Page hero */
    .page-hero {
        padding: 7rem 5% 3rem;
    }

    .page-hero h1 {
        font-size: clamp(1.8rem, 6vw, 2.8rem);
    }

    .page-hero p {
        font-size: 0.92rem;
        max-width: 100%;
    }

    .trow {
        gap: 0.6rem;
    }

    .tc2 {
        font-size: 0.75rem;
        padding: 0.4rem 0.8rem;
    }

    /* Service boxes */
    .services-wrapper {
        padding: 3.5rem 5%;
    }

    .service-box,
    .service-box.rv {
        grid-template-columns: 1fr;
        direction: ltr;
        gap: 2rem;
        padding: 2rem 1.5rem;
    }

    .service-box.rv>* {
        direction: ltr;
    }

    .bi {
        font-size: 2.2rem;
    }

    .service-box h2 {
        font-size: 1.4rem;
    }

    .sd {
        font-size: 0.85rem;
    }

    .pills {
        gap: 0.3rem;
    }

    .p2 {
        font-size: 0.65rem;
        padding: 0.18rem 0.55rem;
    }

    .fl li {
        font-size: 0.8rem;
    }

    /* Service right box */
    .srb {
        padding: 1.6rem;
    }

    .srb h4 {
        font-size: 0.7rem;
    }

    .dl {
        gap: 0.6rem;
    }

    .di {
        font-size: 1rem;
    }

    .dt strong {
        font-size: 0.8rem;
    }

    .dt span {
        font-size: 0.7rem;
    }

    .pb .am {
        font-size: 1.8rem;
    }

    .btn-block-p,
    .btn-block-s {
        padding: 0.75rem;
        font-size: 0.85rem;
    }

    /* Maintenance grid */
    .mant-g {
        grid-template-columns: 1fr;
        gap: 0.7rem;
    }

    .mg {
        padding: 1rem;
    }

    .mg h5 {
        font-size: 0.8rem;
    }

    .mg .mp {
        font-size: 1rem;
    }

    .mg .ms {
        font-size: 0.68rem;
    }

    .mg ul li {
        font-size: 0.7rem;
    }

    /* CTA banner */
    .cta-banner {
        margin: 1.5rem 5% 3rem;
        padding: 2.5rem 1.8rem;
    }

    .cta-banner h2 {
        font-size: 1.5rem;
    }

    .cta-banner p {
        font-size: 0.85rem;
    }

    .btn-p {
        padding: 0.8rem 1.6rem;
        font-size: 0.88rem;
    }
}

/* ─── MOBILE SMALL (≤480px) ──────────────────────────────── */
@media (max-width: 480px) {
    /* Page hero */
    .page-hero {
        padding: 6rem 5% 2.5rem;
    }

    .page-hero h1 {
        font-size: clamp(1.6rem, 7vw, 2.3rem);
    }

    .page-hero p {
        font-size: 0.85rem;
    }

    .tc2 {
        font-size: 0.7rem;
        padding: 0.35rem 0.7rem;
        gap: 0.4rem;
    }

    .tc2 span {
        font-size: 0.85rem;
    }

    /* Service boxes */
    .services-wrapper {
        padding: 3rem 5%;
    }

    .service-box,
    .service-box.rv {
        padding: 1.8rem 1.2rem;
        border-radius: 16px;
    }

    .bi {
        font-size: 2rem;
    }

    .stag {
        font-size: 0.68rem;
    }

    .service-box h2 {
        font-size: 1.25rem;
    }

    .sd {
        font-size: 0.8rem;
    }

    .fl li {
        font-size: 0.75rem;
    }

    .srb {
        padding: 1.4rem;
        border-radius: 12px;
    }

    .dl {
        gap: 0.5rem;
    }

    .dt strong {
        font-size: 0.75rem;
    }

    .dt span {
        font-size: 0.65rem;
    }

    .pb .am {
        font-size: 1.6rem;
    }

    .pb .tm {
        font-size: 0.68rem;
    }

    .btn-block-p,
    .btn-block-s {
        padding: 0.7rem;
        font-size: 0.8rem;
        border-radius: 8px;
    }

    /* Maintenance */
    .mg {
        padding: 0.9rem;
        border-radius: 8px;
    }

    .mg h5 {
        font-size: 0.75rem;
    }

    .mg .mp {
        font-size: 0.95rem;
    }

    .mg .ms {
        font-size: 0.65rem;
    }

    .mg ul {
        gap: 0.25rem;
    }

    .mg ul li {
        font-size: 0.68rem;
    }

    /* CTA banner */
    .cta-banner {
        margin: 1.2rem 5% 2.5rem;
        padding: 2rem 1.4rem;
        border-radius: 16px;
    }

    .cta-banner h2 {
        font-size: 1.3rem;
    }

    .cta-banner p {
        font-size: 0.8rem;
        margin-bottom: 1.5rem;
    }

    .btn-p {
        padding: 0.75rem 1.4rem;
        font-size: 0.82rem;
        border-radius: 8px;
    }
}

/* ─── DISPOSITIVOS MUY PEQUEÑOS (≤360px) ─────────────────── */
@media (max-width: 360px) {
    .page-hero h1 {
        font-size: clamp(1.4rem, 8vw, 2rem);
    }

    .tc2 {
        font-size: 0.65rem;
        padding: 0.3rem 0.6rem;
    }

    .service-box h2 {
        font-size: 1.15rem;
    }

    .sd {
        font-size: 0.75rem;
    }

    .fl li {
        font-size: 0.7rem;
    }

    .pb .am {
        font-size: 1.4rem;
    }

    .mg h5 {
        font-size: 0.7rem;
    }

    .mg .mp {
        font-size: 0.9rem;
    }

    .mg ul li {
        font-size: 0.65rem;
    }
}

/* ─── DESKTOP GRANDE (≥1440px) ───────────────────────────── */
@media (min-width: 1440px) {
    .page-hero {
        max-width: 1400px;
        margin: 0 auto;
    }

    .service-box {
        max-width: 1300px;
        margin-left: auto;
        margin-right: auto;
    }

    .cta-banner {
        max-width: 1200px;
        margin-left: auto;
        margin-right: auto;
    }
}