/**
 * Professional Bio Page - Clean & Trustworthy Design
 * 
 * Estilo enfocado en profesionalismo, limpieza, confianza y proporción.
 * Ideal para el sector salud/psicología. 100% Responsive.
 *
 * @package ConectaTerapia
 * @version 4.0.0
 */

/* ============================================
   VARIABLES Y CONFIGURACIÓN
   ============================================ */

.ct-bio-page {
    /* Brand Colors */
    --ct-primary: #50A4A7;
    --ct-primary-dark: #378689;
    --ct-primary-light: #e6f3f3;
    
    --ct-accent: #F59E0B;
    --ct-accent-light: #FFFBEB;
    --ct-accent-text: #B45309;
    
    --ct-success: #10B981;
    --ct-success-bg: #ECFDF5;
    --ct-success-text: #047857;

    /* Text Colors */
    --ct-text-main: #1E293B; /* Slate 800 */
    --ct-text-body: #475569; /* Slate 600 */
    --ct-text-muted: #64748B; /* Slate 500 */
    
    /* Backgrounds & Borders */
    --ct-bg-main: #F8FAFC; /* Slate 50 */
    --ct-bg-card: #FFFFFF;
    --ct-border-light: #F1F5F9; /* Slate 100 */
    --ct-border-base: #E2E8F0; /* Slate 200 */
    --ct-border-dark: #CBD5E1; /* Slate 300 */

    /* Shadows */
    --ct-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --ct-shadow-base: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    --ct-shadow-md: 0 10px 15px -3px rgba(0, 0, 0, 0.05), 0 4px 6px -2px rgba(0, 0, 0, 0.025);
    --ct-shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 10px 10px -5px rgba(0, 0, 0, 0.02);
    
    /* Structure */
    --ct-radius-sm: 8px;
    --ct-radius-md: 12px;
    --ct-radius-lg: 16px;
    --ct-radius-full: 9999px;
    
    --ct-transition: all 0.25s ease-in-out;
    
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    color: var(--ct-text-body);
    background-color: var(--ct-bg-main);
    line-height: 1.6;
}

.ct-bio-page * {
    box-sizing: border-box;
}

.ct-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.25rem;
}

@media (min-width: 768px) {
    .ct-container {
        padding: 0 2rem;
    }
}

/* ============================================
   TYPOGRAPHY & HEADINGS
   ============================================ */

.ct-bio-page h1, 
.ct-bio-page h2, 
.ct-bio-page h3, 
.ct-bio-page h4 {
    color: var(--ct-text-main);
    line-height: 1.3;
    margin-top: 0;
}

/* ============================================
   BOTONES
   ============================================ */

.ct-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border-radius: var(--ct-radius-md);
    font-family: inherit;
    font-weight: 600;
    font-size: 0.95rem;
    text-decoration: none;
    cursor: pointer;
    transition: var(--ct-transition);
    border: 1px solid transparent;
    line-height: 1.2;
}

.ct-btn--primary {
    background-color: var(--ct-primary);
    color: #FFFFFF;
    box-shadow: 0 2px 4px rgba(80, 164, 167, 0.2);
}

.ct-btn--primary:hover {
    background-color: var(--ct-primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(80, 164, 167, 0.3);
}

.ct-btn--secondary {
    background-color: var(--ct-bg-card);
    color: var(--ct-text-main);
    border-color: var(--ct-border-dark);
}

.ct-btn--secondary:hover {
    background-color: var(--ct-border-light);
    border-color: var(--ct-text-muted);
}

.ct-btn--outline {
    background-color: transparent;
    color: var(--ct-primary-dark);
    border-color: var(--ct-primary);
}

.ct-btn--outline:hover {
    background-color: var(--ct-primary-light);
}

.ct-btn--lg {
    padding: 0.875rem 1.75rem;
    font-size: 1rem;
}

.ct-btn--full {
    width: 100%;
}

/* ============================================
   HERO SECTION
   ============================================ */

.ct-bio-hero {
    background-color: var(--ct-bg-card);
    padding: 3rem 0;
    position: relative;
    border-bottom: 1px solid var(--ct-border-base);
}

.ct-bio-hero__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: center;
}

