/* ============================================
   PNIC LANDING DIANA V2 - ESTILOS GLOBALES
   Azul: #0e1e3f | Beige: #f5f1e8 | Gold: #bf9c62
   Marrón: #94724d | Gris: #7a7168
   ============================================ */

.pnic-diana-container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
.pnic-diana-label { font-size: 12px; font-weight: 400; text-transform: uppercase; letter-spacing: 2.5px; color: var(--pnic-accent, #bf9c62); margin-bottom: 20px; display: block; }
.pnic-diana-headline { font-family: "Playfair Display", Georgia, serif; font-size: 42px; font-weight: 400; line-height: 1.15; color: #0e1e3f; margin-bottom: 20px; }
.pnic-diana-headline em { font-style: italic; color: var(--pnic-accent, #bf9c62); }
.pnic-diana-headline.white { color: #ffffff; }
.pnic-diana-headline.white em { color: #f5f1e8; }
.pnic-diana-sub { font-size: 17px; font-weight: 300; color: #7a7168; line-height: 1.7; max-width: 700px; }
.pnic-diana-sub.white { color: rgba(255,255,255,0.8); }
.pnic-diana-sub.center { margin: 0 auto; }

/* Botones */
.pnic-diana-cta { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; text-decoration: none; padding: 18px 40px; border-radius: 30px; transition: all 0.3s ease; cursor: pointer; border: none; }
.pnic-diana-cta-primary { background: var(--pnic-accent, #bf9c62); color: #ffffff; box-shadow: 0 6px 24px rgba(191,156,98,0.4); }
.pnic-diana-cta-primary:hover { background: #94724d; transform: translateY(-3px); box-shadow: 0 10px 35px rgba(148,114,77,0.5); }
.pnic-diana-cta-outline { background: transparent; color: var(--pnic-accent, #bf9c62); border: 2px solid var(--pnic-accent, #bf9c62); }
.pnic-diana-cta-outline:hover { background: var(--pnic-accent, #bf9c62); color: #ffffff; }
.pnic-diana-cta-white { background: #ffffff; color: #0e1e3f; box-shadow: 0 6px 24px rgba(0,0,0,0.15); }
.pnic-diana-cta-white:hover { background: var(--pnic-accent, #bf9c62); color: #ffffff; }

/* ===== SECCIÓN 4: ACCORDION ===== */
.pnic-accordion-wrap { width: 100%; background: var(--pnic-bg, #f5f1e8); padding: 80px 0; }
.pnic-accordion-inner { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.pnic-accordion-header { text-align: center; margin-bottom: 48px; }
.pnic-accordion-list { display: flex; flex-direction: column; gap: 12px; }
.pnic-accordion-item { border: 1px solid #e8e0d6; border-radius: 12px; overflow: hidden; transition: all 0.3s ease; background: #ffffff; }
.pnic-accordion-item:hover { border-color: #d5ccc0; }
.pnic-accordion-item.active { border-color: var(--pnic-accent, #bf9c62); box-shadow: 0 4px 20px rgba(191,156,98,0.08); }
.pnic-accordion-trigger { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 24px 28px; cursor: pointer; background: #ffffff; transition: all 0.3s ease; border: none; width: 100%; text-align: left; }
.pnic-accordion-item.active .pnic-accordion-trigger { background: rgba(191,156,98,0.03); }
.pnic-accordion-trigger-left { display: flex; align-items: center; gap: 16px; }
.pnic-accordion-icon { width: 40px; height: 40px; border-radius: 10px; background: rgba(191,156,98,0.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 0.3s ease; }
.pnic-accordion-item.active .pnic-accordion-icon { background: var(--pnic-accent, #bf9c62); }
.pnic-accordion-icon svg { width: 20px; height: 20px; stroke: var(--pnic-accent, #bf9c62); fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; transition: all 0.3s ease; }
.pnic-accordion-item.active .pnic-accordion-icon svg { stroke: #ffffff; }
.pnic-accordion-title { font-family: "Playfair Display", Georgia, serif; font-size: 20px; font-weight: 400; color: #0e1e3f; transition: color 0.3s ease; }
.pnic-accordion-item.active .pnic-accordion-title { color: var(--pnic-accent, #bf9c62); }
.pnic-accordion-arrow { width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; transition: transform 0.4s ease; flex-shrink: 0; }
.pnic-accordion-arrow svg { width: 16px; height: 16px; stroke: var(--pnic-accent, #bf9c62); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.pnic-accordion-item.active .pnic-accordion-arrow { transform: rotate(180deg); }
.pnic-accordion-content { max-height: 0; overflow: hidden; transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
.pnic-accordion-item.active .pnic-accordion-content { max-height: 800px; }
.pnic-accordion-body { padding: 0 28px 28px 84px; font-size: 15px; font-weight: 300; line-height: 1.7; color: #7a7168; }
.pnic-accordion-body p { margin-bottom: 12px; }
.pnic-accordion-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.pnic-accordion-tag { font-size: 12px; font-weight: 400; color: var(--pnic-accent, #bf9c62); background: rgba(191,156,98,0.06); padding: 6px 14px; border-radius: 20px; border: 1px solid rgba(191,156,98,0.15); }
.pnic-accordion-cta { margin-top: 48px; text-align: center; }
.pnic-accordion-cta-link { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 400; text-transform: uppercase; letter-spacing: 1.5px; color: #ffffff; background: var(--pnic-accent, #bf9c62); padding: 14px 32px; text-decoration: none; transition: all 0.3s ease; border-radius: 30px; }
.pnic-accordion-cta-link:hover { background: #94724d; }

/* ===== SECCIÓN 5: PREVENTION CTA ===== */
.pnic-prevention-wrap { width: 100%; background: var(--pnic-bg, #0e1e3f); padding: 80px 0; text-align: center; }
.pnic-prevention-inner { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.pnic-prevention-wrap .pnic-diana-headline { color: #ffffff; }
.pnic-prevention-wrap .pnic-diana-headline em { color: #bf9c62; }
.pnic-prevention-wrap .pnic-diana-sub { color: rgba(255,255,255,0.85); margin: 0 auto; }

/* ===== SECCIÓN 6: PNIC EXPLANATION ===== */
.pnic-explanation-wrap { width: 100%; background: var(--pnic-bg, #ffffff); padding: 90px 0; text-align: center; }
.pnic-explanation-inner { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.pnic-explanation-wrap .pnic-diana-sub { margin: 0 auto; max-width: 800px; }

/* ===== SECCIÓN 7: PROCESS TIMELINE ===== */
.pnic-process-wrap { width: 100%; background: var(--pnic-bg, #7a7168); padding: 80px 0; }
.pnic-process-inner { max-width: 900px; margin: 0 auto; padding: 0 24px; }
.pnic-process-header { text-align: center; margin-bottom: 56px; }
.pnic-process-wrap .pnic-diana-headline { color: #ffffff; }
.pnic-process-wrap .pnic-diana-headline em { color: #f5f1e8; }
.pnic-process-wrap .pnic-diana-sub { color: rgba(255,255,255,0.7); }
.pnic-process-timeline { position: relative; padding-left: 60px; }
.pnic-process-timeline::before { content: ""; position: absolute; left: 20px; top: 0; bottom: 0; width: 2px; background: linear-gradient(to bottom, var(--pnic-accent, #bf9c62), rgba(191,156,98,0.2)); }
.pnic-process-step { position: relative; padding-bottom: 40px; }
.pnic-process-step:last-child { padding-bottom: 0; }
.pnic-process-number { position: absolute; left: -60px; top: 0; width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--pnic-accent, #bf9c62); display: flex; align-items: center; justify-content: center; font-family: "Playfair Display", Georgia, serif; font-size: 18px; color: var(--pnic-accent, #bf9c62); background: var(--pnic-bg, #7a7168); transition: all 0.4s ease; z-index: 2; }
.pnic-process-step.active .pnic-process-number { background: var(--pnic-accent, #bf9c62); color: #ffffff; box-shadow: 0 0 0 6px rgba(191,156,98,0.15); }
.pnic-process-content { padding-top: 4px; }
.pnic-process-title { font-family: "Playfair Display", Georgia, serif; font-size: 22px; font-weight: 400; color: #ffffff; margin-bottom: 8px; line-height: 1.3; }
.pnic-process-text { font-size: 15px; font-weight: 300; line-height: 1.7; color: rgba(255,255,255,0.75); max-width: 600px; }
.pnic-process-cta { margin-top: 48px; text-align: center; }
.pnic-process-cta-link { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 400; text-transform: uppercase; letter-spacing: 1.5px; color: var(--pnic-bg, #7a7168); background: #ffffff; padding: 16px 40px; text-decoration: none; transition: all 0.3s ease; border-radius: 30px; }
.pnic-process-cta-link:hover { background: var(--pnic-accent, #bf9c62); color: #ffffff; }

/* ===== SECCIÓN 8: COMMITMENT CTA ===== */
.pnic-commitment-wrap { width: 100%; background: var(--pnic-bg, #bf9c62); padding: 90px 0; text-align: center; }
.pnic-commitment-inner { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.pnic-commitment-wrap .pnic-diana-headline { color: #ffffff; }
.pnic-commitment-wrap .pnic-diana-headline em { color: #0e1e3f; }
.pnic-commitment-wrap .pnic-diana-sub { color: rgba(255,255,255,0.9); margin: 0 auto; }

/* ===== SECCIÓN 9: FINAL PATH CTA ===== */
.pnic-final-path-wrap { width: 100%; background: var(--pnic-bg, #0e1e3f); padding: 80px 0; text-align: center; }
.pnic-final-path-inner { max-width: 700px; margin: 0 auto; padding: 0 24px; }
.pnic-final-path-wrap .pnic-diana-headline { color: #ffffff; }
.pnic-final-path-wrap .pnic-diana-headline em { color: #bf9c62; }
.pnic-final-path-wrap .pnic-diana-sub { color: rgba(255,255,255,0.8); margin: 0 auto; }
.pnic-final-path-button { margin-top: 40px; }

/* ===== SECCIÓN 10: COLLEAGUES ===== */
.pnic-colleagues-wrap { width: 100%; background: var(--pnic-bg, #ffffff); padding: 80px 0; }
.pnic-colleagues-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.pnic-colleagues-text { text-align: left; }
.pnic-colleagues-headline { font-family: "Playfair Display", Georgia, serif; font-size: 42px; font-weight: 400; line-height: 1.15; color: #0e1e3f; margin-bottom: 24px; }
.pnic-colleagues-headline em { font-style: italic; color: var(--pnic-accent, #bf9c62); }
.pnic-colleagues-body { font-size: 16px; font-weight: 300; line-height: 1.7; color: #7a7168; margin-bottom: 16px; }
.pnic-colleagues-highlight { font-family: "Playfair Display", Georgia, serif; font-size: 18px; font-style: italic; color: var(--pnic-accent, #bf9c62); margin: 24px 0 32px; display: block; }
.pnic-colleagues-cta { display: inline-block; font-size: 12px; font-weight: 400; text-transform: uppercase; letter-spacing: 1.5px; color: var(--pnic-accent, #bf9c62); border: 1px solid var(--pnic-accent, #bf9c62); padding: 14px 32px; text-decoration: none; transition: all 0.3s ease; }
.pnic-colleagues-cta:hover { background: var(--pnic-accent, #bf9c62); color: #ffffff; }
.pnic-colleagues-visual { display: flex; align-items: center; justify-content: center; }
.pnic-colleagues-visual-inner { width: 280px; height: 280px; position: relative; }
.pnic-colleagues-circle-outer { position: absolute; width: 100%; height: 100%; border: 1px solid rgba(191,156,98,0.2); border-radius: 50%; animation: pnic-rotate 20s linear infinite; }
.pnic-colleagues-circle-inner { position: absolute; top: 20%; left: 20%; width: 60%; height: 60%; border: 1px solid rgba(191,156,98,0.4); border-radius: 50%; animation: pnic-rotate-reverse 15s linear infinite; }
.pnic-colleagues-center { position: absolute; top: 35%; left: 35%; width: 30%; height: 30%; background: var(--pnic-accent, #bf9c62); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.pnic-colleagues-center svg { width: 24px; height: 24px; stroke: #ffffff; fill: none; stroke-width: 2; }
.pnic-colleagues-dots { position: absolute; width: 100%; height: 100%; }
.pnic-colleagues-dot { position: absolute; width: 8px; height: 8px; background: var(--pnic-accent, #bf9c62); border-radius: 50%; opacity: 0.6; }
.pnic-colleagues-dot:nth-child(1) { top: 0; left: 50%; transform: translateX(-50%); }
.pnic-colleagues-dot:nth-child(2) { bottom: 15%; left: 10%; }
.pnic-colleagues-dot:nth-child(3) { bottom: 15%; right: 10%; }
@keyframes pnic-rotate { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
@keyframes pnic-rotate-reverse { 0% { transform: rotate(0deg); } 100% { transform: rotate(-360deg); } }

/* ===== SECCIÓN 11: ABOUT ME ===== */
.pnic-about-wrap { width: 100%; background: var(--pnic-bg, #f5f1e8); padding: 90px 0; }
.pnic-about-inner { max-width: 1100px; margin: 0 auto; padding: 0 24px; display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; align-items: center; }
.pnic-about-image { border-radius: 20px; overflow: hidden; box-shadow: 0 25px 70px rgba(14,30,63,0.15); }
.pnic-about-image img { width: 100%; height: auto; display: block; }
.pnic-about-text { text-align: left; }
.pnic-about-headline { font-family: "Playfair Display", Georgia, serif; font-size: 42px; font-weight: 400; line-height: 1.15; color: #0e1e3f; margin-bottom: 24px; }
.pnic-about-headline em { font-style: italic; color: var(--pnic-accent, #bf9c62); }
.pnic-about-body { font-size: 16px; font-weight: 300; line-height: 1.8; color: #7a7168; margin-bottom: 20px; }
.pnic-about-body p { margin-bottom: 20px; }
.pnic-about-highlight { font-family: "Playfair Display", Georgia, serif; font-size: 20px; font-style: italic; color: var(--pnic-accent, #bf9c62); margin: 32px 0; padding: 24px 0; border-top: 1px solid rgba(191,156,98,0.3); border-bottom: 1px solid rgba(191,156,98,0.3); }
.pnic-about-commitment-title { font-family: "Playfair Display", Georgia, serif; font-size: 24px; color: #0e1e3f; margin: 32px 0 16px; font-weight: 500; }

/* ===== SECCIÓN 13: BOOKING BOX ===== */
.pnic-booking-wrap { width: 100%; background: var(--pnic-bg, #ffffff); padding: 80px 0; }
.pnic-booking-inner { max-width: 900px; margin: 0 auto; padding: 0 24px; }
.pnic-booking-box { background: var(--pnic-accent, #bf9c62); border-radius: 24px; padding: 60px; text-align: center; box-shadow: 0 20px 60px rgba(191,156,98,0.2); }
.pnic-booking-box .pnic-diana-headline { color: #ffffff; margin-bottom: 16px; }
.pnic-booking-box .pnic-diana-headline em { color: #0e1e3f; }
.pnic-booking-box .pnic-diana-sub { color: rgba(255,255,255,0.9); margin: 0 auto 32px; }
.pnic-booking-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.pnic-booking-social { margin-top: 32px; display: flex; gap: 24px; justify-content: center; align-items: center; flex-wrap: wrap; }
.pnic-booking-social a { color: #ffffff; text-decoration: none; font-size: 14px; display: flex; align-items: center; gap: 8px; transition: opacity 0.3s ease; }
.pnic-booking-social a:hover { opacity: 0.8; }
.pnic-booking-social svg { width: 20px; height: 20px; fill: #ffffff; }

/* ===== SECCIÓN 14: FAQ ===== */
.pnic-faq-wrap { width: 100%; background: var(--pnic-bg, #f5f1e8); padding: 90px 0; }
.pnic-faq-inner { max-width: 800px; margin: 0 auto; padding: 0 24px; }
.pnic-faq-header { text-align: center; margin-bottom: 56px; }
.pnic-faq-list { display: flex; flex-direction: column; gap: 14px; }
.pnic-faq-item { background: #ffffff; border-radius: 16px; overflow: hidden; border: 2px solid #e8e0d6; transition: all 0.3s ease; }
.pnic-faq-item:hover { border-color: #d5ccc0; }
.pnic-faq-item.active { border-color: var(--pnic-accent, #bf9c62); box-shadow: 0 8px 30px rgba(191,156,98,0.08); }
.pnic-faq-question { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 24px 28px; cursor: pointer; font-family: "Playfair Display", Georgia, serif; font-size: 20px; color: #0e1e3f; transition: all 0.3s ease; border: none; background: none; width: 100%; text-align: left; font-weight: 500; }
.pnic-faq-question:hover { color: var(--pnic-accent, #bf9c62); }
.pnic-faq-question svg { width: 22px; height: 22px; stroke: var(--pnic-accent, #bf9c62); fill: none; stroke-width: 2; flex-shrink: 0; transition: transform 0.3s ease; }
.pnic-faq-item.active .pnic-faq-question svg { transform: rotate(180deg); }
.pnic-faq-answer { max-height: 0; overflow: hidden; transition: all 0.4s ease; }
.pnic-faq-item.active .pnic-faq-answer { max-height: 800px; }
.pnic-faq-answer-inner { padding: 0 28px 28px; font-size: 15px; font-weight: 300; color: #7a7168; line-height: 1.7; }
.pnic-faq-social { margin-top: 48px; text-align: center; font-size: 14px; color: #7a7168; }
.pnic-faq-social p { margin: 8px 0; }
.pnic-faq-social strong { color: var(--pnic-accent, #bf9c62); }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
    .pnic-accordion-wrap, .pnic-prevention-wrap, .pnic-explanation-wrap, .pnic-process-wrap, .pnic-commitment-wrap, .pnic-final-path-wrap, .pnic-colleagues-wrap, .pnic-about-wrap, .pnic-booking-wrap, .pnic-faq-wrap { padding: 60px 0; }
    .pnic-diana-headline, .pnic-colleagues-headline, .pnic-about-headline { font-size: 32px; }
    .pnic-accordion-trigger, .pnic-faq-question { padding: 20px; }
    .pnic-accordion-body { padding: 0 20px 24px; }
    .pnic-faq-answer-inner { padding: 0 20px 24px; }
    .pnic-colleagues-inner, .pnic-about-inner { grid-template-columns: 1fr; gap: 40px; }
    .pnic-colleagues-text, .pnic-about-text { text-align: center; }
    .pnic-colleagues-visual, .pnic-about-image { order: -1; }
    .pnic-colleagues-visual-inner { width: 200px; height: 200px; }
    .pnic-process-timeline { padding-left: 48px; }
    .pnic-process-timeline::before { left: 16px; }
    .pnic-process-number { left: -48px; width: 32px; height: 32px; font-size: 14px; }
    .pnic-booking-box { padding: 40px 24px; }
    .pnic-booking-buttons { flex-direction: column; align-items: center; }
}
@media (max-width: 480px) {
    .pnic-accordion-wrap, .pnic-prevention-wrap, .pnic-explanation-wrap, .pnic-process-wrap, .pnic-commitment-wrap, .pnic-final-path-wrap, .pnic-colleagues-wrap, .pnic-about-wrap, .pnic-booking-wrap, .pnic-faq-wrap { padding: 48px 0; }
    .pnic-diana-headline, .pnic-colleagues-headline, .pnic-about-headline { font-size: 26px; }
}