/* ═══════════════════════════════════════════
   SECTIONS  —  Hero, proyectos, contacto, etc.
   Desktop-first: definimos el tamaño PC base
   y reducimos con media queries descendentes
   ═══════════════════════════════════════════ */

/* ════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════ */
.hero-wrap {
    position: relative;
    overflow: hidden;
    padding-top: 10px;
}
.hero-wrap::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(820px 560px at 10% 30%, rgba(31,166,74,.14), transparent 55%),
        radial-gradient(640px 440px at 88% 25%, rgba(31,166,74,.07), transparent 60%);
    z-index: -1;
    pointer-events: none;
}

/* H1 — Desktop: 3.2rem | Tablet: 2.4rem | Mobile: 1.9rem */
.hero-wrap h1 {
    font-size: 3.2rem;
    line-height: 1.14;
    font-weight: 800;
    letter-spacing: -0.04em;
}
@media (max-width: 1024px) { .hero-wrap h1 { font-size: 2.6rem; } }
@media (max-width: 768px)  { .hero-wrap h1 { font-size: 2.1rem; } }
@media (max-width: 480px)  { .hero-wrap h1 { font-size: 1.75rem; line-height: 1.2; } }

/* Subtítulo hero — Desktop: 1.1rem | Mobile: 0.95rem */
.hero-kicker {
    color: rgba(255,255,255,.68);
    font-weight: 500;
    margin-top: 18px;
    max-width: 60ch;
    font-size: 1.1rem;
    line-height: 1.7;
}
@media (max-width: 768px)  { .hero-kicker { font-size: 1rem; margin-top: 14px; } }
@media (max-width: 480px)  { .hero-kicker { font-size: .93rem; max-width: 100%; } }

/* Chips hero — Desktop visible y compactos | Mobile: envuelven */
.chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 15px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,.04);
    color: rgba(255,255,255,.72);
    font-weight: 600;
    font-size: .92rem;
    white-space: nowrap;
    transition: border-color .15s;
}
.chip:hover { border-color: rgba(31,166,74,.35); }
@media (max-width: 768px)  { .chip { font-size: .87rem; padding: 8px 12px; } }
@media (max-width: 380px)  { .chip { font-size: .8rem;  padding: 7px 10px; } }

/* Card de contacto rápido del hero — desktop: buen padding */
.hero-wrap .card-pro { padding: 28px; }
@media (max-width: 768px)  { .hero-wrap .card-pro { padding: 22px; } }
@media (max-width: 480px)  { .hero-wrap .card-pro { padding: 18px; } }


/* ════════════════════════════════════════════
   PROYECTOS
   ════════════════════════════════════════════ */
.projects-grid {
    display: grid;
    gap: 20px;
    /* Desktop: 3 columnas */
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 991px) {
    /* Tablet: 2 columnas */
    .projects-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (max-width: 575px) {
    /* Mobile: 1 columna */
    .projects-grid { grid-template-columns: 1fr; gap: 14px; }
}

/* project-card ya no necesita grid-column manual */
.project-card {
    border: 1px solid var(--border);
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255,255,255,.025);
    text-align: left;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.project-card:hover {
    transform: translateY(-5px);
    border-color: rgba(31,166,74,.32);
    box-shadow: 0 16px 36px rgba(0,0,0,.30);
}
@media (prefers-reduced-motion: reduce) {
    .project-card { transition: none; }
    .project-card:hover { transform: none; }
}

.project-img-wrap {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}
.project-img-wrap img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .4s ease;
}
.project-card:hover .project-img-wrap img { transform: scale(1.06); }