@media (min-width: 992px) {
    .ct-bio-hero {
        padding: 4rem 0 5rem;
    }
    .ct-bio-hero__grid {
        grid-template-columns: 1fr 400px;
        gap: 4rem;
    }
}

/* Hero Badge Area */
.ct-bio-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.ct-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    border-radius: var(--ct-radius-full);
    font-size: 0.8125rem;
    font-weight: 500;
}

.ct-badge--verified {
    background-color: var(--ct-success-bg);
    color: var(--ct-success-text);
}

.ct-badge--verified svg {
    color: var(--ct-success);
}

.ct-badge--specialty {
    background-color: var(--ct-accent-light);
    color: var(--ct-accent-text);
}

.ct-badge--available {
    background-color: var(--ct-bg-card);
    color: var(--ct-text-body);
    border: 1px solid var(--ct-border-base);
}

.ct-pulse {
    width: 8px;
    height: 8px;
    background-color: var(--ct-success);
    border-radius: 50%;
    animation: ct-pulse-dot 2s infinite;
}

@keyframes ct-pulse-dot {
    0% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.4); }
    70% { box-shadow: 0 0 0 6px rgba(16, 185, 129, 0); }
    100% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0); }
}

/* Title & Subtitle */
.ct-bio-hero__title {
    font-size: 2.25rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    letter-spacing: -0.01em;
}

.ct-bio-hero__subtitle {
    font-size: 1.125rem;
    color: var(--ct-primary-dark);
    font-weight: 500;
    margin-bottom: 1rem;
}

@media (min-width: 768px) {
    .ct-bio-hero__title {
        font-size: 2.75rem;
    }
}

/* Rating */
.ct-bio-rating {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1.25rem;
}

.ct-stars {
    display: flex;
    color: var(--ct-accent);
}

.ct-stars svg {
    width: 18px;
    height: 18px;
}

.ct-rating-text {
    font-size: 0.9rem;
    color: var(--ct-text-muted);
}

.ct-rating-text strong {
    color: var(--ct-text-main);
    font-weight: 600;
}

/* Hero Excerpt */
.ct-bio-hero__excerpt {
    font-size: 1rem;
    margin-bottom: 2rem;
    max-width: 90%;
}

/* Stats Row */
.ct-bio-stats {
    display: flex;
    gap: 2rem;
    margin-bottom: 2rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--ct-border-light);
}

.ct-bio-stat__value {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ct-text-main);
}

.ct-bio-stat__label {
    font-size: 0.85rem;
    color: var(--ct-text-muted);
}

.ct-bio-stat__icon {
    display: none; /* Hide emojis in stats for a cleaner look */
}

/* Actions */
.ct-bio-hero__actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

/* Image Visual */
.ct-bio-hero__visual {
    position: relative;
    padding: 0 1rem;
}

.ct-bio-image-wrapper {
    position: relative;
    max-width: 320px;
    margin: 0 auto;
}

.ct-bio-image {
    width: 100%;
    aspect-ratio: 4/5;
    object-fit: cover;
    border-radius: var(--ct-radius-lg);
    box-shadow: var(--ct-shadow-md);
    background-color: var(--ct-bg-main);
    display: block;
}

.ct-bio-floating-card {
    position: absolute;
    bottom: -1rem;
    left: -1.5rem;
    background-color: var(--ct-bg-card);
    padding: 0.75rem 1rem;
    border-radius: var(--ct-radius-md);
    box-shadow: var(--ct-shadow-base);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border: 1px solid var(--ct-border-light);
}

.ct-bio-floating-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background-color: var(--ct-primary-light);
    color: var(--ct-primary-dark);
    border-radius: 50%;
    font-size: 0.85rem;
}

