*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

        :root {
          --cream: #f5f0e8;
          --cream-dark: #ede5d5;
          --warm-brown: #6b4f3a;
          --dark-brown: #3a2a1e;
          --forest-green: #3d5a3e;
          --forest-green-light: #4e7050;
          --text-body: #5a4535;
          --text-light: #8a7060;
          --section-divider: #c8b89a;
          --font-serif: 'Cormorant Garamond', Georgia, serif;
          --font-body: 'EB Garamond', Georgia, serif;
        }

        html { scroll-behavior: smooth; }
        body {
          font-family: var(--font-body);
          background-color: var(--cream);
          color: var(--text-body);
          overflow-x: hidden;
        }

        /* ====== HERO ====== */
        .hero {
          margin-top: 61px;
          position: relative;
          overflow: hidden;
          min-height: 340px;
          max-height: 460px;
          display: flex;
          align-items: center;
          justify-content: center;
        }
        .hero-bg {
          position: absolute; inset: 0;
          background:
            linear-gradient(to bottom, rgba(20,15,8,0.25) 0%, rgba(20,15,8,0.55) 100%),
            /*url('https://images.unsplash.com/photo-1529156069898-49953e39b3ac?w=1400&q=80') center/cover no-repeat;*/
            url('../img/comunitat_nou.avif') center/cover no-repeat;
          transition: transform 6s ease-out;
        }
        .hero-content {
          position: relative; z-index: 2;
          text-align: center; color: #fff;
          padding: 64px 24px;
          animation: fadeUp 0.9s ease both;
        }
        .hero-title {
          font-family: var(--font-serif);
          font-size: clamp(2.4rem, 6vw, 4rem);
          font-weight: 400; letter-spacing: 0.04em;
          text-shadow: 0 2px 16px rgba(0,0,0,0.3);
          margin-bottom: 0.3em;
        }
        .hero-subtitle {
          font-family: var(--font-serif);
          font-style: italic;
          font-size: clamp(1rem, 2vw, 1.3rem);
          font-weight: 300; opacity: 0.92;
          text-shadow: 0 1px 8px rgba(0,0,0,0.25);
        }

        @keyframes fadeUp {
          from { opacity: 0; transform: translateY(22px); }
          to   { opacity: 1; transform: translateY(0); }
        }

        /* ====== PAGE WRAPPER ====== */
        .page {
          max-width: 1060px;
          margin: 0 auto;
          padding: 0 24px 80px;
        }

        /* ====== DIVIDER ====== */
        .divider-diamond {
          display: flex; align-items: center; justify-content: center;
          gap: 0; margin: 48px 0 40px;
        }
        .divider-diamond .line {
          height: 1px; flex: 1;
          background: var(--section-divider);
          max-width: 140px;
        }
        .divider-diamond .diamond {
          width: 8px; height: 8px;
          background: var(--section-divider);
          transform: rotate(45deg);
          margin: 0 12px; flex-shrink: 0;
        }

        /* ====== TABS ====== */
        .tabs-wrap {
          display: flex;
          align-items: center;
          justify-content: center;
          gap: 4px;
          margin-bottom: 48px;
          background: var(--cream-dark);
          border-radius: 100px;
          padding: 5px;
          max-width: 360px;
          margin-left: auto;
          margin-right: auto;
        }

        .tab-btn {
          flex: 1;
          padding: 10px 20px;
          background: none;
          border: none;
          border-radius: 100px;
          font-family: var(--font-body);
          font-size: 0.97rem;
          letter-spacing: 0.05em;
          color: var(--text-light);
          cursor: pointer;
          transition: background 0.25s, color 0.25s;
          white-space: nowrap;
        }
        .tab-btn.active {
          background: #fff;
          color: var(--dark-brown);
          box-shadow: 0 2px 12px rgba(58,42,30,0.1);
        }
        .tab-btn:hover:not(.active) { color: var(--text-body); }

        /* ====== TAB PANELS ====== */
        .tab-panel { display: none; }
        .tab-panel.active { display: block; animation: fadeUp 0.5s ease both; }

        /* ====== FEATURED ARTICLE ====== */
        .featured-article {
          display: grid;
          grid-template-columns: 1fr 1fr;
          gap: 40px;
          align-items: center;
          background: #fff;
          border-radius: 16px;
          overflow: hidden;
          box-shadow: 0 6px 32px rgba(58,42,30,0.08);
          margin-bottom: 48px;
          transition: box-shadow 0.3s, transform 0.3s;
          cursor: pointer;
          text-decoration: none;
          color: inherit;
        }
        .featured-article:hover {
          box-shadow: 0 16px 48px rgba(58,42,30,0.13);
          transform: translateY(-4px);
        }
        .featured-img-wrap {
          aspect-ratio: 4/3;
          overflow: hidden;
        }
        .featured-img-wrap img {
          width: 100%; height: 100%;
          object-fit: cover; display: block;
          filter: sepia(0.08) brightness(0.95);
          transition: transform 0.5s ease;
        }
        .featured-article:hover .featured-img-wrap img { transform: scale(1.05); }

        .featured-body { padding: 36px 36px 36px 0; }
        .article-tag {
          display: inline-block;
          font-family: var(--font-body);
          font-size: 0.78rem;
          letter-spacing: 0.1em;
          text-transform: uppercase;
          color: var(--forest-green);
          margin-bottom: 12px;
        }
        .featured-body h2 {
          font-family: var(--font-serif);
          font-size: clamp(1.4rem, 2.5vw, 1.9rem);
          font-weight: 400;
          color: var(--dark-brown);
          line-height: 1.3;
          margin-bottom: 14px;
          letter-spacing: 0.02em;
        }
        .featured-body p {
          font-family: var(--font-body);
          font-size: 1rem;
          color: var(--text-light);
          line-height: 1.8;
          margin-bottom: 20px;
        }
        .read-link {
          display: inline-flex;
          align-items: center;
          gap: 6px;
          font-family: var(--font-body);
          font-size: 0.95rem;
          color: var(--forest-green);
          text-decoration: none;
          letter-spacing: 0.04em;
          transition: gap 0.2s, color 0.2s;
        }
        .read-link:hover { gap: 10px; color: var(--forest-green-light); }
        .read-link-arrow { font-size: 1rem; }

        /* ====== ARTICLES GRID ====== */
        .articles-grid {
          display: grid;
          grid-template-columns: repeat(3, 1fr);
          gap: 24px;
        }

        .article-card {
          background: #fff;
          border-radius: 12px;
          overflow: hidden;
          box-shadow: 0 4px 20px rgba(58,42,30,0.07);
          display: flex; flex-direction: column;
          text-decoration: none; color: inherit;
          transition: transform 0.3s ease, box-shadow 0.3s ease;
          cursor: pointer;
        }
        .article-card:hover {
          transform: translateY(-5px);
          box-shadow: 0 14px 40px rgba(58,42,30,0.13);
        }
        .card-img-wrap {
          aspect-ratio: 3/2;
          overflow: hidden;
        }
        .card-img-wrap img {
          width: 100%; height: 100%;
          object-fit: cover; display: block;
          filter: sepia(0.08) brightness(0.95);
          transition: transform 0.5s ease;
        }
        .article-card:hover .card-img-wrap img { transform: scale(1.06); }

        .card-body {
          padding: 20px 20px 24px;
          flex: 1; display: flex; flex-direction: column;
        }
        .card-tag {
          font-family: var(--font-body);
          font-size: 0.75rem;
          letter-spacing: 0.1em;
          text-transform: uppercase;
          color: var(--forest-green);
          margin-bottom: 8px;
        }
        .card-title {
          font-family: var(--font-serif);
          font-size: 1.15rem; font-weight: 400;
          color: var(--dark-brown);
          line-height: 1.35; margin-bottom: 10px;
          letter-spacing: 0.01em;
          flex: 1;
        }
        .card-excerpt {
          font-family: var(--font-body);
          font-size: 0.92rem;
          color: var(--text-light);
          line-height: 1.7;
          margin-bottom: 16px;
          display: -webkit-box;
          -webkit-line-clamp: 2;
          -webkit-box-orient: vertical;
          overflow: hidden;
        }
        .card-meta {
          font-family: var(--font-body);
          font-size: 0.82rem;
          color: var(--section-divider);
          letter-spacing: 0.04em;
          margin-top: auto;
        }

        /* ====== VIDEO GRID ====== */
        .videos-grid {
          display: grid;
          grid-template-columns: repeat(2, 1fr);
          gap: 28px;
        }

        .video-card {
          background: #fff;
          border-radius: 12px;
          overflow: hidden;
          box-shadow: 0 4px 20px rgba(58,42,30,0.07);
          transition: transform 0.3s ease, box-shadow 0.3s ease;
          cursor: pointer;
        }
        .video-card:hover {
          transform: translateY(-5px);
          box-shadow: 0 14px 40px rgba(58,42,30,0.13);
        }

        .video-thumb {
          position: relative;
          aspect-ratio: 16/9;
          overflow: hidden;
          background: var(--dark-brown);
        }
        .video-thumb img {
          width: 100%; height: 100%;
          object-fit: cover; display: block;
          filter: sepia(0.1) brightness(0.8);
          transition: transform 0.5s ease, filter 0.3s;
        }
        .video-card:hover .video-thumb img {
          transform: scale(1.04);
          filter: sepia(0.05) brightness(0.9);
        }

        /* Play button overlay */
        .play-btn {
          position: absolute;
          top: 50%; left: 50%;
          transform: translate(-50%, -50%);
          width: 56px; height: 56px;
          background: rgba(255,255,255,0.92);
          border-radius: 50%;
          display: flex; align-items: center; justify-content: center;
          transition: transform 0.25s ease, background 0.2s;
          box-shadow: 0 4px 20px rgba(0,0,0,0.25);
        }
        .play-btn::after {
          content: '';
          display: block;
          width: 0; height: 0;
          border-style: solid;
          border-width: 9px 0 9px 16px;
          border-color: transparent transparent transparent var(--forest-green);
          margin-left: 3px;
        }
        .video-card:hover .play-btn {
          transform: translate(-50%, -50%) scale(1.1);
          background: #fff;
        }

        .video-duration {
          position: absolute;
          bottom: 10px; right: 12px;
          background: rgba(20,12,6,0.72);
          color: #fff;
          font-family: var(--font-body);
          font-size: 0.78rem;
          padding: 3px 8px;
          border-radius: 4px;
          letter-spacing: 0.04em;
        }

        .video-body { padding: 18px 20px 22px; }
        .video-tag {
          font-family: var(--font-body);
          font-size: 0.75rem;
          letter-spacing: 0.1em;
          text-transform: uppercase;
          color: var(--forest-green);
          margin-bottom: 7px;
        }
        .video-title {
          font-family: var(--font-serif);
          font-size: 1.1rem; font-weight: 400;
          color: var(--dark-brown);
          line-height: 1.35; margin-bottom: 8px;
        }
        .video-desc {
          font-family: var(--font-body);
          font-size: 0.92rem;
          color: var(--text-light);
          line-height: 1.7;
          display: -webkit-box;
          -webkit-line-clamp: 2;
          -webkit-box-orient: vertical;
          overflow: hidden;
        }

        /* ====== VIDEO MODAL ====== */
        .modal-overlay {
          display: none;
          position: fixed; inset: 0;
          background: rgba(20,12,6,0.82);
          z-index: 200;
          align-items: center;
          justify-content: center;
          padding: 24px;
          backdrop-filter: blur(4px);
          animation: fadeIn 0.25s ease both;
        }
        .modal-overlay.open { display: flex; }

        @keyframes fadeIn {
          from { opacity: 0; }
          to   { opacity: 1; }
        }

        .modal-box {
          width: 100%; max-width: 800px;
          background: var(--dark-brown);
          border-radius: 14px;
          overflow: hidden;
          position: relative;
          animation: scaleIn 0.3s ease both;
        }
        @keyframes scaleIn {
          from { opacity: 0; transform: scale(0.93); }
          to   { opacity: 1; transform: scale(1); }
        }

        .modal-close {
          position: absolute;
          top: 12px; right: 14px;
          background: rgba(255,255,255,0.12);
          border: none; border-radius: 50%;
          width: 36px; height: 36px;
          color: #fff; font-size: 1.1rem;
          cursor: pointer; z-index: 2;
          display: flex; align-items: center; justify-content: center;
          transition: background 0.2s;
        }
        .modal-close:hover { background: rgba(255,255,255,0.25); }

        .modal-video {
          width: 100%;
          aspect-ratio: 16/9;
          display: block;
          background: #000;
        }
        .modal-video iframe {
          width: 100%; height: 100%;
          border: none; display: block;
        }

        /* ====== NEWSLETTER ====== */
        .newsletter-wrap {
          margin-top: 72px;
          background: var(--dark-brown);
          border-radius: 20px;
          padding: 56px 48px;
          text-align: center;
          position: relative;
          overflow: hidden;
        }
        /* Subtle texture */
        .newsletter-wrap::before {
          content: '';
          position: absolute; inset: 0;
          background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
          opacity: 0.3; pointer-events: none;
        }

        .newsletter-eyebrow {
          font-family: var(--font-body);
          font-size: 0.8rem;
          letter-spacing: 0.14em;
          text-transform: uppercase;
          color: var(--section-divider);
          margin-bottom: 14px;
          position: relative;
        }
        .newsletter-title {
          font-family: var(--font-serif);
          font-size: clamp(1.7rem, 3.5vw, 2.4rem);
          font-weight: 400;
          color: #fff;
          letter-spacing: 0.03em;
          margin-bottom: 12px;
          position: relative;
        }
        .newsletter-desc {
          font-family: var(--font-serif);
          font-style: italic;
          font-size: clamp(0.97rem, 1.5vw, 1.1rem);
          color: rgba(255,255,255,0.65);
          line-height: 1.7;
          max-width: 440px;
          margin: 0 auto 32px;
          position: relative;
        }

        .newsletter-form {
          display: flex;
          gap: 10px;
          max-width: 440px;
          margin: 0 auto;
          position: relative;
        }
        .newsletter-input {
          flex: 1;
          padding: 13px 18px;
          background: rgba(255,255,255,0.1);
          border: 1.5px solid rgba(255,255,255,0.2);
          border-radius: 100px;
          font-family: var(--font-body);
          font-size: 1rem;
          color: #fff;
          outline: none;
          transition: border-color 0.25s, background 0.2s;
        }
        .newsletter-input::placeholder { color: rgba(255,255,255,0.4); }
        .newsletter-input:focus {
          border-color: rgba(255,255,255,0.5);
          background: rgba(255,255,255,0.15);
        }

        .newsletter-btn {
          padding: 13px 26px;
          background: var(--forest-green);
          color: #fff;
          font-family: var(--font-body);
          font-size: 0.97rem;
          letter-spacing: 0.06em;
          border: none; border-radius: 100px;
          cursor: pointer; white-space: nowrap;
          transition: background 0.3s, transform 0.2s;
          flex-shrink: 0;
        }
        .newsletter-btn:hover {
          background: var(--forest-green-light);
          transform: translateY(-2px);
        }

        .newsletter-note {
          margin-top: 14px;
          font-family: var(--font-serif);
          font-style: italic;
          font-size: 0.82rem;
          color: rgba(255,255,255,0.35);
          position: relative;
        }

        .newsletter-success {
          display: none;
          font-family: var(--font-serif);
          font-style: italic;
          font-size: 1.1rem;
          color: rgba(255,255,255,0.8);
          animation: fadeUp 0.5s ease both;
          position: relative;
        }
        .newsletter-success.visible { display: block; }

        /* ====== COMING SOON BAND ====== */
        .coming-soon-band {
          margin-top: 56px;
          padding: 36px 32px;
          background: var(--cream-dark);
          border-radius: 14px;
          border: 1px solid var(--section-divider);
          display: flex;
          align-items: center;
          gap: 28px;
        }
        .coming-soon-icon {
          font-size: 2.2rem;
          flex-shrink: 0;
        }
        .coming-soon-text h3 {
          font-family: var(--font-serif);
          font-size: 1.3rem; font-weight: 400;
          color: var(--dark-brown);
          margin-bottom: 6px;
        }
        .coming-soon-text p {
          font-family: var(--font-body);
          font-size: 0.97rem;
          color: var(--text-light);
          line-height: 1.7;
        }
        .coming-soon-text p em { font-style: italic; }

        /* ====== EVENT CARDS ====== */
                .events-grid {
                  display: grid;
                  grid-template-columns: repeat(2, 1fr);
                  gap: 24px;
                }

                .event-card {
                  background: #fff;
                  border-radius: 14px;
                  overflow: hidden;
                  box-shadow: 0 4px 20px rgba(58,42,30,0.07);
                  display: flex; flex-direction: column;
                  transition: transform 0.3s ease, box-shadow 0.3s ease;
                  position: relative;
                }
                .event-card:hover {
                  transform: translateY(-5px);
                  box-shadow: 0 14px 40px rgba(58,42,30,0.13);
                }
                .event-card.sold-out { opacity: 0.72; }

                .event-img-wrap {
                  aspect-ratio: 16/7;
                  overflow: hidden;
                  position: relative;
                }
                .event-img-wrap img {
                  width: 100%; height: 100%;
                  object-fit: cover; display: block;
                  filter: sepia(0.08) brightness(0.92);
                  transition: transform 0.5s ease;
                }
                .event-card:hover .event-img-wrap img { transform: scale(1.05); }

                /* Status badge on image */
                .event-status {
                  position: absolute; top: 14px; left: 14px;
                  font-family: var(--font-body); font-size: 0.75rem;
                  letter-spacing: 0.1em; text-transform: uppercase;
                  padding: 5px 14px; border-radius: 100px;
                  font-weight: 500;
                }
                .event-status.upcoming {
                  background: var(--forest-green); color: #fff;
                }
                .event-status.past {
                  background: rgba(58,42,30,0.55); color: rgba(255,255,255,0.85);
                }
                .event-status.sold-out-badge {
                  background: var(--warm-brown); color: #fff;
                }

                .event-body {
                  padding: 22px 22px 26px;
                  flex: 1; display: flex; flex-direction: column; gap: 10px;
                }

                .event-meta-row {
                  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
                }
                .event-type {
                  font-family: var(--font-body); font-size: 0.75rem;
                  letter-spacing: 0.1em; text-transform: uppercase;
                  color: var(--forest-green);
                }
                .event-date {
                  font-family: var(--font-body); font-size: 0.82rem;
                  color: var(--text-light); letter-spacing: 0.04em;
                  display: flex; align-items: center; gap: 5px;
                }

                .event-title {
                  font-family: var(--font-serif);
                  font-size: clamp(1.1rem, 2vw, 1.3rem);
                  font-weight: 400; color: var(--dark-brown);
                  line-height: 1.3; letter-spacing: 0.01em;
                }

                .event-desc {
                  font-family: var(--font-body); font-size: 0.93rem;
                  color: var(--text-light); line-height: 1.7;
                  display: -webkit-box;
                  -webkit-line-clamp: 2;
                  -webkit-box-orient: vertical;
                  overflow: hidden;
                  flex: 1;
                }

                .event-footer {
                  display: flex; align-items: center;
                  justify-content: space-between; gap: 12px;
                  margin-top: 6px; flex-wrap: wrap;
                }

                .event-price-wrap { display: flex; flex-direction: column; gap: 1px; }
                .event-price {
                  font-family: var(--font-serif);
                  font-size: 1.4rem; font-weight: 400; color: var(--dark-brown); line-height: 1;
                }
                .event-price-note {
                  font-family: var(--font-body); font-size: 0.78rem; color: var(--text-light);
                }

                .event-btn {
                  display: inline-flex; align-items: center; gap: 6px;
                  padding: 10px 20px;
                  font-family: var(--font-body); font-size: 0.9rem;
                  letter-spacing: 0.05em; border-radius: 100px;
                  text-decoration: none; border: none; cursor: pointer;
                  transition: background 0.3s, color 0.3s, transform 0.2s;
                  white-space: nowrap;
                }
                .event-btn-primary {
                  background: var(--forest-green); color: #fff;
                  box-shadow: 0 3px 14px rgba(61,90,62,0.22);
                }
                .event-btn-primary:hover { background: var(--forest-green-light); transform: translateY(-2px); }
                .event-btn-disabled {
                  background: var(--cream-dark); color: var(--text-light);
                  cursor: not-allowed;
                }
                .event-btn-past {
                  background: transparent; color: var(--text-light);
                  border: 1.5px solid var(--section-divider);
                }
                .event-btn-past:hover { border-color: var(--text-light); color: var(--text-body); }

                .event-spots {
                  font-family: var(--font-body); font-size: 0.8rem;
                  color: var(--warm-brown); letter-spacing: 0.04em;
                  display: flex; align-items: center; gap: 5px;
                }
                .event-spots::before {
                  content: '';
                  display: inline-block; width: 6px; height: 6px;
                  border-radius: 50%; background: var(--warm-brown);
                }

        /* ====== SCROLL REVEAL ====== */
        .reveal {
          opacity: 0; transform: translateY(22px);
          transition: opacity 0.7s ease, transform 0.7s ease;
        }
        .reveal.visible { opacity: 1; transform: none; }
        .reveal-delay-1 { transition-delay: 0.1s; }
        .reveal-delay-2 { transition-delay: 0.2s; }
        .reveal-delay-3 { transition-delay: 0.3s; }

        /* ====== RESPONSIVE ====== */
        @media (max-width: 767px) {
          .featured-article {
            grid-template-columns: 1fr;
          }
          .featured-body { padding: 24px 24px 28px; }

          .articles-grid { grid-template-columns: 1fr; }
          .videos-grid   { grid-template-columns: 1fr; }
          .events-grid   { grid-template-columns: 1fr; }

          .newsletter-wrap { padding: 40px 24px; border-radius: 14px; }
          .newsletter-form { flex-direction: column; }
          .newsletter-btn  { width: 100%; text-align: center; }

          .coming-soon-band { flex-direction: column; text-align: center; gap: 16px; }

          .tabs-wrap { max-width: 100%; }
        }

        @media (min-width: 768px) and (max-width: 1023px) {
          .articles-grid { grid-template-columns: repeat(2, 1fr); }
        }

        @media (min-width: 1024px) {
          .page { padding: 0 48px 80px; }
        }