/* ==========================================================================
   DESARROLLO WEB — pagina espectacular de servicios
   ========================================================================== */

.dw-page { overflow-x: clip; }

/* ------------------------------------------------------------------------
   HERO
   ------------------------------------------------------------------------ */
.dw-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: radial-gradient(ellipse at 50% -10%, rgba(255,94,20,.16), transparent 60%), var(--color-bg);
    border-bottom: 1px solid var(--color-border);
}

.dw-hero__bg { position: absolute; inset: 0; z-index: 0; }

.dw-hero__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: .55;
    animation: dwOrbFloat 16s ease-in-out infinite;
}
.dw-hero__orb--1 { width: 420px; height: 420px; left: -10%; top: 10%; background: radial-gradient(circle, rgba(255,94,20,.55), transparent 70%); animation-delay: 0s; }
.dw-hero__orb--2 { width: 340px; height: 340px; right: -8%; top: 30%; background: radial-gradient(circle, rgba(255,150,80,.4), transparent 70%); animation-delay: -5s; }
.dw-hero__orb--3 { width: 300px; height: 300px; left: 35%; bottom: -15%; background: radial-gradient(circle, rgba(255,94,20,.35), transparent 70%); animation-delay: -10s; }

@keyframes dwOrbFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50%      { transform: translate(40px, -30px) scale(1.12); }
}

.dw-hero__grid {
    position: absolute;
    inset: -1px;
    background-image:
        linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 48px 48px;
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 100%);
    mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 100%);
}

.dw-hero__inner {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 820px;
    /* El texto es visible desde el primer frame; solo se asienta con un leve desplazamiento. */
    animation: dwHeroIn .6s ease-out both;
}
@keyframes dwHeroIn {
    from { transform: translateY(12px); }
    to   { transform: translateY(0); }
}

.dw-hero__eyebrow {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--color-accent);
    margin-bottom: var(--space-3);
}

.dw-hero__title {
    font-size: clamp(2.4rem, 6vw, 4.2rem);
    font-weight: var(--font-weight-extrabold);
    letter-spacing: -0.03em;
    line-height: 1.08;
    margin-bottom: var(--space-5);
}
.dw-hero__title-accent {
    background: linear-gradient(95deg, var(--color-accent) 10%, #FFB088 55%, var(--color-accent) 95%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.dw-hero__title-accent { animation: dwGradientShift 5s linear infinite; }
@keyframes dwGradientShift { to { background-position: 200% center; } }

.dw-hero__sub {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    max-width: 600px;
    margin-inline: auto;
    margin-bottom: var(--space-8);
}

.dw-hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }

@media (prefers-reduced-motion: reduce) {
    .dw-hero__orb { animation: none; }
    .dw-hero__inner { animation: none; }
    .dw-hero__title-accent { animation: none; }
}

/* ------------------------------------------------------------------------
   SECCIONES GENERALES
   ------------------------------------------------------------------------ */
/* Mismo ritmo vertical que .section del resto del sitio. Los encabezados usan
   .section__header (clase compartida), no una propia. */
.dw-section { padding-block: var(--space-20); }

/* ------------------------------------------------------------------------
   PORTFOLIO
   ------------------------------------------------------------------------ */
.dw-portfolio-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.dw-port-card {
    display: block;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}
.dw-port-card:hover { transform: translateY(-4px); border-color: var(--color-border-accent); box-shadow: 0 8px 28px rgba(255,94,20,.16); }
.dw-port-card__shot { aspect-ratio: 16/10; overflow: hidden; background: var(--color-bg-elevated); border-bottom: 1px solid var(--color-border); }
.dw-port-card__shot img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform var(--transition-slow); }
.dw-port-card:hover .dw-port-card__shot img { transform: scale(1.04); }
.dw-port-card__body { padding: var(--space-5); }
.dw-port-card__name { font-size: var(--font-size-lg); margin-bottom: var(--space-1); }
.dw-port-card__tag { font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-bottom: var(--space-3); }
.dw-port-card__link { display: inline-flex; align-items: center; gap: var(--space-1); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); color: var(--color-accent); }