.ct-bio-floating-card strong {
    display: block;
    font-size: 0.85rem;
    color: var(--ct-text-main);
    line-height: 1.2;
}

.ct-bio-floating-card span {
    font-size: 0.75rem;
    color: var(--ct-text-muted);
}

@media (max-width: 991px) {
    .ct-bio-hero__visual {
        order: -1; /* Pone la imagen arriba en móviles */
    }
    .ct-bio-stats {
        flex-wrap: wrap;
        gap: 1.5rem;
    }
    .ct-bio-floating-card {
        left: 50%;
        transform: translateX(-50%);
        bottom: -1.5rem;
        width: max-content;
    }
}

/* ============================================
   CONTENT LAYOUT
   ============================================ */

.ct-bio-content {
    padding: 3rem 0 5rem;
}

.ct-bio-content__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 1024px) {
    .ct-bio-content {
        padding: 4rem 0 6rem;
    }
    .ct-bio-content__grid {
        grid-template-columns: 250px 1fr 320px;
        gap: 2.5rem;
        align-items: start;
    }
}

/* ============================================
   SIDEBARS & CARDS
   ============================================ */

.ct-bio-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.ct-bio-card {
    background-color: var(--ct-bg-card);
    border-radius: var(--ct-radius-md);
    padding: 1.5rem;
    box-shadow: var(--ct-shadow-sm);
    border: 1px solid var(--ct-border-base);
}

.ct-bio-card--sticky {
    position: sticky;
    top: 2rem;
}

.ct-bio-card--highlight {
    border-top: 4px solid var(--ct-primary);
}

.ct-bio-card__title {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid var(--ct-border-light);
    padding-bottom: 0.75rem;
}

/* Sidebar Info List */
.ct-bio-info-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
}

.ct-bio-info-list li {
    display: flex;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--ct-border-light);
}

.ct-bio-info-list li:last-child {
    border-bottom: none;
}

.ct-bio-info-list__icon {
    display: none; /* Hide emojis for a cleaner look */
}

