/* ═══════════════════════════════════════════════════════════════
   Casal d'Estiu GASC — Landing v2
   Tokens: navy primary + yellow accent + Fraunces / Inter
   ═══════════════════════════════════════════════════════════════ */

:root {
	/* Brand — tokens from prototype tweaks defaults */
	--c-primary:    #2BA8A6;
	--c-primary-10: rgba(43,168,166,0.10);
	--c-primary-18: rgba(43,168,166,0.22);
	--c-primary-deep: #1F8786;
	--c-accent:     #F26B3A;
	--c-accent-10:  rgba(242,107,58,0.10);
	--c-accent-deep:#D4521D;
	--c-navy:       #15294B;
	--c-yellow:     #FFCB4D;
	--c-teal:       #2BA8A6;
	--c-orange:     #F26B3A;
	--c-sky:        #3389D9;
	--c-coral:      #F273A6;
	--c-green:      #7BB93F;
	--c-purple:     #7A3FB8;

	/* Neutrals */
	--c-paper:  #FAF7F2;
	--c-paper2: #F3EEE5;
	--c-white:  #FFFFFF;
	--c-ink:    #1A1F2E;
	--c-ink2:   #3A4358;
	--c-muted:  #6B7280;
	--c-line:   #E7E2D7;
	--c-line2:  #D9D2C2;

	/* Tints / status */
	--c-ok:     #1F8A5B;
	--c-warn:   #E07A1A;
	--c-bad:    #D14343;
	--c-ok-bg:  #E3F3EA;
	--c-warn-bg:#FCEED7;
	--c-bad-bg: #FBE1E1;
	--c-sky-bg: #E6F1FC;
	--c-yellow-bg:#FFF4D6;
	--c-teal-bg:#DCF1F0;

	/* Type — Nunito (display + body) per prototype tweak defaults */
	--font-display: 'Nunito', system-ui, -apple-system, sans-serif;
	--font-body:    'Nunito', system-ui, -apple-system, sans-serif;

	/* Radii */
	--r-sm: 10px;
	--r-md: 16px;
	--r-lg: 22px;
	--r-xl: 28px;
	--r-pill: 999px;

	/* Spacing scale */
	--sp-1: 4px;
	--sp-2: 8px;
	--sp-3: 12px;
	--sp-4: 16px;
	--sp-5: 20px;
	--sp-6: 24px;
	--sp-8: 32px;
	--sp-10: 40px;
	--sp-12: 48px;
	--sp-16: 64px;
	--sp-20: 80px;
	--sp-24: 96px;

	/* Shadows */
	--sh-sm: 0 1px 2px rgba(20,30,50,0.05), 0 2px 8px rgba(20,30,50,0.04);
	--sh-md: 0 4px 12px rgba(20,30,50,0.07), 0 2px 6px rgba(20,30,50,0.04);
	--sh-lg: 0 12px 32px rgba(20,30,50,0.10), 0 4px 10px rgba(20,30,50,0.05);
	--sh-xl: 0 24px 60px rgba(20,30,50,0.18);
	--sh-photo: 0 30px 60px rgba(20,30,50,0.18);

	/* Misc */
	--container: 1240px;
	--container-narrow: 880px;
	--container-px: 28px;
	--dur: .25s;
	--ease: cubic-bezier(.4, 0, .2, 1);
}

/* ── Reset ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.55;
	color: var(--c-ink);
	background: var(--c-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
ul, ol { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4 { margin: 0; }
p { margin: 0; }
::selection { background: var(--c-accent); color: #fff; }
::-moz-selection { background: var(--c-accent); color: #fff; }
:focus-visible { outline: 3px solid color-mix(in oklab, var(--c-primary) 60%, white); outline-offset: 2px; border-radius: 4px; }

/* ── Layout helpers ────────────────────────────────────────────── */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--container-px); }
.container--narrow { max-width: var(--container-narrow); }

