/* ============================================================
 *  LBP Sections — página Agencia
 * ============================================================ */

/* ---------- Eyebrows / titulares compartidos ---------- */
.lbp-eyebrow {
    font-size: 12px;
    font-weight: 600;
    color: var(--lbp-accent);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.lbp-eyebrow--light { color: var(--lbp-accent); }

.lbp-section-title {
    font-size: clamp(28px, 4.4vw, 40px);
    line-height: 1.08;
    letter-spacing: -1.2px;
    max-width: 700px;
    color: var(--lbp-fg);
}
.lbp-section-title--md { font-size: clamp(26px, 4vw, 40px); }
.lbp-section-title--sm { font-size: clamp(24px, 3.6vw, 36px); max-width: 640px; }
.lbp-accent-italic { color: var(--lbp-accent); font-style: italic; font-weight: 400; }

.lbp-section-head { margin-bottom: 32px; }

/* ============================================================
 *  Live bar
 * ============================================================ */
.lbp-livebar {
    background: #1a1a1a;
    color: #fff;
    font-size: 12px;
}
.lbp-livebar__inner {
    max-width: 100%;
    margin: 0 auto;
    padding: 9px clamp(16px, 4vw, 40px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.lbp-livebar__left { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.lbp-livebar__right { display: flex; gap: 24px; opacity: 0.7; }
.lbp-livebar__label { opacity: 0.7; }
.lbp-livebar__value { font-weight: 500; }
.lbp-livebar__sep { opacity: 0.4; margin: 0 4px; }

@media (max-width: 720px) {
    .lbp-livebar__inner { flex-direction: column; align-items: flex-start; gap: 6px; padding: 10px 16px; }
    .lbp-livebar__right { gap: 14px; }
}

/* ============================================================
 *  Hero
 * ============================================================ */
.lbp-hero { background: var(--lbp-bg); }
.lbp-hero__inner {
    max-width: var(--lbp-max);
    margin: 0 auto;
    padding: clamp(40px, 7vw, 72px) var(--lbp-pad-x) clamp(28px, 4vw, 40px);
}

.lbp-hero__eyebrow {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
    font-size: 13px;
    flex-wrap: wrap;
}
.lbp-hero__badge {
    background: var(--lbp-accent-soft);
    color: var(--lbp-accent);
    padding: 4px 10px;
    border-radius: 999px;
    font-weight: 500;
}
.lbp-hero__meta { color: var(--lbp-fg-muted); }

.lbp .lbp-hero__title {
    font-size: clamp(38px, 7vw, 76px);
    font-weight: 600;
    letter-spacing: -2.8px;
    line-height: 0.96;
    max-width: 1100px;
    text-wrap: balance;
    margin: 0;
}
.lbp-hero__accent {
    color: var(--lbp-accent);
    font-style: italic;
    font-weight: 400;
}

.lbp .lbp-hero__subtitle {
    font-size: clamp(15px, 1.6vw, 20px);
    color: var(--lbp-fg-soft);
    margin: clamp(22px, 2.4vw, 32px) 0 0;
    max-width: 680px;
    line-height: 1.45;
}

.lbp-hero__ctas {
    display: flex;
    gap: 12px;
    margin-top: 36px;
    align-items: center;
    flex-wrap: wrap;
}

.lbp-hero__rating {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: 16px;
    font-size: 13px;
    color: var(--lbp-fg-muted);
}
.lbp-hero__rating strong { color: var(--lbp-fg); font-weight: 700; }

@media (max-width: 720px) {
    .lbp-hero__title { letter-spacing: -1.6px; }
    .lbp-hero__rating { margin-left: 0; }
}

/* ============================================================
 *  Stats strip
 * ============================================================ */
.lbp-stats { background: var(--lbp-bg); }
.lbp-stats__inner {
    max-width: var(--lbp-max);
    margin: 0 auto;
    padding: 0 var(--lbp-pad-x) clamp(40px, 6vw, 56px);
}
.lbp-stats__card {
    background: #fff;
    border: 1px solid rgba(20,20,20,0.08);
    border-radius: var(--lbp-radius-lg);
    padding: clamp(22px, 3.5vw, 32px) clamp(22px, 4vw, 40px);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(20px, 3vw, 40px);
}
.lbp-stat__value {
    font-size: clamp(32px, 4.8vw, 48px);
    font-weight: 600;
    letter-spacing: -1.5px;
    line-height: 1;
    color: var(--lbp-fg);
    font-variant-numeric: tabular-nums;
}
.lbp-stat__label {
    font-size: 13px;
    color: var(--lbp-fg-muted);
    margin-top: 8px;
}

@media (max-width: 920px)  { .lbp-stats__card { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .lbp-stats__card { grid-template-columns: 1fr; } }

/* ============================================================
 *  Servicios
 * ============================================================ */
.lbp-servicios { background: var(--lbp-bg); }
.lbp-servicios__inner {
    max-width: var(--lbp-max);
    margin: 0 auto;
    padding: clamp(28px, 4vw, 32px) var(--lbp-pad-x) clamp(56px, 8vw, 80px);
}

.lbp-servicios__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.lbp-service-card {
    background: #fff;
    border: 1px solid var(--lbp-line);
    border-radius: 14px;
    padding: 22px;
    cursor: pointer;
    transition: transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s, border-color .22s;
    box-shadow: 0 1px 2px rgba(20,20,20,0.03);
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: 220px;
}
.lbp-service-card:hover,
.lbp-service-card:focus-within {
    transform: translateY(-3px);
    border-color: var(--lbp-line-strong);
    box-shadow: 0 14px 32px rgba(20,20,20,0.08);
}

.lbp-service-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .3s;
}
.lbp-service-card:hover .lbp-service-card__icon {
    transform: rotate(-6deg) scale(1.08);
}

/* Color tokens — copia del PLUGIN_COLORS del diseño */
.lbp-color-coral   { background: #FFE8DF; color: #B8421A; }
.lbp-color-violet  { background: #EEE4FF; color: #5B2FB8; }
.lbp-color-emerald { background: #DCF5E8; color: #126B44; }
.lbp-color-amber   { background: #FFEFD0; color: #8A5A00; }
.lbp-color-sky     { background: #DCECFF; color: #14508F; }
.lbp-color-rose    { background: #FFE0EA; color: #A6244D; }
.lbp-color-indigo  { background: #E1E4FF; color: #2E36A6; }
.lbp-color-teal    { background: #D4F0EE; color: #0C6660; }

.lbp-service-card__name {
    font-size: 16px;
    font-weight: 600;
    color: var(--lbp-fg);
    margin-bottom: 6px;
    letter-spacing: -0.2px;
}
.lbp-service-card__desc {
    font-size: 13px;
    color: var(--lbp-fg-muted);
    line-height: 1.45;
    text-wrap: pretty;
}
.lbp-service-card__more {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--lbp-fg-muted);
    font-weight: 500;
    transition: color .2s;
}
.lbp-service-card:hover .lbp-service-card__more {
    color: var(--lbp-accent);
}

@media (max-width: 1100px) { .lbp-servicios__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 820px)  { .lbp-servicios__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .lbp-servicios__grid { grid-template-columns: 1fr; } }

/* ============================================================
 *  Por qué escogernos (sección oscura)
 * ============================================================ */
.lbp-porque {
    background: #1a1a1a;
    color: #fff;
}
.lbp-porque__inner {
    max-width: var(--lbp-max);
    margin: 0 auto;
    padding: clamp(56px, 8vw, 80px) var(--lbp-pad-x);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(40px, 6vw, 80px);
}
.lbp-porque .lbp-eyebrow { color: var(--lbp-accent); margin-bottom: 12px; }
.lbp-porque__title {
    font-size: clamp(30px, 4.6vw, 44px);
    font-weight: 600;
    letter-spacing: -1.4px;
    line-height: 1.05;
}
.lbp-porque__accent {
    color: var(--lbp-accent);
    font-style: italic;
    font-weight: 400;
}
.lbp-porque__sub {
    font-size: 17px;
    color: rgba(255,255,255,0.7);
    margin-top: 24px;
    line-height: 1.5;
}

.lbp-porque__cards {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.lbp-value-card {
    display: flex;
    gap: 16px;
    padding: 20px;
    background: rgba(255,255,255,0.04);
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.06);
}
.lbp-value-card__icon {
    width: 38px;
    height: 38px;
    border-radius: 9px;
    background: rgba(232,90,43,0.15);
    color: var(--lbp-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.lbp-value-card__title { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.lbp-value-card__body  { font-size: 13.5px; color: rgba(255,255,255,0.65); line-height: 1.5; margin: 0; }

@media (max-width: 880px) { .lbp-porque__inner { grid-template-columns: 1fr; } }

/* ============================================================
 *  Testimonios
 * ============================================================ */
.lbp-testimonios { background: var(--lbp-bg); }
.lbp-testimonios__inner {
    max-width: var(--lbp-max);
    margin: 0 auto;
    padding: clamp(56px, 8vw, 80px) var(--lbp-pad-x);
}

.lbp-testimonios__head {
    margin-bottom: 40px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.lbp-testimonios__rating {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--lbp-fg-muted);
}
.lbp-testimonios__rating strong { color: var(--lbp-fg); font-weight: 700; }

.lbp-testimonios__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.lbp-testimonial {
    background: #fff;
    border: 1px solid var(--lbp-line);
    border-radius: var(--lbp-radius-lg);
    padding: 24px;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.lbp-testimonial__quote {
    font-size: 15px;
    color: var(--lbp-fg);
    line-height: 1.5;
    margin: 0;
    text-wrap: pretty;
    flex: 1;
}
.lbp-testimonial__author {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--lbp-line);
}
.lbp-testimonial__avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 13px;
    flex-shrink: 0;
}
.lbp-testimonial__name { display: block; font-size: 14px; font-weight: 600; color: var(--lbp-fg); }
.lbp-testimonial__role { display: block; font-size: 12px; color: var(--lbp-fg-faint); }

@media (max-width: 980px) { .lbp-testimonios__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .lbp-testimonios__grid { grid-template-columns: 1fr; } }

/* ============================================================
 *  Marquee de trabajos
 * ============================================================ */
.lbp-marquee-section {
    background: var(--lbp-bg);
    padding: 24px 0 clamp(56px, 8vw, 88px);
    overflow: hidden;
}
.lbp-marquee-section__head {
    max-width: var(--lbp-max);
    margin: 0 auto 28px;
    padding: 0 var(--lbp-pad-x);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.lbp-marquee-section__meta {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.lbp-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: #fff;
    border: 1px solid rgba(20,20,20,0.08);
    border-radius: 999px;
    font-size: 13px;
    color: var(--lbp-fg-soft);
}
.lbp-link-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    padding: 10px 16px;
    border: 1px solid var(--lbp-line-strong);
    border-radius: 999px;
    text-decoration: none;
    color: var(--lbp-fg);
    background: transparent;
    transition: background .15s, color .15s;
}
.lbp-link-pill:hover { background: var(--lbp-fg); color: #fff; }

.lbp-marquee-wrap {
    position: relative;
}
.lbp-marquee-wrap::before,
.lbp-marquee-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 80px;
    z-index: 2;
    pointer-events: none;
}
.lbp-marquee-wrap::before { left: 0;  background: linear-gradient(to right, var(--lbp-bg), transparent); }
.lbp-marquee-wrap::after  { right: 0; background: linear-gradient(to left,  var(--lbp-bg), transparent); }

.lbp-marquee-track {
    display: flex;
    gap: 20px;
    width: max-content;
    animation: lbpMarquee 44s linear infinite;
}
.lbp-marquee-wrap:hover .lbp-marquee-track { animation-play-state: paused; }

.lbp-work-card {
    flex: 0 0 auto;
    width: 420px;
    height: 300px;
    border-radius: 18px;
    overflow: hidden;
    position: relative;
    border: 1px solid var(--lbp-line);
    transition: transform .35s cubic-bezier(.2,.7,.3,1), box-shadow .35s;
    box-shadow: 0 1px 3px rgba(20,20,20,0.04);
    text-decoration: none;
    color: inherit;
    display: block;
}
.lbp-work-card:hover {
    transform: translateY(-6px) scale(1.015);
    box-shadow: 0 24px 48px rgba(20,20,20,0.14);
}

.lbp-work-card__art {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.lbp-work-card__img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; object-position: top center;
    display: block;
    transition: transform .5s cubic-bezier(.2,.7,.3,1);
}
.lbp-work-card:hover .lbp-work-card__img { transform: scale(1.06); }
.lbp-work-card__initial {
    font-size: 160px;
    font-weight: 700;
    letter-spacing: -6px;
    line-height: 1;
    color: var(--lbp-fg);
    opacity: 0.18;
    transition: transform .5s cubic-bezier(.2,.7,.3,1);
}
.lbp-work-card:hover .lbp-work-card__initial { transform: scale(1.06) rotate(-3deg); }
.lbp-work-card__bubble {
    position: absolute;
    border-radius: 50%;
    background: var(--lbp-fg);
    opacity: 0.18;
    transition: transform .5s;
}
.lbp-work-card__bubble--a { top: -40px; right: -40px; width: 160px; height: 160px; opacity: 0.22; }
.lbp-work-card__bubble--b { bottom: -30px; left: -30px; width: 110px; height: 110px; opacity: 0.14; }
.lbp-work-card:hover .lbp-work-card__bubble--a { transform: scale(1.25); }

.lbp-work-card__badges {
    position: absolute;
    top: 14px;
    left: 14px;
    right: 14px;
    display: flex;
    gap: 6px;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
}
.lbp-work-card__badge {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.4px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.95);
    color: var(--lbp-fg);
    text-transform: uppercase;
    box-shadow: 0 1px 3px rgba(20,20,20,0.06);
}
.lbp-work-card__metric {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    padding: 5px 10px;
    border-radius: 999px;
    color: #fff;
}

.lbp-work-card__overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 48px 20px 20px;
    background: linear-gradient(to top, rgba(20,20,20,0.85) 0%, rgba(20,20,20,0) 100%);
    color: #fff;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
    z-index: 2;
}
.lbp-work-card__slug {
    font-size: 11px;
    opacity: 0.75;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.lbp-work-card__name {
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.5px;
}
.lbp-work-card__arrow {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #fff;
    color: var(--lbp-fg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .3s;
    flex-shrink: 0;
}
.lbp-work-card:hover .lbp-work-card__arrow { transform: translateX(4px); }

.lbp-marquee-section__footer {
    max-width: var(--lbp-max);
    margin: 32px auto 0;
    padding: 0 var(--lbp-pad-x);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    font-size: 13px;
    color: var(--lbp-fg-muted);
}
.lbp-marquee-section__hint { display: inline-flex; align-items: center; gap: 6px; }
.lbp-marquee-section__stats { display: flex; gap: 28px; flex-wrap: wrap; }
.lbp-marquee-section__stats strong { color: var(--lbp-fg); font-size: 15px; }
.lbp-marquee-section__stats span { color: var(--lbp-fg-faint); }

@media (max-width: 720px) {
    .lbp-work-card { width: 320px; height: 240px; }
    .lbp-work-card__initial { font-size: 130px; }
    .lbp-work-card__name { font-size: 19px; }
}

/* ============================================================
 *  Contacto
 * ============================================================ */
.lbp-contacto {
    background: #fff;
    border-top: 1px solid var(--lbp-line);
    padding: clamp(56px, 8vw, 80px) var(--lbp-pad-x);
}
.lbp-contacto__inner {
    max-width: 1080px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(32px, 5vw, 64px);
    align-items: start;
}

.lbp-contacto__title {
    font-size: clamp(30px, 4.4vw, 44px);
    font-weight: 600;
    letter-spacing: -1.4px;
    line-height: 1.05;
    color: var(--lbp-fg);
}
.lbp-contacto__sub {
    font-size: 16px;
    color: var(--lbp-fg-soft);
    margin-top: 20px;
    line-height: 1.5;
    max-width: 420px;
}

.lbp-contacto__rows {
    list-style: none;
    padding: 0;
    margin: 36px 0 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.lbp-contacto__rows li {
    display: flex;
    gap: 14px;
    align-items: center;
}
.lbp-contacto__row-icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: var(--lbp-accent-soft);
    color: var(--lbp-accent-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.lbp-contacto__row-label { display: block; font-size: 13px; color: var(--lbp-fg-muted); }
.lbp-contacto__row-value { display: block; font-size: 14px; font-weight: 600; color: var(--lbp-fg); }

.lbp-contacto__social {
    margin-top: 36px;
    padding: 20px;
    background: var(--lbp-bg);
    border-radius: 12px;
    display: flex;
    gap: 14px;
    align-items: center;
}
.lbp-contacto__avatars { display: flex; }
.lbp-contacto__avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid var(--lbp-bg);
    margin-left: -10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 12px;
    color: var(--lbp-fg);
}
.lbp-contacto__avatar:first-child { margin-left: 0; }
.lbp-contacto__social-text { font-size: 13px; color: var(--lbp-fg-soft); line-height: 1.4; }
.lbp-contacto__social-text strong { color: var(--lbp-fg); }

.lbp-contacto__form {
    background: var(--lbp-bg);
    border-radius: var(--lbp-radius-lg);
    padding: 32px;
    border: 1px solid var(--lbp-line);
}

.lbp-field { display: block; margin-bottom: 16px; }
.lbp-field > span {
    display: block;
    font-size: 12px;
    font-weight: 500;
    color: var(--lbp-fg-muted);
    margin-bottom: 6px;
}
.lbp-field input,
.lbp-field select {
    width: 100%;
    background: #fff;
    border: 1px solid rgba(20,20,20,0.1);
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 14px;
    font-family: inherit;
    color: var(--lbp-fg);
    outline: none;
    transition: border-color .15s;
}
.lbp-field input:focus,
.lbp-field select:focus { border-color: var(--lbp-fg); }
.lbp-field select {
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 5l3 3 3-3' stroke='%231a1a1a' stroke-width='1.4' fill='none' stroke-linecap='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.lbp-contacto__submit {
    width: 100%;
    justify-content: center;
    margin-top: 8px;
    padding: 14px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 15px;
}

.lbp-contacto__legal {
    font-size: 11px;
    color: var(--lbp-fg-faint);
    margin-top: 12px;
    text-align: center;
    line-height: 1.5;
}

@media (max-width: 880px) { .lbp-contacto__inner { grid-template-columns: 1fr; } }
