/* ===============================
   EXPRESSION COFFEE - COMMUNITY PAGE STYLES
   =============================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ===============================
   SECTION 1: HERO
   =============================== */
.exp-community-hero {
    background: #0f2d2e;
    padding: 120px 20px;
    text-align: center;
}
.exp-community-hero__container { max-width: 1200px; margin: 0 auto; }
.exp-community-hero__title {
    font-family: 'Inter', sans-serif;
    font-size: 86px; font-weight: 700; line-height: 1.1;
    color: #ffffff; margin: 0 0 24px 0; letter-spacing: -0.02em;
}
.exp-community-hero__subtitle {
    font-family: 'Inter', sans-serif;
    font-size: 18px; line-height: 1.6;
    color: rgba(255,255,255,0.9); margin: 0 auto; max-width: 700px;
}

/* ===============================
   SECTION 2: WHY JOIN
   =============================== */
.exp-community-why { background: #173d3e; padding: 100px 20px; }
.exp-community-why__container {
    max-width: 1200px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.exp-community-why__content { padding-right: 20px; }
.exp-community-why__eyebrow {
    font-family: 'Inter', sans-serif; font-size: 14px; letter-spacing: 0.15em;
    text-transform: uppercase; font-weight: 600; color: rgba(255,255,255,0.8); margin: 0 0 20px 0;
}
.exp-community-why__title {
    font-family: 'Inter', sans-serif; font-size: 68px; font-weight: 700;
    line-height: 1.15; color: #ffffff; margin: 0 0 24px 0; letter-spacing: -0.01em;
}
.exp-community-why__description {
    font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.7;
    color: rgba(255,255,255,0.9); margin: 0 0 32px 0;
}
.exp-community-why__list { list-style: none; padding: 0; margin: 0 0 40px 0; }
.exp-community-why__list-item {
    font-family: 'Inter', sans-serif; font-size: 17px; line-height: 1.6;
    color: rgba(255,255,255,0.9); margin: 0 0 12px 0;
    padding-left: 28px; position: relative;
}
.exp-community-why__list-item:before {
    content: "•"; position: absolute; left: 0;
    color: rgba(255,255,255,0.9); font-weight: 700; font-size: 24px;
}
.exp-community-why__image {
    width: 100%; aspect-ratio: 1; background: #d1d5db;
    border-radius: 16px; display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}

/* ===============================
   SECTION 3: BELONGING
   =============================== */
.exp-community-belonging { background: #ffffff; padding: 100px 20px; text-align: center; }
.exp-community-belonging__header { max-width: 800px; margin: 0 auto 60px auto; }
.exp-community-belonging__eyebrow {
    font-family: 'Inter', sans-serif; font-size: 14px; letter-spacing: 0.15em;
    text-transform: uppercase; font-weight: 600; color: #111111; margin: 0 0 20px 0;
}
.exp-community-belonging__title {
    font-family: 'Inter', sans-serif; font-size: 68px; font-weight: 700;
    line-height: 1.15; color: #111111; margin: 0 0 20px 0; letter-spacing: -0.01em;
}
.exp-community-belonging__description {
    font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.7; color: #555555; margin: 0;
}
.exp-community-belonging__grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px;
    max-width: 1200px; margin: 60px auto 0 auto;
}
.exp-community-pillar { text-align: center; }
.exp-community-pillar__image {
    width: 100%; max-width: 360px; aspect-ratio: 4/3; background: #d1d5db;
    border-radius: 16px; margin: 0 auto 24px auto; overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.exp-community-pillar__title {
    font-family: 'Inter', sans-serif; font-size: 28px; font-weight: 700;
    color: #111111; margin: 0 0 12px 0;
}
.exp-community-pillar__description {
    font-family: 'Inter', sans-serif; font-size: 17px; line-height: 1.6; color: #555555; margin: 0;
}

/* ===============================
   SECTION 4: REAL VOICES
   =============================== */
.exp-community-voices { background: #d8d9d9; padding: 100px 20px; }
.exp-community-voices__container { max-width: 1200px; margin: 0 auto; }
.exp-community-voices__header { margin-bottom: 60px; }
.exp-community-voices__title {
    font-family: 'Inter', sans-serif; font-size: 68px; font-weight: 700;
    line-height: 1.15; color: #111111; margin: 0 0 12px 0; text-align: left;
}
.exp-community-voices__subtitle {
    font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.6;
    color: #555555; margin: 0; text-align: left;
}
.exp-community-voices__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.exp-community-testimonial { display: flex; flex-direction: column; gap: 16px; }
.exp-community-testimonial__stars { display: flex; gap: 4px; color: #111111; }
.exp-community-testimonial__stars svg { width: 18px; height: 18px; }
.exp-community-testimonial__quote {
    font-family: 'Inter', sans-serif; font-size: 22px; font-weight: 700;
    line-height: 1.4; color: #111111; margin: 0;
}
.exp-community-testimonial__author { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
.exp-community-testimonial__avatar {
    width: 48px; height: 48px; border-radius: 50%; background: #c4c4c4; flex-shrink: 0;
}
.exp-community-testimonial__name {
    font-family: 'Inter', sans-serif; font-size: 16px; font-weight: 700; color: #111111; margin: 0;
}
.exp-community-testimonial__role {
    font-family: 'Inter', sans-serif; font-size: 15px; color: #555555; margin: 0;
}

/* ===============================
   SECTION 5: CTA
   =============================== */
.exp-community-cta { background: #ffffff; padding: 100px 20px; text-align: center; }
.exp-community-cta__container { max-width: 800px; margin: 0 auto; }
.exp-community-cta__title {
    font-family: 'Inter', sans-serif; font-size: 76px; font-weight: 700;
    line-height: 1.1; color: #111111; margin: 0 0 20px 0; letter-spacing: -0.02em;
}
.exp-community-cta__description {
    font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.7; color: #555555; margin: 0 0 0 0;
}

/* ===============================
   SECTION 6: MOMENTS SHARED
   =============================== */
.exp-community-moments { background: #ffffff; padding: 100px 20px; }
.exp-community-moments__container { max-width: 1400px; margin: 0 auto; }
.exp-community-moments__header {
    display: grid; grid-template-columns: 1fr auto;
    gap: 40px; align-items: center; margin-bottom: 60px;
}
.exp-community-moments__content { max-width: 500px; }
.exp-community-moments__title {
    font-family: 'Inter', sans-serif; font-size: 68px; font-weight: 700;
    line-height: 1.15; color: #111111; margin: 0 0 12px 0;
}
.exp-community-moments__description {
    font-family: 'Inter', sans-serif; font-size: 17px; line-height: 1.7; color: #555555; margin: 0;
}
.exp-community-moments__controls { display: flex; gap: 12px; }
.exp-community-moments__arrow {
    width: 54px; height: 54px; border-radius: 8px; background: transparent;
    border: 1px solid rgba(0,0,0,0.15); color: #111111; cursor: pointer;
    display: flex; align-items: center; justify-content: center; transition: all 0.2s ease;
}
.exp-community-moments__arrow:hover { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.25); }
.exp-community-moments__carousel {
    display: flex; gap: 24px; overflow-x: auto; scroll-behavior: smooth;
    scrollbar-width: none; -ms-overflow-style: none;
}
.exp-community-moments__carousel::-webkit-scrollbar { display: none; }
.exp-community-moment-card {
    flex: 0 0 auto; width: 500px; aspect-ratio: 1.5;
    background: #d1d5db; border-radius: 16px; overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.exp-community-moments__dots {
    display: flex; gap: 8px; justify-content: center; margin-top: 40px;
}
.exp-community-moments__dot {
    width: 10px; height: 10px; border-radius: 50%; background: rgba(0,0,0,0.2);
    border: none; cursor: pointer; transition: all 0.2s ease; padding: 0;
}
.exp-community-moments__dot:hover { background: rgba(0,0,0,0.4); }
.exp-community-moments__dot--active { background: #111111; }

/* ===============================
   SECTION 7: FAQ
   =============================== */
.exp-community-faq { background: #0f2d2e; padding: 100px 20px; }
.exp-community-faq__container { max-width: 900px; margin: 0 auto; }
.exp-community-faq__header { text-align: center; margin-bottom: 60px; }
.exp-community-faq__title {
    font-family: 'Inter', sans-serif; font-size: 68px; font-weight: 700;
    line-height: 1.2; color: #ffffff; margin: 0 0 16px 0;
}
.exp-community-faq__subtitle {
    font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.6;
    color: rgba(255,255,255,0.9); margin: 0;
}
.exp-community-faq__list { margin-bottom: 80px; }
.exp-community-faq-item { padding: 32px 0; border-bottom: 1px solid rgba(255,255,255,0.15); }
.exp-community-faq-item:first-child { padding-top: 0; }
.exp-community-faq-item__question {
    font-family: 'Inter', sans-serif; font-size: 22px; font-weight: 700;
    line-height: 1.4; color: #ffffff; margin: 0 0 12px 0;
}
.exp-community-faq-item__answer {
    font-family: 'Inter', sans-serif; font-size: 17px; line-height: 1.7;
    color: rgba(255,255,255,0.85); margin: 0;
}
.exp-community-faq__contact { text-align: center; }
.exp-community-faq__contact-title {
    font-family: 'Inter', sans-serif; font-size: 40px; font-weight: 700;
    line-height: 1.3; color: #ffffff; margin: 0 0 12px 0;
}
.exp-community-faq__contact-text {
    font-family: 'Inter', sans-serif; font-size: 17px; line-height: 1.6;
    color: rgba(255,255,255,0.85); margin: 0 0 24px 0;
}

/* ===============================
   BOTÓN ÚNICO POR SECCIÓN
   =============================== */
.exp-community-section-btn { margin-top: 40px; }
.exp-community-section-btn--center { display: flex; justify-content: center; }

/* ===============================
   BUTTONS
   =============================== */
.exp-community-button {
    font-family: 'Inter', sans-serif; padding: 16px 36px; font-size: 17px; font-weight: 600;
    border-radius: 8px; cursor: pointer; transition: all 0.2s ease;
    display: inline-flex; align-items: center; gap: 8px; text-decoration: none;
}
.exp-community-button--primary {
    background: linear-gradient(90deg, #0f766e, #a16207); color: #ffffff; border: none;
}
.exp-community-button--primary:hover { opacity: 0.9; }
.exp-community-button--outline {
    background: transparent; color: #ffffff; border: 1px solid rgba(255,255,255,0.3);
}
.exp-community-button--outline:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.5); }
.exp-community-button--outline-dark {
    background: transparent; color: #111111; border: 1px solid rgba(0,0,0,0.2);
}
.exp-community-button--outline-dark:hover { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.3); }

/* ===============================
   RESPONSIVE
   =============================== */
@media (max-width: 1024px) {
    .exp-community-hero__title     { font-size: 72px; }
    .exp-community-why__container  { grid-template-columns: 1fr; gap: 48px; }
    .exp-community-why__content    { padding-right: 0; }
    .exp-community-why__title      { font-size: 58px; }
    .exp-community-belonging__title { font-size: 58px; }
    .exp-community-voices__title   { font-size: 58px; }
    .exp-community-cta__title      { font-size: 68px; }
    .exp-community-moments__title  { font-size: 58px; }
    .exp-community-moment-card     { width: 400px; }
    .exp-community-faq__title      { font-size: 58px; }
    .exp-community-faq__contact-title { font-size: 34px; }
}

@media (max-width: 768px) {
    .exp-community-hero            { padding: 90px 24px; }
    .exp-community-hero__title     { font-size: 58px; }
    .exp-community-why             { padding: 80px 24px; }
    .exp-community-why__title      { font-size: 48px; }
    .exp-community-belonging       { padding: 80px 24px; }
    .exp-community-belonging__title { font-size: 48px; }
    .exp-community-belonging__grid { grid-template-columns: 1fr; gap: 48px; }
    .exp-community-voices          { padding: 80px 24px; }
    .exp-community-voices__title   { font-size: 48px; }
    .exp-community-voices__grid    { grid-template-columns: 1fr; gap: 40px; }
    .exp-community-cta             { padding: 80px 24px; }
    .exp-community-cta__title      { font-size: 58px; }
    .exp-community-moments         { padding: 80px 24px; }
    .exp-community-moments__title  { font-size: 48px; }
    .exp-community-moments__header { grid-template-columns: 1fr; gap: 32px; }
    .exp-community-moment-card     { width: 320px; }
    .exp-community-faq             { padding: 80px 24px; }
    .exp-community-faq__title      { font-size: 48px; }
    .exp-community-button          { width: 100%; justify-content: center; }
}

@media (max-width: 640px) {
    .exp-community-hero__title     { font-size: 48px; }
    .exp-community-why__title      { font-size: 40px; }
    .exp-community-belonging__title { font-size: 40px; }
    .exp-community-voices__title   { font-size: 40px; }
    .exp-community-cta__title      { font-size: 48px; }
    .exp-community-moments__title  { font-size: 40px; }
    .exp-community-moment-card     { width: 280px; }
    .exp-community-faq__title      { font-size: 40px; }
    .exp-community-faq-item__question { font-size: 20px; }
}

@media (max-width: 480px) {
    .exp-community-hero__title     { font-size: 40px; }
    .exp-community-cta__title      { font-size: 40px; }
}