/* ------------------------------------------------------------------------
   TABS (Landing / Tienda)
   ------------------------------------------------------------------------ */
.dw-tabs { display: flex; justify-content: center; gap: var(--space-2); margin-bottom: var(--space-8); }
.dw-tab {
    padding: var(--space-3) var(--space-6);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-secondary);
    background: var(--glass-bg);
    transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.dw-tab.is-active { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.dw-tab:not(.is-active):hover { background: var(--glass-bg-hover); color: var(--color-text); }

/* ------------------------------------------------------------------------
   PLAN / COMBO CARDS
   ------------------------------------------------------------------------ */
.dw-plans-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }

.dw-plan-card {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: var(--space-8) var(--space-6) var(--space-6);
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-xl);
    transition: transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}
.dw-plan-card:hover { transform: translateY(-4px); border-color: var(--color-border-accent); box-shadow: 0 8px 28px rgba(255,94,20,.16); }
.dw-plan-card--featured { border-color: var(--color-border-accent); background: linear-gradient(165deg, rgba(255,94,20,.08), var(--glass-bg) 60%); box-shadow: var(--shadow-accent); }

.dw-plan-card__ribbon {
    position: absolute;
    top: var(--space-5);
    right: var(--space-6);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-accent);
    background: var(--color-accent-subtle);
    padding: 2px var(--space-3);
    border-radius: var(--radius-full);
}
.dw-plan-card__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.dw-plan-card__name { font-size: var(--font-size-2xl); margin-bottom: var(--space-1); }
.dw-plan-card__tagline { font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-bottom: var(--space-6); }

.dw-plan-card__features { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-6); flex: 1; }
.dw-plan-card__features li { display: flex; align-items: flex-start; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.dw-plan-card__features li svg { flex-shrink: 0; margin-top: 3px; color: var(--color-accent); }

.dw-plan-card__price { margin-bottom: var(--space-5); }
.dw-plan-card__price-label { display: block; font-size: var(--font-size-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: var(--space-1); }
.dw-plan-card__price-value { font-size: var(--font-size-3xl); font-weight: var(--font-weight-extrabold); letter-spacing: -.02em; }

/* ------------------------------------------------------------------------
   PROCESO
   ------------------------------------------------------------------------ */
.dw-process-list { max-width: 720px; margin-inline: auto; position: relative; padding-left: var(--space-2); }
.dw-process-list::before {
    content: '';
    position: absolute;
    left: 19px;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background: var(--color-border);
}
.dw-process-list .step-v { position: relative; align-items: flex-start; flex-wrap: wrap; gap: var(--space-3) var(--space-5); }
.dw-process-list .step-v__body { flex: 1; min-width: 200px; }
.dw-process-pago {
    margin-left: calc(40px + var(--space-5));
    color: var(--color-accent);
    background: var(--color-accent-subtle);
}

.dw-process-note {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    max-width: 720px;
    margin: var(--space-8) auto 0;
    padding: var(--space-5) var(--space-6);
    color: var(--color-accent);
}
.dw-process-note p { color: var(--color-text-secondary); font-size: var(--font-size-sm); margin-top: var(--space-1); }

/* ------------------------------------------------------------------------
   RESPONSIVE
   ------------------------------------------------------------------------ */
@media (max-width: 1023px) {
    .dw-plans-grid { grid-template-columns: repeat(2, 1fr); }
    .dw-plans-grid .dw-plan-card:last-child { grid-column: 1 / -1; max-width: 480px; margin-inline: auto; }
}

@media (max-width: 767px) {
    .dw-portfolio-grid { grid-template-columns: 1fr; }
    .dw-plans-grid { grid-template-columns: 1fr; }
    .dw-plans-grid .dw-plan-card:last-child { max-width: none; }
    .dw-hero { min-height: 100svh; }
    .dw-process-pago { margin-left: 0; }
}