.ct-bio-info-list strong {
    display: block;
    font-size: 0.75rem;
    color: var(--ct-text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

.ct-bio-info-list span {
    font-size: 0.95rem;
    color: var(--ct-text-main);
    font-weight: 500;
}

/* Sidebar Tags & Certifications */
.ct-bio-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ct-bio-tag {
    display: inline-block;
    padding: 0.35rem 0.85rem;
    background-color: var(--ct-bg-main);
    color: var(--ct-text-body);
    border-radius: var(--ct-radius-full);
    font-size: 0.85rem;
    border: 1px solid var(--ct-border-base);
}

.ct-bio-certifications {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ct-bio-certification {
    padding: 0.75rem;
    background-color: var(--ct-bg-main);
    border-radius: var(--ct-radius-sm);
    font-size: 0.875rem;
    color: var(--ct-text-body);
}

.ct-bio-certification__icon {
    display: none; /* Hide emojis */
}

/* ============================================
   PRICING CARD (RIGHT SIDEBAR)
   ============================================ */

.ct-bio-card__price {
    text-align: center;
    margin-bottom: 1.25rem;
}

.ct-bio-card__price-label {
    display: block;
    font-size: 0.875rem;
    color: var(--ct-text-muted);
    margin-bottom: 0.25rem;
}

.ct-bio-card__price-value {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 0.2rem;
    color: var(--ct-text-main);
}

.ct-currency {
    font-size: 1.25rem;
    font-weight: 600;
    margin-top: 0.25rem;
}

.ct-amount {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1;
}

.ct-bio-card__price-period {
    display: block;
    font-size: 0.875rem;
    color: var(--ct-text-muted);
    margin-top: 0.5rem;
}

.ct-bio-card__features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.ct-bio-card__features li {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.9rem;
    color: var(--ct-text-body);
    margin-bottom: 0.75rem;
}

.ct-bio-card__features svg {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    color: var(--ct-success);
    margin-top: 0.125rem;
}

.ct-bio-card__note {
    font-size: 0.8rem;
    color: var(--ct-text-muted);
    text-align: center;
    margin-top: 1rem;
    line-height: 1.4;
}

/* ============================================
   MAIN CONTENT AREA
   ============================================ */

.ct-bio-main {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.ct-bio-section {
    background-color: var(--ct-bg-card);
    border-radius: var(--ct-radius-md);
    padding: 2rem;
    box-shadow: var(--ct-shadow-sm);
    border: 1px solid var(--ct-border-base);
}

.ct-bio-section__title {
    font-size: 1.35rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
}

.ct-bio-section__content {
    font-size: 0.95rem;
}

.ct-bio-section__content p {
    margin-bottom: 1rem;
}

.ct-bio-section__content p:last-child {
    margin-bottom: 0;
}

/* Approach Columns */
.ct-bio-approach {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .ct-bio-approach {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ct-bio-approach__item {
    background-color: var(--ct-bg-main);
    padding: 1.25rem;
    border-radius: var(--ct-radius-sm);
    border: 1px solid var(--ct-border-base);
}

.ct-bio-approach__icon {
    display: none; /* Hide emojis */
}

.ct-bio-approach__item h4 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.ct-bio-approach__item p {
    font-size: 0.875rem;
    margin: 0;
}

/* Services */
.ct-bio-services {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.ct-bio-service-card {
    padding: 1.25rem;
    border: 1px solid var(--ct-border-base);
    border-radius: var(--ct-radius-sm);
}

.ct-bio-service-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.ct-bio-service-card__header h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
}

.ct-bio-service-card__price {
    font-weight: 600;
    color: var(--ct-primary-dark);
}

.ct-bio-service-card p {
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
}

.ct-bio-service-card__duration {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.8rem;
    color: var(--ct-text-muted);
}

/* Reviews */
.ct-bio-reviews-summary {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--ct-border-light);
}

.ct-bio-reviews-summary__number {
    font-size: 3rem;
    font-weight: 700;
    color: var(--ct-text-main);
    line-height: 1;
}

.ct-bio-reviews-summary .ct-stars {
    margin-bottom: 0.25rem;
}

.ct-bio-reviews-summary span:last-child {
    font-size: 0.875rem;
    color: var(--ct-text-muted);
}

.ct-bio-reviews-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.ct-bio-review {
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--ct-border-light);
}

.ct-bio-review:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.ct-bio-review__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.ct-bio-review__avatar {
    width: 36px;
    height: 36px;
    background-color: var(--ct-primary-light);
    color: var(--ct-primary-dark);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.9rem;
}

.ct-bio-review__meta strong {
    display: block;
    font-size: 0.95rem;
    color: var(--ct-text-main);
}

.ct-bio-review__date {
    margin-left: auto;
    font-size: 0.8rem;
    color: var(--ct-text-muted);
}

.ct-bio-review__text {
    font-size: 0.9rem;
    margin: 0;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 1023px) {
    .ct-bio-sidebar--left {
        order: 2;
    }
    .ct-bio-main {
        order: 1;
    }
    .ct-bio-sidebar--right {
        order: 3;
    }
}

@media (max-width: 767px) {
    .ct-bio-hero__actions {
        flex-direction: column;
    }
    .ct-bio-hero__actions .ct-btn {
        width: 100%;
    }
    .ct-bio-section {
        padding: 1.5rem;
    }
    .ct-bio-reviews-summary {
        flex-direction: column;
        text-align: center;
        gap: 0.5rem;
    }
    .ct-bio-review__header {
        flex-wrap: wrap;
    }
    .ct-bio-review__date {
        margin-left: 0;
        width: 100%;
        padding-left: calc(36px + 0.75rem); /* avatar width + gap */
        margin-top: -0.25rem;
    }
}