/* ── Typography ────────────────────────────────────────────────── */
.h-display {
	font-family: var(--font-display);
	font-weight: 800;
	color: var(--c-primary);
	letter-spacing: -0.025em;
	line-height: 1.05;
	font-size: clamp(2rem, 4.4vw, 3.5rem);
	text-wrap: balance;
}
.eyebrow {
	display: inline-flex; align-items: center; gap: var(--sp-2);
	font-family: var(--font-body);
	font-size: 12px; font-weight: 700; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--c-primary);
}
.eyebrow > i { display: inline-block; width: 22px; height: 2px; background: var(--c-accent); }
.eyebrow--light { color: #fff; }
.eyebrow--light > i { background: rgba(255,255,255,0.7); }
.block-head { margin-bottom: var(--sp-12); max-width: 720px; }
.block-head--center { margin-inline: auto; text-align: center; }
.block-head--split { display: flex; flex-wrap: wrap; gap: var(--sp-6); justify-content: space-between; align-items: flex-end; max-width: none; }
.block-head--split > div:first-child { max-width: 600px; }
.block-head--split .block-lead { max-width: 380px; }
.block-head .h-display { margin: 12px 0; }
.block-lead { font-size: 17px; color: var(--c-ink2); line-height: 1.55; }

/* ── Buttons ───────────────────────────────────────────────────── */
.btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: var(--sp-2);
	font-family: var(--font-body); font-weight: 600; font-size: 15px;
	padding: 12px 20px; border-radius: var(--r-pill);
	border: 1.5px solid transparent; transition: transform .08s, box-shadow var(--dur), background var(--dur), color var(--dur);
	line-height: 1.1; white-space: nowrap; cursor: pointer;
}
.btn:hover { transform: translateY(-1px); }
.btn--sm { padding: 8px 14px; font-size: 13px; }
.btn--lg { padding: 16px 26px; font-size: 17px; }
.btn--primary { background: var(--c-primary); color: #fff; box-shadow: 0 1px 0 rgba(0,0,0,0.12) inset, 0 4px 14px var(--c-primary-18); }
.btn--primary:hover { background: var(--c-primary-deep); box-shadow: 0 1px 0 rgba(0,0,0,0.12) inset, 0 8px 22px var(--c-primary-18); }
.btn--accent { background: var(--c-accent); color: #fff; box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 4px 14px rgba(242,107,58,0.35); }
.btn--accent:hover { background: var(--c-accent-deep); }
.btn--secondary { background: var(--c-white); color: var(--c-primary); border-color: var(--c-line2); }
.btn--secondary:hover { background: var(--c-paper2); }
.btn--ghost { background: transparent; color: var(--c-primary); }
.btn--ghost:hover { background: var(--c-primary-10); }
.btn--ghost-light { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.25); }
.btn--ghost-light:hover { background: rgba(255,255,255,0.18); }

/* ── Pills / Badges ────────────────────────────────────────────── */
.pill {
	display: inline-flex; align-items: center; gap: var(--sp-2);
	padding: 7px 14px; border-radius: var(--r-pill);
	font-family: var(--font-body); font-size: 13px; font-weight: 600;
}
.pill--white { background: var(--c-white); border: 1.5px solid var(--c-line); color: var(--c-ink2); }
.pill__dot { display: inline-block; width: 8px; height: 8px; border-radius: 99px; background: var(--c-muted); }
.pill__dot--ok { background: var(--c-ok); box-shadow: 0 0 0 4px rgba(31,138,91,0.18); }

/* ── NAV ───────────────────────────────────────────────────────── */
.nav {
	position: sticky; top: 0; z-index: 50;
	background: rgba(250,247,242,0.96);
	border-bottom: 1px solid var(--c-line);
	padding: 14px var(--container-px);
}
/* Glass effect only on desktop (creates containing block, breaks fixed positioning on mobile drawer) */
@media (min-width: 1024px) {
	.nav { background: rgba(250,247,242,0.85); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); }
}
.nav__inner { max-width: var(--container); margin-inline: auto; display: flex; align-items: center; gap: 24px; flex-wrap: nowrap; }
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.brand__lamp { flex-shrink: 0; }
.brand__logo { display: block; height: 44px; width: auto; max-width: none; flex-shrink: 0; }
.brand--footer .brand__logo { height: 52px; }
.brand__word { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--c-primary); letter-spacing: -0.01em; line-height: 1; }
.brand__word-accent { color: var(--c-accent); }
.footer .brand__word-accent { color: var(--c-accent); }
.nav__links { display: flex; gap: 8px; margin-left: 18px; flex: 1; }
.nav__links a {
	position: relative;
	font-family: var(--font-body); font-size: 14px; font-weight: 600;
	color: var(--c-ink2);
	padding: 6px 10px;
	transition: color .2s, transform .35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* Squiggly marker underline — appears on hover/focus */
.nav__links a::after {
	content: '';
	position: absolute;
	left: 8px; right: 8px; bottom: -4px;
	height: 7px;
	background: var(--link-c, var(--c-primary));
	-webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 8' preserveAspectRatio='none'%3E%3Cpath d='M2 4 Q 12 0 25 4 T 50 4 T 75 4 T 98 4' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 8' preserveAspectRatio='none'%3E%3Cpath d='M2 4 Q 12 0 25 4 T 50 4 T 75 4 T 98 4' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	opacity: 0;
	transform: scaleX(0.5) translateY(3px);
	transform-origin: center;
	transition: opacity .2s, transform .35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* Tiny floating dot above link — appears on hover */
.nav__links a::before {
	content: '';
	position: absolute;
	top: -2px; left: 50%;
	width: 5px; height: 5px;
	border-radius: 99px;
	background: var(--link-c, var(--c-primary));
	transform: translateX(-50%) scale(0);
	transition: transform .3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nav__links a:hover,
.nav__links a:focus-visible {
	color: var(--link-c, var(--c-primary));
	transform: translateY(-3px);
}
.nav__links a:hover::after,
.nav__links a:focus-visible::after {
	opacity: 1;
	transform: scaleX(1) translateY(0);
}
.nav__links a:hover::before,
.nav__links a:focus-visible::before {
	transform: translateX(-50%) scale(1);
}
.nav__links a:nth-child(1) { --link-c: #3389D9; }  /* Activitats — sky */
.nav__links a:nth-child(2) { --link-c: #F26B3A; }  /* Modalitats — orange */
.nav__links a:nth-child(3) { --link-c: #2BA8A6; }  /* Setmanes — teal */
.nav__links a:nth-child(4) { --link-c: #F273A6; }  /* Famílies — coral */
.nav__links a:nth-child(5) { --link-c: #1F8A5B; }  /* Com funciona — green */
.nav__links a:nth-child(6) { --link-c: #7A3FB8; }  /* Documents — purple */
.nav__links a:nth-child(7) { --link-c: #E07A1A; }  /* FAQ — warm */
.nav__actions { display: flex; gap: 10px; align-items: center; margin-left: auto; }
.lang-switch { display: flex; gap: 4px; padding: 3px; background: var(--c-white); border-radius: 99px; border: 1px solid var(--c-line); }
.lang-switch__btn { padding: 5px 10px; border: none; background: transparent; border-radius: 99px; color: var(--c-ink2); font-family: var(--font-body); font-size: 11px; font-weight: 700; letter-spacing: 0.04em; transition: all var(--dur); }
.lang-switch__btn.is-active { background: var(--c-primary); color: #fff; }
.nav__menu-btn { display: none; background: transparent; border: 1px solid var(--c-line); color: var(--c-ink2); padding: 8px; border-radius: var(--r-sm); position: relative; z-index: 60; }
.nav__menu-icon--close { display: none; }
.nav--open .nav__menu-icon--open { display: none; }
.nav--open .nav__menu-icon--close { display: inline-block; }
.nav--open .nav__menu-btn { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* ── HERO ──────────────────────────────────────────────────────── */
.hero {
	position: relative; overflow: hidden;
	padding: clamp(40px, 6vw, 80px) var(--container-px) clamp(40px, 8vw, 90px);
	background: var(--c-paper);
}
.hero__deco { position: absolute; pointer-events: none; }
.hero__deco--sun { top: -100px; right: -180px; color: var(--c-accent); opacity: 0.55; transform: rotate(15deg); }
.hero__deco--sun svg { width: clamp(280px, 35vw, 480px); height: clamp(280px, 35vw, 480px); }
.hero__deco--star1 { top: 18%; left: 52%; opacity: 0.7; }
.hero__deco--star2 { top: 60%; left: 47%; opacity: 0.65; }
.hero__inner { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; position: relative; }
.hero__content { position: relative; z-index: 2; }
.hero__title {
	font-family: var(--font-display);
	font-weight: 800; color: var(--c-primary);
	letter-spacing: -0.035em; line-height: 0.96;
	font-size: clamp(2.5rem, 7vw, 5.5rem);
	margin: 20px 0 0;
	text-wrap: balance;
}
.hero__title-hl { position: relative; display: inline-block; padding: 0 6px; }
.hero__title-hl-bg {
	position: absolute; inset: -2px -8px;
	background: var(--c-accent); border-radius: 14px;
	z-index: 0; transform: rotate(-1.5deg);
}
.hero__title-hl > span:last-child { position: relative; z-index: 1; color: #fff; }
.hero__title-sub { display: inline-block; }
.hero__lead { font-family: var(--font-body); font-size: clamp(16px, 1.6vw, 19px); line-height: 1.55; color: var(--c-ink2); max-width: 580px; margin: 22px 0 32px; }
.hero__lead strong { color: var(--c-primary); font-weight: 700; }
.hero__actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.hero__trust { display: flex; gap: 22px; align-items: center; margin-top: 38px; flex-wrap: wrap; }
.hero__trust-avatars { display: flex; }
.hero__trust-avatars > span {
	width: 36px; height: 36px; border-radius: 99px;
	border: 2.5px solid var(--c-paper);
	display: grid; place-items: center;
	font-family: var(--font-display); font-size: 13px; font-weight: 800;
	color: var(--c-primary);
}
.hero__trust-avatars > span + span { margin-left: -10px; }
.hero__trust-text strong { display: block; font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--c-primary); line-height: 1; }
.hero__trust-text span { display: block; font-family: var(--font-body); font-size: 12px; color: var(--c-muted); margin-top: 2px; }

/* Hero photo collage */
.hero__media { position: relative; min-height: 420px; }
.hero__photo {
	position: absolute; overflow: hidden;
	background: var(--c-paper2);
	box-shadow: var(--sh-photo);
	border: 7px solid #fff;
}
.hero__photo img { width: 100%; height: 100%; object-fit: cover; }
.hero__photo--a { left: 10%; top: 0; width: 56%; height: 64%; border-radius: 18px; transform: rotate(-4deg); }
.hero__photo--b { right: 0; top: 12%; width: 44%; height: 50%; border-radius: 18px; transform: rotate(5deg); z-index: 2; }
.hero__photo--c { right: 12%; bottom: 0; width: 40%; aspect-ratio: 1; border-radius: 50%; transform: rotate(-3deg); z-index: 3; }
.hero__sticker {
	position: absolute; left: -10px; bottom: 16%;
	width: 96px; height: 96px; border-radius: 99px;
	background: var(--c-accent); color: #fff;
	transform: rotate(-14deg);
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	box-shadow: 0 10px 24px rgba(242,107,58,0.32);
	z-index: 4; text-align: center; line-height: 1;
}
.hero__sticker strong { font-family: var(--font-display); font-size: 28px; font-weight: 800; }
.hero__sticker span { font-family: var(--font-body); font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; }

/* Hero stats card */
.hero__stats {
	max-width: var(--container); margin: 60px auto 0;
	padding: 24px 28px;
	background: var(--c-white); border-radius: var(--r-xl);
	border: 1px solid var(--c-line); box-shadow: var(--sh-md);
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px;
	position: relative; z-index: 1;
}
.stat { padding-left: 0; }
.stat__value {
	font-family: var(--font-display); font-size: clamp(2rem, 3.5vw, 2.75rem);
	font-weight: 800; color: var(--c-primary); letter-spacing: -0.03em; line-height: 1;
}
.stat__label { font-family: var(--font-body); font-size: 13px; font-weight: 700; color: var(--c-ink); margin-top: 4px; }
.stat__sub { font-family: var(--font-body); font-size: 12px; color: var(--c-muted); margin-top: 2px; }

/* ── BEFORE / AFTER ────────────────────────────────────────────── */
.ba { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper2); }
.ba > .container { max-width: 1100px; }
.ba__grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
.ba__card { background: var(--c-white); border-radius: var(--r-xl); padding: 28px; border: 1.5px solid var(--c-line); position: relative; overflow: hidden; }
.ba__card--before { opacity: 0.95; }
.ba__card--after { background: var(--c-primary); color: #fff; border-color: transparent; box-shadow: var(--sh-xl); }
.ba__after-deco { position: absolute; right: -30px; top: -30px; opacity: 0.18; pointer-events: none; }
.ba__head { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; position: relative; }
.ba__icon { width: 38px; height: 38px; border-radius: 12px; display: grid; place-items: center; flex-shrink: 0; }
.ba__icon--bad { background: var(--c-bad-bg); color: var(--c-bad); }
.ba__icon--ok { background: var(--c-accent); color: #fff; }
.ba__tag { font-family: var(--font-body); font-size: 11px; color: var(--c-muted); font-weight: 700; letter-spacing: 0.1em; }
.ba__tag--accent { color: var(--c-accent); }
.ba__title { font-family: var(--font-display); font-size: 26px; font-weight: 700; color: var(--c-ink); margin-top: 8px; letter-spacing: -0.015em; }
.ba__card--after .ba__title { color: #fff; }
.ba__meta { font-family: var(--font-body); font-size: 14px; color: var(--c-muted); margin-bottom: 18px; }
.ba__meta--light { color: rgba(255,255,255,0.7); }
.ba__list { display: flex; flex-direction: column; gap: 10px; position: relative; }
.ba__list li { display: flex; align-items: flex-start; gap: 10px; font-family: var(--font-body); font-size: 14.5px; color: var(--c-ink2); }
.ba__num { flex-shrink: 0; width: 22px; height: 22px; border-radius: 99px; background: var(--c-paper2); color: var(--c-muted); display: grid; place-items: center; font-family: var(--font-display); font-size: 12px; font-weight: 700; }
.ba__list--bad li span:last-child { text-decoration: line-through; text-decoration-color: rgba(209,67,67,0.4); text-decoration-thickness: 2px; }
.ba__check { flex-shrink: 0; width: 22px; height: 22px; border-radius: 99px; background: var(--c-accent); color: #fff; display: grid; place-items: center; }
.ba__list--good li { color: #fff; }
.ba__hint { margin-top: 22px; padding: 12px 16px; background: rgba(255,255,255,0.1); border-radius: 14px; display: flex; align-items: center; gap: 10px; font-family: var(--font-body); font-size: 13.5px; line-height: 1.4; position: relative; }

/* ── ACTIVITATS (bento) ────────────────────────────────────────── */
.acts { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper); }
.acts__bento { display: grid; gap: 14px; grid-template-columns: 1fr; }
.acts__big { position: relative; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--c-line); background: var(--c-paper2); min-height: 320px; }
.acts__big img { width: 100%; height: 100%; object-fit: cover; }
.acts__caption {
	position: absolute; left: 18px; bottom: 18px;
	background: rgba(255,255,255,0.94);
	backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
	padding: 14px 18px; border-radius: 16px; max-width: 280px;
}
.acts__caption-title { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: var(--c-primary); letter-spacing: -0.02em; line-height: 1.1; }
.acts__caption-sub { font-family: var(--font-body); font-size: 12.5px; color: var(--c-ink2); margin-top: 4px; }
.act-card {
	position: relative; overflow: hidden;
	background: var(--c, var(--c-primary)); color: #fff;
	border-radius: var(--r-lg); padding: 22px;
	display: flex; flex-direction: column; justify-content: space-between;
	min-height: 150px; gap: 14px;
	box-shadow: var(--sh-sm);
	transition: transform var(--dur) var(--ease), box-shadow var(--dur);
	text-decoration: none;
}
.act-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.act-card__bg {
	position: absolute; right: -28px; bottom: -28px;
	width: 170px; height: 170px;
	color: rgba(255,255,255,0.22);
	pointer-events: none; z-index: 0;
}
.act-card__bg svg { width: 100%; height: 100%; }
.act-card__bg svg, .act-card__bg use { fill: none; stroke: currentColor; stroke-width: 1.3; stroke-linecap: round; stroke-linejoin: round; }
.act-card__icon { position: relative; z-index: 1; color: #fff; display: inline-block; line-height: 0; }
.act-card__icon svg { width: 44px; height: 44px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.act-card__label { position: relative; z-index: 1; font-family: var(--font-display); font-size: 22px; font-weight: 800; color: #fff; letter-spacing: -0.01em; line-height: 1.05; }

/* ── MODALITATS ────────────────────────────────────────────────── */
.mods { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-white); border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
.mods__grid { display: grid; gap: 24px; grid-template-columns: 1fr; }
.mod-card { background: var(--c-paper); border-radius: var(--r-xl); padding: 32px; border: 1.5px solid var(--c-line); position: relative; overflow: hidden; }
.mod-card__circle { position: absolute; top: -40px; right: -40px; width: 200px; height: 200px; border-radius: 99px; pointer-events: none; }
.mod-card--lleure .mod-card__circle { background: var(--c-primary-10); }
.mod-card--esports .mod-card__circle { background: rgba(31,138,91,0.10); }
.mod-card__ribbon {
	position: absolute; top: 22px; right: 22px;
	background: var(--c-warn-bg); color: var(--c-warn);
	padding: 4px 12px; border-radius: var(--r-pill);
	font-family: var(--font-body); font-size: 11.5px; font-weight: 700; letter-spacing: 0.04em;
}
.mod-card__head { display: flex; align-items: center; gap: 14px; position: relative; }
.mod-card__key {
	width: 56px; height: 56px; border-radius: 18px;
	display: grid; place-items: center; flex-shrink: 0;
	font-family: var(--font-display); font-size: 28px; font-weight: 800;
	color: #fff;
}
.mod-card--lleure .mod-card__key { background: var(--c-primary); }
.mod-card--esports .mod-card__key { background: var(--c-ok); }
.mod-card__kicker { font-family: var(--font-body); font-size: 11px; font-weight: 700; color: var(--c-muted); letter-spacing: 0.12em; text-transform: uppercase; }
.mod-card__title { font-family: var(--font-display); font-size: 38px; font-weight: 800; color: var(--c-primary); letter-spacing: -0.025em; line-height: 1; }
.mod-card__text { font-family: var(--font-body); font-size: 15px; color: var(--c-ink2); line-height: 1.55; margin: 18px 0; }
.mod-card__bullets { display: flex; flex-direction: column; gap: 10px; }
.mod-card__bullets li { display: flex; align-items: flex-start; gap: 10px; font-family: var(--font-body); font-size: 14px; color: var(--c-ink2); }
.mod-card__check { flex-shrink: 0; width: 20px; height: 20px; border-radius: 99px; background: var(--c-primary-10); color: var(--c-primary); display: grid; place-items: center; }
.mod-card__check--orange { background: rgba(31,138,91,0.10); color: var(--c-ok); }
.mod-card__foot { display: flex; justify-content: space-between; align-items: center; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--c-line); gap: 12px; flex-wrap: wrap; }
.mod-card__foot-label { font-family: var(--font-body); font-size: 11px; font-weight: 700; color: var(--c-muted); letter-spacing: 0.08em; text-transform: uppercase; }
.mod-card__foot-value { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--c-primary); }

/* ── SETMANES ──────────────────────────────────────────────────── */
.weeks { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper); }
.weeks__grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
.week-card {
	background: var(--bg, var(--c-paper2));
	border-radius: var(--r-lg);
	padding: 22px;
	border: 1px solid var(--c-line);
	position: relative; overflow: hidden;
	min-height: 180px;
	display: flex; flex-direction: column; justify-content: space-between;
}
.week-card__bg {
	position: absolute; right: -16px; top: -16px;
	color: var(--c, var(--c-primary)); opacity: 0.18;
	pointer-events: none;
}
.week-card__bg svg { width: 140px; height: 140px; fill: none; stroke: currentColor; stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.week-card__head { display: flex; align-items: center; gap: 10px; position: relative; }
.week-card__num {
	width: 44px; height: 44px; border-radius: 14px;
	background: #fff; color: var(--c, var(--c-primary));
	display: grid; place-items: center;
	font-family: var(--font-display); font-size: 18px; font-weight: 800;
}
.week-card__label { font-family: var(--font-body); font-size: 11px; color: var(--c-muted); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.week-card__dates { font-family: var(--font-body); font-size: 13px; color: var(--c-ink2); font-weight: 600; }
.week-card__theme { position: relative; font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--c-primary); letter-spacing: -0.02em; line-height: 1.05; text-wrap: balance; }
.weeks__cta { margin-top: var(--sp-10); text-align: center; }

/* ── REASSURE / TRANQUIL·LITAT ─────────────────────────────────── */
.reassure { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-white); border-top: 1px solid var(--c-line); }
.reassure__grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
.reassure-card {
	background: var(--c-paper); border-radius: var(--r-lg);
	border: 1px solid var(--c-line); padding: 22px;
	transition: transform var(--dur) var(--ease), box-shadow var(--dur);
}
.reassure-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.reassure-card__icon { width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 14px; }
.reassure-card__title { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--c-primary); letter-spacing: -0.01em; margin-bottom: 6px; line-height: 1.2; }
.reassure-card__text { font-family: var(--font-body); font-size: 14px; color: var(--c-ink2); line-height: 1.5; }

/* ── HOW IT WORKS ──────────────────────────────────────────────── */
.how { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper2); }
.how__path { position: relative; }
.how__line { display: none; }
.how__steps { display: grid; gap: 36px; grid-template-columns: 1fr; }
.step { display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; }
.step__icon {
	position: relative;
	width: 76px; height: 76px; border-radius: 24px;
	background: var(--c-white);
	border: 2px solid var(--c-primary); color: var(--c-primary);
	display: grid; place-items: center;
	box-shadow: 0 6px 14px rgba(20,30,50,0.06);
}
.step__num {
	position: absolute; top: -8px; right: -8px;
	width: 26px; height: 26px; border-radius: 99px;
	background: var(--c-accent); color: #fff;
	display: grid; place-items: center;
	font-family: var(--font-display); font-size: 13px; font-weight: 800;
}
.step__title { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--c-primary); margin-top: 14px; letter-spacing: -0.01em; line-height: 1.1; }
.step__text { font-family: var(--font-body); font-size: 13px; color: var(--c-muted); margin-top: 4px; line-height: 1.4; max-width: 220px; }

/* ── DOCS ──────────────────────────────────────────────────────── */
.docs { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper); }
.docs__list { display: grid; gap: 14px; grid-template-columns: 1fr; max-width: 760px; margin: 0 auto; }
.doc-item {
	display: flex; align-items: flex-start; gap: 16px;
	background: var(--c-white); border: 1px solid var(--c-line);
	border-radius: var(--r-lg); padding: 18px;
	transition: border-color var(--dur), transform var(--dur);
}
.doc-item:hover { border-color: var(--c-primary); transform: translateX(4px); }
.doc-item__icon { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; flex-shrink: 0; }
.doc-item__title { font-family: var(--font-display); font-size: 17px; font-weight: 700; color: var(--c-primary); letter-spacing: -0.01em; margin-bottom: 2px; }
.doc-item__text { font-family: var(--font-body); font-size: 14px; color: var(--c-muted); }
.docs__note { margin-top: var(--sp-8); text-align: center; font-size: 14px; color: var(--c-muted); max-width: 640px; margin-inline: auto; }

/* ── FAQ ───────────────────────────────────────────────────────── */
.faq { padding: clamp(60px, 10vw, 100px) var(--container-px); background: var(--c-paper); }
.faq__list { display: flex; flex-direction: column; gap: 10px; }
.faq__item { background: var(--c-white); border-radius: 18px; border: 1px solid var(--c-line); overflow: hidden; transition: border-color var(--dur), box-shadow var(--dur); }
.faq__item[open] { border-color: var(--c-primary); box-shadow: var(--sh-sm); }
.faq__item summary { list-style: none; cursor: pointer; padding: 18px 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item h3 { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--c-primary); letter-spacing: -0.01em; }
.faq__toggle { flex-shrink: 0; width: 32px; height: 32px; border-radius: 99px; background: var(--c-paper2); color: var(--c-muted); display: grid; place-items: center; transition: all var(--dur); }
.faq__item[open] .faq__toggle { background: var(--c-primary); color: #fff; transform: rotate(180deg); }
.faq__body { padding: 0 22px 18px; }
.faq__body p { font-family: var(--font-body); font-size: 15px; color: var(--c-ink2); line-height: 1.55; }
.faq__contact {
	margin-top: 32px; padding: 22px; background: var(--c-white); border-radius: 22px;
	border: 1.5px dashed var(--c-line2);
	display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.faq__contact > div:first-child { flex: 1; min-width: 220px; }
.faq__contact-title { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: var(--c-primary); letter-spacing: -0.015em; }
.faq__contact-sub { font-family: var(--font-body); font-size: 14px; color: var(--c-muted); margin-top: 2px; }

/* ── CTA ───────────────────────────────────────────────────────── */
.cta {
	position: relative; overflow: hidden;
	padding: clamp(60px, 10vw, 90px) var(--container-px);
	background: var(--c-primary); color: #fff;
}
.cta__deco { position: absolute; pointer-events: none; }
.cta__deco--a { right: -60px; top: -40px; opacity: 0.16; }
.cta__deco--b { left: -60px; bottom: -60px; opacity: 0.18; }
.cta__inner { max-width: 900px; margin: 0 auto; text-align: center; position: relative; }
.cta__title {
	font-family: var(--font-display); font-weight: 800; color: #fff;
	letter-spacing: -0.03em; line-height: 1;
	font-size: clamp(2.25rem, 5.5vw, 4.25rem);
	margin: 14px 0 16px; text-wrap: balance;
}
.cta__title-hl { color: var(--c-accent); }
.cta__lead { font-family: var(--font-body); font-size: clamp(15px, 1.4vw, 19px); color: rgba(255,255,255,0.88); line-height: 1.5; max-width: 580px; margin: 0 auto 32px; }
.cta__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.cta__badges { margin-top: 32px; display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; font-family: var(--font-body); font-size: 13px; color: rgba(255,255,255,0.7); }
.cta__badges > span { display: inline-flex; align-items: center; gap: 6px; }

/* ── FOOTER ────────────────────────────────────────────────────── */
.footer { background: var(--c-paper2); color: var(--c-ink2); padding: 60px var(--container-px) 24px; border-top: 1px solid var(--c-line); }
.footer__grid { display: grid; gap: 40px; grid-template-columns: 1fr; padding-bottom: 40px; border-bottom: 1px solid var(--c-line); }
.footer__brand .brand__word { color: var(--c-primary); }
.footer__brand .brand__word-accent { color: var(--c-accent); }
.footer__org { font-family: var(--font-body); font-size: 14px; color: var(--c-ink2); line-height: 1.6; max-width: 320px; margin-top: 14px; }
.footer__heading { font-family: var(--font-body); font-size: 12px; font-weight: 700; color: var(--c-primary); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 14px; }
.footer__list { display: flex; flex-direction: column; gap: 10px; }
.footer__list a, .footer__list span { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); font-size: 14px; color: var(--c-ink2); transition: color var(--dur); }
.footer__list a:hover { color: var(--c-primary); }
.footer__bottom { padding-top: 24px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-family: var(--font-body); font-size: 12.5px; color: var(--c-muted); }
.footer__legal { display: flex; gap: 18px; }
.footer__legal a:hover { color: var(--c-primary); }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

@media (min-width: 640px) {
	.hero__stats { grid-template-columns: repeat(4, 1fr); }
	.hero__stats .stat:not(:first-child) { padding-left: 20px; border-left: 1px solid var(--c-line); }
	.weeks__grid { grid-template-columns: repeat(2, 1fr); }
	.reassure__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
	.acts__bento {
		display: grid;
		grid-template-columns: repeat(12, 1fr);
		grid-auto-rows: 140px;
	}
	.acts__big { grid-column: span 6; grid-row: span 3; min-height: 0; }
	.act-card { grid-column: span 3; grid-row: span 1; min-height: 0; }
	.weeks__grid { grid-template-columns: repeat(3, 1fr); }
	.reassure__grid { grid-template-columns: repeat(3, 1fr); }
	.how__steps { grid-template-columns: repeat(5, 1fr); gap: 16px; }
	.how__line {
		display: block;
		position: absolute;
		top: 38px; left: 10%; right: 10%; height: 2px;
		background: repeating-linear-gradient(90deg, var(--c-line2) 0 8px, transparent 8px 16px);
		z-index: 0;
	}
	.step__icon { position: relative; z-index: 1; }
	.mods__grid { grid-template-columns: 1fr 1fr; }
	.ba__grid { grid-template-columns: 1fr 1fr; }
	.footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; }
}

@media (min-width: 1024px) {
	.hero__inner { grid-template-columns: 1.05fr 0.95fr; gap: 60px; }
	.hero__media { min-height: 520px; }
}

@media (max-width: 1023px) {
	.nav__links { display: none; }
	.nav__menu-btn { display: inline-grid; place-items: center; }
	.nav--open .nav__links {
		display: flex; flex-direction: column; gap: 0;
		position: fixed;
		top: 64px; left: 0; right: 0; bottom: 0;
		background: var(--c-paper);
		padding: var(--sp-6) var(--container-px) var(--sp-10);
		overflow-y: auto;
		z-index: 45;
		animation: navOpen .22s var(--ease);
	}
	@keyframes navOpen { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
	.nav--open .nav__links a {
		padding: 18px 8px;
		font-size: 22px; font-weight: 700;
		color: var(--c-primary);
		border-bottom: 1px solid var(--c-line);
	}
	.nav--open .nav__links a:last-child { border-bottom: none; }
	.nav__inner { gap: 12px; }
	/* Cuando el menú está abierto, ocultar lang-switch del header (recuperable via reload) */
	.nav--open .lang-switch,
	.nav--open .nav__actions > .btn { display: none; }
}

@media (max-width: 767px) {
	:root { --container-px: 20px; }
	.brand__logo { height: 36px; }
	.brand--footer .brand__logo { height: 44px; }
	.hero__media { min-height: 360px; }
	.hero__photo--a { width: 60%; height: 52%; }
	.hero__photo--b { width: 48%; height: 44%; }
	.hero__photo--c { width: 38%; }
	.hero__sticker { width: 76px; height: 76px; }
	.hero__sticker strong { font-size: 22px; }
	.hero__title { font-size: clamp(2rem, 9vw, 3rem); }
	.h-display { font-size: clamp(1.75rem, 7vw, 2.4rem); }
	.cta__title { font-size: clamp(2rem, 9vw, 3rem); }
	.block-head--split { flex-direction: column; align-items: flex-start; }
	.block-head--split .block-lead { max-width: none; }
}

@media (max-width: 559px) {
	:root { --container-px: 14px; }
	.brand__logo { height: 30px; }
	.nav__inner { gap: 8px; }
	.lang-switch { display: none; }
	.nav__actions .btn--sm { padding: 7px 12px; font-size: 12px; }
	/* Hide arrow icon next to "Inscribirse" text on very small screens to save room */
	.nav__actions .btn--sm svg { display: none; }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
	.btn:hover { transform: none; }
}

@media print {
	.nav, .cta, .footer__bottom { display: none; }
}