.project-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.62));
}
.project-badge {
    position: absolute; left: 12px; top: 12px;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(8,14,22,.55);
    color: rgba(255,255,255,.90);
    font-weight: 700; font-size: .8rem;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.project-body { padding: 18px 18px 20px; }
@media (max-width: 576px) { .project-body { padding: 14px 14px 16px; } }

/* Desktop: título de proyecto más visible */
.project-title {
    font-weight: 800;
    letter-spacing: -0.025em;
    margin-bottom: 7px;
    font-size: 1.05rem;
    color: #fff;
    line-height: 1.3;
}
@media (max-width: 576px) { .project-title { font-size: .95rem; } }

.project-desc {
    color: var(--muted);
    font-size: .92rem;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* En desktop con pantalla grande, mostrar 3 líneas completas */
@media (min-width: 992px) { .project-desc { -webkit-line-clamp: 3; } }

.project-tags { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 6px; }
.project-tag {
    display: inline-block;
    padding: 4px 11px;
    border-radius: 999px;
    border: 1px solid rgba(31,166,74,.22);
    background: rgba(31,166,74,.07);
    color: rgba(255,255,255,.62);
    font-size: .76rem;
    font-weight: 600;
}
.project-link {
    margin-top: 12px;
    font-weight: 700;
    font-size: .9rem;
    color: rgba(255,255,255,.80);
    display: flex; align-items: center; gap: 4px;
    transition: color .15s;
}
.project-card:hover .project-link { color: var(--brand); }


/* ════════════════════════════════════════════
   SERVICIOS — cards icono + texto
   ════════════════════════════════════════════ */
#services .card-pro {
    padding: 32px 28px;
    transition: border-color .2s, transform .2s;
}
#services .card-pro:hover {
    border-color: rgba(31,166,74,.28);
    transform: translateY(-4px);
}
@media (max-width: 768px)  { #services .card-pro { padding: 24px; } }
@media (max-width: 480px)  { #services .card-pro { padding: 18px; } }

/* Icono grande en desktop */
#services .card-pro > i { font-size: 2rem; }
@media (max-width: 480px)  { #services .card-pro > i { font-size: 1.6rem; } }

/* Título de servicio */
#services h5.fw-bold { font-size: 1.1rem; margin-top: 16px !important; }

/* Línea complementaria de servicios */
#services .card-mini { padding: 16px 20px !important; }


/* ════════════════════════════════════════════
   SECTORES
   ════════════════════════════════════════════ */
#sectors .card-pro { padding: 24px; transition: border-color .2s, transform .2s; }
#sectors .card-pro:hover {
    border-color: rgba(31,166,74,.28);
    transform: translateY(-3px);
}
#sectors .muted { font-size: .95rem; line-height: 1.6; margin-top: 8px; }
@media (max-width: 768px) { #sectors .card-pro { padding: 20px; } }


/* ════════════════════════════════════════════
   DIFERENCIALES
   ════════════════════════════════════════════ */
#differentials .card-pro {
    padding: 36px 28px;
    transition: border-color .2s, transform .2s;
}
#differentials .card-pro:hover {
    border-color: rgba(31,166,74,.28);
    transform: translateY(-4px);
}
#differentials .card-pro i { font-size: 2.2rem; }
#differentials h5.fw-bold { font-size: 1.05rem; margin-top: 14px !important; }

@media (max-width: 768px) { #differentials .card-pro { padding: 24px 20px; } }
@media (max-width: 480px) {
    #differentials .card-pro { padding: 20px 18px; }
    #differentials .card-pro i { font-size: 1.7rem; }
}


/* ════════════════════════════════════════════
   CALIDAD
   ════════════════════════════════════════════ */
#quality .card-pro { padding: 36px; }
@media (max-width: 768px) { #quality .card-pro { padding: 24px; } }
@media (max-width: 480px) { #quality .card-pro { padding: 18px; } }


/* ════════════════════════════════════════════
   NOSOTROS
   ════════════════════════════════════════════ */
.about { background: rgba(255,255,255,.008); }
#about .card-pro { padding: 28px; transition: border-color .2s; }
#about .card-pro:hover { border-color: rgba(31,166,74,.22); }
#about .card-pro > i { font-size: 1.8rem; }
@media (max-width: 480px) { #about .card-pro { padding: 18px; } }


/* ════════════════════════════════════════════
   CONTACTO
   ════════════════════════════════════════════ */
.contact-stat { display: flex; align-items: flex-start; gap: 14px; }
.contact-stat-icon {
    width: 40px; height: 40px;
    border-radius: 11px;
    background: rgba(31,166,74,.12);
    border: 1px solid rgba(31,166,74,.22);
    display: flex; align-items: center; justify-content: center;
    color: var(--brand); font-size: 1.05rem; flex-shrink: 0;
}
.contact-tel {
    display: inline-flex; align-items: center;
    color: var(--brand); font-weight: 700; font-size: .95rem;
    min-height: 36px;
}
.contact-tel:hover { opacity: .82; color: var(--brand); }

/* Chips de servicio */
.service-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.service-chip {
    padding: 9px 16px;
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: rgba(255,255,255,.03);
    color: var(--muted);
    font-weight: 600; font-size: .9rem;
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s;
    display: flex; align-items: center; gap: 7px;
    min-height: 40px;
}
.service-chip:hover  { border-color: rgba(31,166,74,.4); color: var(--text); }
.service-chip.active { border-color: var(--brand); background: rgba(31,166,74,.12); color: #fff; }
@media (max-width: 480px) { .service-chip { font-size: .85rem; padding: 8px 12px; } }

/* Urgencia */
.urgency-group { display: flex; flex-wrap: wrap; gap: 8px; }
.urgency-opt { cursor: pointer; }
.urgency-opt input[type="radio"] { display: none; }
.urgency-opt span {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 18px;
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: rgba(255,255,255,.03);
    color: var(--muted); font-weight: 600; font-size: .9rem;
    min-height: 40px;
    transition: border-color .15s, background .15s, color .15s;
}
.urgency-opt input[type="radio"]:checked + span {
    border-color: var(--brand); background: rgba(31,166,74,.12); color: #fff;
}
.urgency-opt:hover span { border-color: rgba(31,166,74,.4); color: var(--text); }


/* ════════════════════════════════════════════
   GLOBAL MOBILE TWEAKS
   ════════════════════════════════════════════ */
@media (max-width: 576px) {
    /* Delay de AOS en mobile → innecesario, lo anulamos */
    [data-aos][data-aos-delay] { transition-delay: 0ms !important; }

    /* Modal ocupa toda la pantalla en mobile */
    .modal-dialog { margin: 6px; max-width: calc(100vw - 12px); }
    .modal-content, .modal-pro { border-radius: 16px; }
}


/* ════════════════════════════════════════════
   CTA BANNER  —  Bloque de llamada a la acción
   ════════════════════════════════════════════ */
.cta-banner {
    background: linear-gradient(135deg,
        rgba(31,166,74,.12) 0%,
        rgba(14,122,47,.08) 100%);
    border: 1px solid rgba(31,166,74,.28);
    border-radius: 20px;
    padding: 32px 36px;
}

.cta-banner-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}

.cta-banner-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .cta-banner { padding: 24px 22px; }
    .cta-banner-content { flex-direction: column; align-items: flex-start; }
    .cta-banner-actions { width: 100%; }
    .cta-banner-actions .btn { flex: 1; justify-content: center; }
}
@media (max-width: 480px) {
    .cta-banner { padding: 20px 16px; border-radius: 16px; }
    .cta-banner-actions { flex-direction: column; }
    .cta-banner-actions .btn { width: 100%; }
}
