:root{
  /* Editorial fluvial · navy + cyan, sense tons càlids */
  --navy:#0A2A4E;--navy-2:#0C447C;--navy-deep:#061827;
  --blue:#1E6FB8;--blue-2:#2D8FD3;
  --river:#2E8BCB;--aqua:#9FE3FF;
  --cyan:#0EA5E9;--cyan-2:#0284C7;       /* NOU · accent fluvial elèctric */
  --soft:#E4ECF5;--sky-2:#EFF5FB;        /* més diferenciat del blanc */
  --canvas:#EBF1F8;                      /* fons gris fluvial · més contrast amb cards blanques */
  --sand:#E4ECF5;--cream:#EFF5FB;        /* sand i cream blaus · sense càlids */
  --ink:#061827;--text:#0F2237;--muted:#5A6B82;
  --border:#E2E8F0;--line:#E2E8F0;
  --card:#FFFFFF;
  --shadow:0 24px 60px rgba(10,42,78,.10);
  --shadow-soft:0 14px 40px rgba(14,165,233,.08);
  --shadow-card:0 30px 80px rgba(10,42,78,.12);
  --shadow-strong:0 40px 120px rgba(10,42,78,.20);
  --shadow-glow:0 20px 60px rgba(14,165,233,.25);  /* NOU */
  --radius:18px;--radius-lg:24px;--radius-md:14px;--radius-sm:10px;  /* més moderns */
  --sky:var(--soft);
  /* Tipografia · NOU */
  --font-display:'Sora','Inter',system-ui,-apple-system,sans-serif;
  --font-sans:'Inter',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--text);line-height:1.65;background:white}a{color:inherit}.container{width:min(1180px,calc(100% - 36px));margin:0 auto}.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}.navbar{width:min(1180px,calc(100% - 36px));margin:0 auto;min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:12px;text-decoration:none}.brand-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:18px;color:#fff;background:linear-gradient(135deg,var(--navy),var(--river));box-shadow:0 12px 28px rgba(12,68,124,.22)}.brand strong{display:block;line-height:1.05}.brand small{color:var(--muted)}.nav-links{display:flex;align-items:center;gap:14px;font-weight:850}.nav-links a{text-decoration:none;color:var(--text)}.nav-cta{background:var(--ink);color:white!important;padding:10px 16px;border-radius:999px}.nav-toggle{display:none;border:0;background:var(--soft);color:var(--navy);padding:10px 13px;border-radius:14px;font-size:22px}
.hero{position:relative;overflow:hidden;padding:122px 0;color:white;background:radial-gradient(circle at 24% 14%,rgba(255,255,255,.22),transparent 28%),linear-gradient(135deg,#071D33 0%,#0C447C 48%,#2E8BCB 100%)}.hero:after{content:"";position:absolute;left:-10%;right:-10%;bottom:-135px;height:270px;border-radius:50% 50% 0 0;background:rgba(255,255,255,.15)}.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.34fr .86fr;gap:44px;align-items:center}.eyebrow,.section-tag{margin:0 0 10px;color:#63B6F2;text-transform:uppercase;letter-spacing:.13em;font-size:13px;font-weight:950}.hero h1{margin:0;font-size:clamp(48px,7vw,88px);line-height:.95;letter-spacing:-.05em}.hero-copy p:not(.eyebrow){font-size:clamp(18px,2vw,23px);color:rgba(255,255,255,.9);max-width:730px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;background:var(--ink);color:white!important;padding:13px 22px;border-radius:999px;font-weight:900;text-decoration:none;cursor:pointer;box-shadow:0 16px 34px rgba(7,29,51,.2)}.btn-light{background:white;color:var(--ink)!important}.btn-soft{background:white!important;color:var(--ink)!important;border:1px solid var(--border)}.btn.full{width:100%}
.hero-card,.form-card,.stats-card,.card,.calendar-card-pro,.events-panel,.join-highlight{border:1px solid var(--border);background:white;color:var(--text);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}.glass{background:rgba(255,255,255,.9);backdrop-filter:blur(14px)}.hero-card ul{list-style:none;padding:0;margin:18px 0 0}.hero-card li{position:relative;padding-left:30px;margin:10px 0}.hero-card li:before{content:"✓";position:absolute;left:0;color:var(--river);font-weight:950}.section{padding:96px 0}.section-soft{background:var(--soft)}.section h2{margin:0 0 18px;font-size:clamp(34px,4vw,54px);line-height:1.03;letter-spacing:-.04em}.intro{max-width:780px;color:var(--muted)}.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}.split.top{align-items:start}.stats-card{display:grid;gap:18px;background:var(--sand)}.stats-card div{padding:18px;border-radius:18px;background:white}.stats-card strong{display:block;font-size:24px}.stats-card span{color:var(--muted)}
.facility-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}.facility-card{border-radius:30px;overflow:hidden;background:white;border:1px solid var(--border);box-shadow:var(--shadow)}.facility-card img{width:100%;height:230px;object-fit:cover;display:block}.facility-card div{padding:22px}.facility-card span{font-size:32px}.facility-card h3{font-size:24px;margin:10px 0 8px}.facility-card p{margin:0;color:var(--muted)}
.muletes-showcase{position:relative;overflow:hidden;padding:110px 0 118px;background:radial-gradient(circle at 18% 18%,rgba(131,200,244,.26),transparent 32%),linear-gradient(180deg,#F9FCFF 0%,#EEF7FF 100%)}.showcase-head{text-align:center;max-width:900px;margin:0 auto 44px}.showcase-head h2{margin:0 0 18px;font-size:clamp(44px,7vw,82px);line-height:.92;letter-spacing:-.06em;color:var(--ink)}.showcase-head p{margin:0 auto;color:var(--muted);font-size:18px;max-width:760px}.carousel-shell{margin:0 calc((100vw - min(1180px, calc(100vw - 36px))) / -2);overflow:hidden}.muletes-carousel{overflow-x:auto;overflow-y:hidden;padding:24px 0 40px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;-webkit-overflow-scrolling:touch;scroll-behavior:auto}.muletes-carousel::-webkit-scrollbar{display:none}.muletes-carousel.dragging{cursor:grabbing}.carousel-track{display:flex;gap:24px;width:max-content;user-select:none}.muleta-slide{flex:0 0 360px;height:520px;position:relative;overflow:hidden;border-radius:36px;background:white;box-shadow:0 28px 70px rgba(12,68,124,.22);cursor:pointer}.slide-media{position:absolute;inset:0;background:linear-gradient(135deg,#0C447C,#2E8BCB)}.slide-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.muleta-slide:hover .slide-img{transform:scale(1.055)}.slide-placeholder{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:white;padding:34px;background:linear-gradient(135deg,#0C447C,#2E8BCB)}.slide-placeholder .boat{font-size:76px;display:block;margin-bottom:14px}.slide-placeholder strong{font-size:32px}.slide-gradient{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,29,51,0) 34%,rgba(7,29,51,.28) 56%,rgba(7,29,51,.94) 100%)}.slide-content{position:absolute;left:0;right:0;bottom:0;padding:28px;color:white}.slide-kicker{display:inline-flex;padding:7px 10px;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.14);border-radius:999px;font-size:12px;font-weight:950;text-transform:uppercase}.slide-content h3{font-size:38px;line-height:.95;letter-spacing:-.05em;margin:16px 0 10px}.slide-content p{margin:0;color:rgba(255,255,255,.82)}.slide-footer{display:flex;justify-content:space-between;align-items:center;margin-top:18px;color:white;font-size:13px;font-weight:900}.showcase-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:12px}.carousel-btn{border:1px solid var(--border);background:rgba(255,255,255,.8);color:var(--ink);border-radius:999px;padding:12px 18px;font-weight:950;cursor:pointer;box-shadow:0 12px 26px rgba(12,68,124,.1)}.carousel-btn.primary{background:var(--ink);color:white}
.competition-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:26px}.competition-cards article{background:var(--soft);border:1px solid var(--border);border-radius:22px;padding:22px}.competition-cards span{font-size:36px}.calendar-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;margin-top:30px}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.calendar-header button{border:1px solid var(--border);border-radius:14px;background:white;padding:10px 14px;font-weight:900;cursor:pointer}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-weekdays span{text-align:center;color:var(--muted);font-weight:950;font-size:13px}.calendar-day{min-height:82px;border:1px solid var(--border);border-radius:16px;background:white;padding:10px;font-weight:800;position:relative}.calendar-day.muted{opacity:.35}.calendar-day.has-event{background:linear-gradient(135deg,#EAF5FF,#fff);border-color:#A9D8F8}.event-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);position:absolute;right:10px;bottom:10px}.events-panel{display:grid;gap:12px;align-content:start}.event-item{border:1px solid var(--border);border-radius:18px;background:white;padding:16px}.event-item span{display:block;color:var(--blue);font-weight:900;font-size:13px}.event-item p{margin:6px 0 0;color:var(--muted)}
.join-highlight{background:linear-gradient(135deg,var(--ink),var(--navy));color:white;margin-top:24px}.join-highlight strong{display:block;font-size:22px}.join-highlight span{display:block;margin-top:8px;color:rgba(255,255,255,.78)}.join-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.availability{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:28px 0}.availability div{padding:18px;border-radius:18px;background:white;border:1px solid var(--border)}.availability strong{display:block;font-size:25px;color:var(--navy)}.availability span{color:var(--muted);font-size:14px}.form-card{display:grid;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}label{display:grid;gap:7px;font-weight:850}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:13px 14px;font:inherit}textarea{resize:vertical}.form-message{margin:0;font-weight:850;color:var(--navy)}.social-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.social-links a{background:var(--ink);color:white;text-decoration:none;border-radius:999px;padding:11px 16px;font-weight:900}.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);min-height:360px}.map-embed iframe{display:block;width:100%;height:360px;border:0}.modal{position:fixed;inset:0;z-index:200;display:none}.modal.open{display:block}.modal-backdrop{position:absolute;inset:0;background:rgba(7,29,51,.62);backdrop-filter:blur(8px)}.modal-card{position:relative;z-index:1;width:min(900px,calc(100% - 34px));max-height:calc(100vh - 40px);overflow:auto;margin:20px auto;background:white;border-radius:32px;box-shadow:0 40px 100px rgba(0,0,0,.35)}.modal-close{position:absolute;right:16px;top:16px;z-index:2;border:0;background:rgba(255,255,255,.9);width:42px;height:42px;border-radius:50%;font-size:28px;cursor:pointer}.modal-img{width:100%;height:420px;object-fit:cover;background:linear-gradient(135deg,#0C447C,#2E8BCB)}.modal-body{padding:30px}.modal-body h2{font-size:42px;margin:0 0 8px}.modal-body p{color:var(--muted)}.modal-actions{margin-top:18px;padding:12px 14px;border-radius:16px;background:var(--soft);color:var(--navy);font-weight:850}.site-footer{background:#071D33;color:white;padding:28px 0}.footer-content{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.footer-content a{color:white;text-decoration:none}
.alta-page{background:linear-gradient(135deg,#0C447C,#071D33);min-height:100vh;padding:28px}.alta-wrap{width:min(980px,100%);margin:0 auto}.alta-card{background:#fff;border-radius:28px;box-shadow:0 28px 90px rgba(0,0,0,.26);overflow:hidden}.alta-header{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;background:#EAF5FF;padding:28px 32px}.alta-header h1{margin:0;font-size:34px}.close-link{text-decoration:none;background:#fff;border:1px solid var(--border);padding:10px 14px;border-radius:999px;font-weight:900}.alta-form{padding:28px 32px;display:grid;gap:20px}.alta-form h2{font-size:14px;color:var(--navy);text-transform:uppercase;letter-spacing:.12em;border-bottom:2px solid #D7EAF8;padding-bottom:10px;margin:6px 0 0}.alta-grid{display:grid;gap:14px}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:1.5fr .75fr .75fr .9fr}.address-grid{grid-template-columns:2fr .7fr .7fr .7fr .7fr}.quotes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.quote-card{border:1px solid #D8D0C7;border-radius:16px;padding:18px;background:#fff}.quote-card span{font-weight:900}.quote-card div{display:flex;align-items:center;gap:8px;margin-top:10px}.quote-input{width:90px}.quote-card small{color:var(--muted)}.total-box{background:#E0F0FF;border-radius:14px;padding:16px;font-size:20px}.alta-actions{display:flex;justify-content:flex-end;gap:12px;position:sticky;bottom:0;background:white;padding-top:14px;border-top:1px solid var(--border)}
@media(max-width:1100px){.facility-grid{grid-template-columns:repeat(2,1fr)}.calendar-layout{grid-template-columns:1fr}}@media(max-width:820px){.nav-toggle{display:block}.nav-links{display:none;position:absolute;top:78px;left:18px;right:18px;padding:18px;border:1px solid var(--border);border-radius:20px;background:white;box-shadow:var(--shadow);flex-direction:column;align-items:stretch}.nav-links.open{display:flex}.hero-grid,.split,.facility-grid,.availability,.competition-cards,.cols-3,.cols-4,.address-grid,.quotes-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.section{padding:68px 0}.muleta-slide{flex-basis:282px;height:440px}.slide-content h3{font-size:30px}.modal-img{height:260px}.calendar-day{min-height:58px;font-size:13px}.map-embed,.map-embed iframe{height:300px;min-height:300px}.alta-page{padding:0}.alta-card{border-radius:0}.alta-header{display:grid}.alta-form{padding:20px}.alta-actions{justify-content:stretch}.alta-actions .btn{flex:1}}

/* Ajustos alta soci V2 */
.alta-form input,
.alta-form select,
.alta-form textarea {
  font-weight: 650;
  color: #0D2B45;
}

.alta-form input::placeholder,
.alta-form textarea::placeholder {
  color: #AAB7C2;
  font-weight: 500;
  opacity: 1;
}

.selectable-quotes .quote-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.selectable-quotes .quote-card:hover {
  transform: translateY(-2px);
  border-color: #83C8F4;
  box-shadow: 0 16px 34px rgba(12,68,124,.12);
}

.quote-check {
  width: 22px !important;
  height: 22px;
  margin-top: 4px;
  accent-color: #0C447C;
}

.quote-content {
  display: grid;
  gap: 6px;
}

.quote-content span {
  font-weight: 950;
  font-size: 17px;
}

.quote-content strong {
  font-size: 24px;
  color: #0C447C;
}

.quote-content small {
  color: #62788D;
  font-weight: 700;
}

.quote-card:has(.quote-check:checked) {
  border-color: #0C447C;
  background: #EAF5FF;
}

.total-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.total-box span {
  color: #0D2B45;
  font-weight: 800;
}

.total-box strong {
  font-size: 28px;
  color: #0C447C;
}


/* Ajustos alta soci V3: selecció visual sense checkbox visible */
.alta-form input::placeholder,
.alta-form textarea::placeholder {
  color: #D5DDE5 !important;
  font-weight: 400 !important;
  opacity: 1;
}

.visually-hidden.quote-check {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px !important;
  height: 1px !important;
}

.selectable-quotes .quote-card {
  grid-template-columns: 1fr !important;
  position: relative;
  min-height: 150px;
  user-select: none;
}

.selectable-quotes .quote-card::after {
  content: "Seleccionar";
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #F2F7FC;
  color: #8EA1B4;
  font-size: 12px;
  font-weight: 900;
}

.quote-card:has(.quote-check:checked)::after {
  content: "Seleccionada";
  background: #0C447C;
  color: white;
}

.quote-card:has(.quote-check:checked) {
  border-color: #0C447C !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(46,139,203,.18), transparent 34%),
    #EAF5FF !important;
  box-shadow: 0 22px 44px rgba(12,68,124,.16) !important;
}

.quote-card:has(.quote-check:checked) .quote-content strong {
  color: #071D33;
}

.quote-content {
  padding-right: 110px;
}


/* Alta soci V4 - declaració unificada i obligatòria */
.cols-2 {
  grid-template-columns: repeat(2, 1fr);
}

.legal-box {
  border: 1px solid #D7EAF8;
  background: linear-gradient(180deg, #F8FCFF, #FFFFFF);
  border-radius: 20px;
  padding: 20px;
  display: grid;
  gap: 16px;
}

.legal-box p {
  margin: 0;
  color: #314E66;
}

.legal-details {
  border: 1px solid #DDEAF4;
  border-radius: 16px;
  background: #FFFFFF;
  overflow: hidden;
}

.legal-details summary {
  cursor: pointer;
  padding: 14px 16px;
  font-weight: 950;
  color: #0C447C;
  user-select: none;
}

.legal-text {
  padding: 0 16px 16px;
  display: grid;
  gap: 12px;
  color: #486176;
  font-size: 14px;
}

.legal-accept {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  padding: 16px;
  background: #EAF5FF;
  border: 1px solid #BFDDF5;
  border-radius: 16px;
  font-weight: 900;
}

.legal-accept input {
  width: 22px !important;
  height: 22px;
  margin-top: 2px;
  accent-color: #0C447C;
}

.legal-accept span {
  color: #0D2B45;
}

#dataSignaturaVisible {
  background: #F6FAFD;
  color: #62788D;
}

@media(max-width:820px) {
  .cols-2 {
    grid-template-columns: 1fr;
  }
}


/* Alta soci V5 - correccions data i total */
#dataSignaturaVisible {
  background: #F6FAFD !important;
  color: #62788D !important;
  cursor: default;
}

.total-box strong {
  min-width: 90px;
  text-align: right;
}

/* Evita que el contingut de quotes es vegi massa apretat */
.selectable-quotes .quote-card {
  min-height: 135px;
}

.quote-content strong {
  white-space: nowrap;
}


/* Escola de Rem */
.escola-rem-section {
  background:
    radial-gradient(circle at 15% 20%, rgba(46,139,203,.12), transparent 32%),
    linear-gradient(180deg, #FFFFFF, #F4FAFF);
}

.escola-grid {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 42px;
  align-items: center;
}

.escola-poster img {
  width: 100%;
  border-radius: 32px;
  box-shadow: 0 28px 70px rgba(12,68,124,.18);
  border: 1px solid #DDEAF4;
}

.escola-facts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 24px 0;
}

.escola-facts div,
.escola-extra-card {
  background: white;
  border: 1px solid #DDEAF4;
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 14px 34px rgba(12,68,124,.08);
}

.escola-facts strong {
  display: block;
  color: #071D33;
}

.escola-facts span {
  display: block;
  margin-top: 6px;
  color: #62788D;
  font-size: 14px;
}

.escola-extra-card ul {
  margin: 10px 0 0;
  color: #486176;
}

.escola-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.activity-pricing {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.pricing-column {
  display: grid;
  gap: 12px;
}

.pricing-column h3 {
  margin: 0;
  color: #0C447C;
}

.school-option,
.school-turn {
  min-height: auto !important;
}

.school-option .quote-content,
.school-turn .quote-content {
  padding-right: 0;
}

.school-option:has(.school-check:checked),
.school-turn:has(.turn-check:checked) {
  border-color: #0C447C !important;
  background: #EAF5FF !important;
  box-shadow: 0 18px 38px rgba(12,68,124,.14) !important;
}

.turn-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.small-muted {
  color: #62788D;
  margin-top: 0;
}

@media(max-width:820px) {
  .escola-grid,
  .escola-facts,
  .activity-pricing,
  .turn-grid {
    grid-template-columns: 1fr;
  }
}


/* =========================
   ESCOLA DE REM PRO V2
   ========================= */
.escola-hero-section {
  padding: 110px 0;
  background:
    radial-gradient(circle at 15% 16%, rgba(46,139,203,.16), transparent 30%),
    linear-gradient(180deg, #FFFFFF 0%, #EEF7FF 100%);
}

.escola-hero-card {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 38px;
  align-items: center;
  padding: 30px;
  border-radius: 38px;
  background: rgba(255,255,255,.86);
  border: 1px solid #DDEAF4;
  box-shadow: 0 34px 90px rgba(12,68,124,.16);
  backdrop-filter: blur(16px);
}

.escola-visual {
  position: relative;
}

/* Quan hi ha foto: el contenidor s'adapta a la mida natural — només es veu la foto, sense fons */
.escola-visual #escola-foto {
  display: block;
  width: 100%;
  height: auto;
  border-radius: inherit;
}

.escola-copy h2 {
  margin: 0 0 16px;
  font-size: clamp(42px, 6vw, 78px);
  line-height: .92;
  letter-spacing: -.06em;
  color: #071D33;
}

.escola-lead {
  color: #486176;
  font-size: 18px;
}

.escola-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 26px 0;
}

.escola-mini-grid div {
  background: #F6FBFF;
  border: 1px solid #DDEAF4;
  border-radius: 20px;
  padding: 16px;
}

.escola-mini-grid span {
  font-size: 26px;
}

.escola-mini-grid strong,
.escola-mini-grid small {
  display: block;
}

.escola-mini-grid strong {
  margin-top: 8px;
  color: #071D33;
}

.escola-mini-grid small {
  color: #62788D;
  margin-top: 3px;
  font-weight: 700;
}

.escola-programa h3 {
  margin-bottom: 10px;
}

.programa-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.programa-tags span {
  background: #071D33;
  color: white;
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 900;
  font-size: 13px;
}

.escola-important {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}

.escola-important div {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  align-items: start;
  background: #EAF5FF;
  border: 1px solid #BFDDF5;
  border-radius: 18px;
  padding: 14px 16px;
}

.escola-important strong {
  color: #0C447C;
}

.escola-important span {
  color: #486176;
}

.escola-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

/* Registration page polished */
.school-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 10% 8%, rgba(46,139,203,.22), transparent 28%),
    linear-gradient(135deg, #071D33, #0C447C);
  padding: 28px;
}

.school-shell {
  width: min(1080px, 100%);
  margin: 0 auto;
}

.school-top {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 18px;
}

.school-back {
  color: white;
  text-decoration: none;
  font-weight: 900;
  opacity: .9;
}

.school-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: white;
  text-align: right;
}

.school-logo {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
}

.school-brand strong,
.school-brand span {
  display: block;
}

.school-brand span {
  opacity: .75;
  font-size: 13px;
}

.school-hero-form {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
  align-items: end;
  padding: 34px;
  background: rgba(255,255,255,.94);
  border-radius: 30px 30px 0 0;
  border: 1px solid rgba(255,255,255,.55);
  border-bottom: 0;
}

.school-hero-form h1 {
  margin: 0 0 12px;
  font-size: clamp(38px, 6vw, 68px);
  line-height: .95;
  letter-spacing: -.06em;
  color: #071D33;
}

.school-hero-form p {
  color: #486176;
  margin-bottom: 0;
}

.school-summary {
  display: grid;
  gap: 10px;
}

.school-summary span {
  padding: 13px 15px;
  border-radius: 16px;
  background: #EAF5FF;
  color: #0C447C;
  font-weight: 950;
}

.school-form {
  background: #FFFFFF;
  border-radius: 0 0 30px 30px;
  padding: 30px 34px 34px;
  display: grid;
  gap: 24px;
  box-shadow: 0 32px 90px rgba(0,0,0,.22);
}

.form-section {
  border: 1px solid #DDEAF4;
  border-radius: 24px;
  padding: 24px;
  background: #FBFDFF;
}

.form-section-title {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 20px;
}

.form-section-title > span {
  flex: 0 0 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  color: white;
  background: #0C447C;
  font-weight: 950;
}

.form-section-title h2 {
  margin: 0;
  font-size: 24px;
  color: #071D33;
}

.form-section-title p {
  margin: 4px 0 0;
  color: #62788D;
}

.field-grid {
  display: grid;
  gap: 14px;
  margin-top: 14px;
}

.field-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.field-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.field-grid.address-grid { grid-template-columns: 2fr .7fr .7fr .7fr .7fr; }

.school-form label {
  color: #0D2B45;
  font-weight: 850;
}

.school-form input,
.school-form select,
.school-form textarea {
  background: white;
  border: 1px solid #D7E5F0;
  border-radius: 14px;
  padding: 13px 14px;
}

.school-form input::placeholder,
.school-form textarea::placeholder {
  color: #C9D5DF;
  font-weight: 400;
}

.pricing-modern {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.pricing-group {
  display: grid;
  gap: 12px;
}

.pricing-group h3 {
  margin: 0;
  color: #0C447C;
  font-size: 20px;
}

.school-price-card,
.turn-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  min-height: 72px;
  padding: 16px 18px;
  border: 1px solid #DDEAF4;
  border-radius: 20px;
  background: white;
  cursor: pointer;
  transition: .18s ease;
}

.school-price-card:hover,
.turn-card:hover {
  transform: translateY(-2px);
  border-color: #83C8F4;
  box-shadow: 0 14px 30px rgba(12,68,124,.1);
}

.school-price-card:has(.school-check:checked),
.turn-card:has(.turn-check:checked) {
  background: #EAF5FF;
  border-color: #0C447C;
  box-shadow: 0 18px 40px rgba(12,68,124,.15);
}

.school-price-card span,
.turn-card span {
  font-weight: 950;
}

.school-price-card small {
  display: block;
  margin-top: 2px;
  color: #62788D;
}

.school-price-card strong {
  color: #0C447C;
  font-size: 25px;
  white-space: nowrap;
}

.turn-modern {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}

.school-total {
  margin-top: 18px;
  border-radius: 20px;
  background: linear-gradient(135deg, #EAF5FF, #D8EEFF);
  padding: 18px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 950;
}

.school-total strong {
  font-size: 32px;
  color: #0C447C;
}

.school-legal {
  display: grid;
  gap: 16px;
  background: white;
  border: 1px solid #DDEAF4;
  border-radius: 20px;
  padding: 20px;
}

.school-legal p {
  margin: 0;
  color: #314E66;
}

.school-legal details {
  border: 1px solid #DDEAF4;
  border-radius: 16px;
  overflow: hidden;
}

.school-legal summary {
  cursor: pointer;
  padding: 14px 16px;
  color: #0C447C;
  font-weight: 950;
}

.school-legal details div {
  padding: 0 16px 16px;
  display: grid;
  gap: 10px;
  font-size: 14px;
}

.school-actions-sticky {
  position: sticky;
  bottom: 0;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 16px 0 0;
  background: linear-gradient(180deg, rgba(255,255,255,0), #fff 40%);
}

.school-final-msg {
  text-align: right;
  font-size: 16px;
}

@media(max-width:900px) {
  .escola-hero-card,
  .school-hero-form,
  .pricing-modern,
  .field-grid.cols-3,
  .field-grid.cols-2,
  .field-grid.address-grid,
  .turn-modern,
  .escola-mini-grid,
  .escola-important div {
    grid-template-columns: 1fr;
  }

  .school-page {
    padding: 0;
  }

  .school-top {
    padding: 18px;
    margin-bottom: 0;
  }

  .school-brand {
    display: none;
  }

  .school-hero-form,
  .school-form {
    border-radius: 0;
    padding: 22px;
  }

  .escola-hero-card {
    padding: 22px;
  }

  .school-actions-sticky {
    justify-content: stretch;
  }

  .school-actions-sticky .btn {
    flex: 1;
  }
}


/* ==========================================================
   DESIGN SYSTEM FINAL PRO - Club Nàutic Móra d'Ebre
   Mobile-first responsive polish
   (Variables consolidades al :root del començament del fitxer)
   ========================================================== */

* {
  box-sizing: border-box;
}

html {
  scroll-padding-top: 92px;
  scroll-behavior: smooth;
}

/* Evita rebot que sembla "scroll trencat" en iOS quan hi ha llistes llargues */
body { overscroll-behavior-y: none; }

/* Safety net: si un drawer o modal queda obert i deixa el body bloquejat,
   un click manual a qualsevol enllaç ho desbloqueja (no caldria, però és un cinturó). */
body:not(.menu-open):not(.modal-open) { overflow-x: hidden; overflow-y: auto !important; }

body {
  background:
    radial-gradient(circle at 12% 0%, rgba(45,143,211,.11), transparent 30%),
    linear-gradient(180deg, #FFFFFF 0%, #F7FBFF 100%);
  color: var(--text);
  font-size: 16px;
}

img {
  max-width: 100%;
}

.container {
  width: min(1180px, calc(100% - 40px));
}

/* Header */
.site-header {
  background: rgba(255,255,255,.78) !important;
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(220,235,251,.82) !important;
}

.navbar {
  min-height: 82px;
}

.brand-icon {
  background: linear-gradient(135deg, var(--navy), var(--blue-2)) !important;
  box-shadow: 0 14px 30px rgba(21,101,169,.24) !important;
}

.brand strong {
  color: var(--ink);
  letter-spacing: -.02em;
}

.nav-links a {
  color: var(--text) !important;
  font-size: 14px;
}

.nav-links a:not(.nav-cta) {
  padding: 9px 4px;
}

.nav-links a:not(.nav-cta):hover {
  color: var(--blue) !important;
}

.nav-cta {
  background: linear-gradient(135deg, var(--navy), var(--blue)) !important;
  box-shadow: 0 12px 28px rgba(21,101,169,.20);
}

/* Hero */
.hero {
  padding: clamp(86px, 9vw, 140px) 0 !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(159,227,255,.22), transparent 28%),
    radial-gradient(circle at 84% 10%, rgba(255,255,255,.14), transparent 28%),
    linear-gradient(135deg, #061C33 0%, #073763 48%, #2D8FD3 100%) !important;
}

.hero::after {
  display: none;
}

.hero-grid {
  gap: clamp(28px, 5vw, 64px) !important;
}

.hero h1 {
  font-size: clamp(46px, 8vw, 92px) !important;
  letter-spacing: -.075em !important;
}

.hero-copy p:not(.eyebrow) {
  max-width: 680px;
  line-height: 1.55;
}

.hero-card {
  border: 1px solid rgba(255,255,255,.48) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.18) !important;
}

.glass {
  background: rgba(255,255,255,.88) !important;
}

/* Base sections */
.section {
  padding: clamp(70px, 8vw, 112px) 0 !important;
}

.section h2,
.escola-copy h2,
.showcase-head h2 {
  color: var(--ink);
}

.section-tag {
  color: var(--blue-2) !important;
  letter-spacing: .16em !important;
}

.intro,
.escola-lead,
.form-section-title p {
  color: var(--muted) !important;
}

.stats-card,
.form-card,
.calendar-card-pro,
.events-panel,
.join-highlight,
.hero-card {
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow-card) !important;
}

.stats-card {
  background: linear-gradient(180deg, var(--sand), #FFFFFF) !important;
}

/* Facilities */
.facility-grid {
  gap: 24px !important;
}

.facility-card {
  border-radius: 30px !important;
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow-soft) !important;
  transition: transform .22s ease, box-shadow .22s ease;
}

@media (hover: hover) and (pointer: fine) {
  .facility-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-card) !important;
  }
}

.facility-card img {
  height: 240px !important;
}

.facility-card div {
  padding: 24px !important;
}

/* Muletes carousel */
.muletes-showcase {
  padding: clamp(82px, 9vw, 124px) 0 !important;
  background:
    radial-gradient(circle at 18% 12%, rgba(159,227,255,.32), transparent 30%),
    radial-gradient(circle at 82% 10%, rgba(21,101,169,.13), transparent 28%),
    linear-gradient(180deg, #FFFFFF 0%, #EDF8FF 100%) !important;
}

.showcase-head h2 {
  font-size: clamp(44px, 8vw, 88px) !important;
}

.muleta-slide {
  border-radius: 34px !important;
  box-shadow: 0 24px 66px rgba(7,55,99,.22) !important;
}

.slide-content h3 {
  text-shadow: 0 8px 24px rgba(0,0,0,.24);
}

.carousel-btn {
  border: 1px solid var(--line) !important;
  background: rgba(255,255,255,.88) !important;
}

.carousel-btn.primary,
.btn {
  background: linear-gradient(135deg, var(--navy), var(--blue)) !important;
  box-shadow: 0 16px 34px rgba(21,101,169,.22) !important;
}

/* Escola homepage */
.escola-hero-section {
  padding: clamp(76px, 9vw, 122px) 0 !important;
  background:
    radial-gradient(circle at 6% 14%, rgba(159,227,255,.24), transparent 30%),
    radial-gradient(circle at 90% 4%, rgba(255,246,232,.9), transparent 28%),
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFF 100%) !important;
}

.escola-hero-card {
  border-radius: var(--radius-lg) !important;
  padding: clamp(20px, 3.5vw, 36px) !important;
  border: 1px solid rgba(220,235,251,.92) !important;
  box-shadow: var(--shadow-strong) !important;
  background: rgba(255,255,255,.82) !important;
}

.escola-visual img {
  border-radius: 30px !important;
}

.escola-floating-badge {
  border-radius: 20px !important;
}

.escola-copy h2 {
  font-size: clamp(44px, 7vw, 82px) !important;
}

.escola-mini-grid div,
.escola-important div,
.escola-extra-card {
  border-color: var(--line) !important;
  background: rgba(255,255,255,.9) !important;
  box-shadow: var(--shadow-soft);
}

.programa-tags span {
  background: linear-gradient(135deg, var(--navy), var(--blue)) !important;
}

/* Calendar */
.calendar-layout {
  gap: 28px !important;
}

.calendar-card-pro,
.events-panel {
  border-radius: 28px !important;
  background: rgba(255,255,255,.92) !important;
}

/* Reset suau — els estils inline del JS (today/has-event) tenen prioritat */
.calendar-day {
  border-radius: 16px;
  border-color: var(--line);
}

.event-item {
  border-radius: 18px !important;
  border-color: var(--line) !important;
  background: #fff !important;
}

/* Forms general */
input,
select,
textarea {
  border-color: #D7E5F0 !important;
  background: #fff !important;
  color: var(--text) !important;
  transition: border-color .16s ease, box-shadow .16s ease;
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: var(--blue-2) !important;
  box-shadow: 0 0 0 4px rgba(45,143,211,.14);
}

input::placeholder,
textarea::placeholder {
  color: #C8D4DF !important;
}

/* Contact */
.map-embed {
  border-radius: 30px !important;
  box-shadow: var(--shadow-card) !important;
}

/* Registration / school pages */
.alta-page,
.school-page {
  background:
    radial-gradient(circle at 15% 5%, rgba(159,227,255,.22), transparent 28%),
    linear-gradient(135deg, #061C33, #073763 55%, #1565A9) !important;
}

.alta-card,
.school-form,
.school-hero-form {
  box-shadow: 0 34px 100px rgba(0,0,0,.24) !important;
}

.alta-card {
  border-radius: 30px !important;
}

.alta-header,
.school-hero-form {
  background:
    radial-gradient(circle at 100% 0%, rgba(159,227,255,.38), transparent 32%),
    linear-gradient(180deg, #F8FCFF, #EAF6FF) !important;
}

.alta-header h1,
.school-hero-form h1 {
  color: var(--ink) !important;
  letter-spacing: -.05em;
}

.alta-form h2 {
  color: var(--navy) !important;
  border-color: #CFE6F8 !important;
}

.legal-box,
.school-legal,
.form-section {
  border-color: var(--line) !important;
  background: rgba(255,255,255,.86) !important;
}

.quote-card,
.school-price-card,
.turn-card {
  border-color: var(--line) !important;
  box-shadow: 0 10px 24px rgba(7,55,99,.06);
}

.quote-card:has(input:checked),
.school-price-card:has(input:checked),
.turn-card:has(input:checked) {
  border-color: var(--blue) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(45,143,211,.17), transparent 38%),
    #EAF6FF !important;
  box-shadow: 0 18px 46px rgba(7,55,99,.15) !important;
}

.total-box,
.school-total {
  background: linear-gradient(135deg, #E5F4FF, #D5EEFF) !important;
}

/* Mobile refinement */
@media (max-width: 980px) {
  .nav-toggle {
    display: grid !important;
  }

  .nav-cta {
    text-align: center;
  }

  .hero-grid,
  .split,
  .escola-hero-card,
  .escola-grid,
  .school-hero-form,
  .calendar-layout {
    grid-template-columns: 1fr !important;
  }

  .hero {
    padding-top: 74px !important;
  }

  .hero h1 {
    font-size: clamp(44px, 13vw, 70px) !important;
  }

  .hero-card {
    padding: 22px !important;
  }

  .facility-grid,
  .cards,
  .escola-mini-grid,
  .pricing-modern,
  .field-grid.cols-3,
  .field-grid.cols-2,
  .field-grid.address-grid,
  .turn-modern,
  .availability,
  .competition-cards {
    grid-template-columns: 1fr !important;
  }

  .facility-card img {
    height: 210px !important;
  }

  .muletes-showcase {
    padding-top: 72px !important;
  }

  .muleta-slide {
    flex-basis: min(82vw, 320px) !important;
    height: 440px !important;
  }

  .slide-content {
    padding: 22px !important;
  }

  .slide-content h3 {
    font-size: 31px !important;
  }

  .carousel-shell {
    margin-left: -20px !important;
    margin-right: -20px !important;
  }

  .calendar-day {
    min-height: 56px !important;
    padding: 8px !important;
    font-size: 13px;
  }

  .events-panel {
    padding: 22px !important;
  }

  .school-page,
  .alta-page {
    padding: 0 !important;
  }

  .school-top {
    padding: 16px !important;
  }

  .school-form,
  .school-hero-form {
    border-radius: 0 !important;
    padding: 20px !important;
  }

  .form-section {
    padding: 18px !important;
    border-radius: 22px !important;
  }

  .school-hero-form h1 {
    font-size: clamp(38px, 12vw, 58px) !important;
  }

  .school-actions-sticky,
  .alta-actions {
    position: sticky;
    bottom: 0;
    flex-direction: column;
    padding: 14px 0 0 !important;
  }

  .school-actions-sticky .btn,
  .alta-actions .btn {
    width: 100%;
  }

  .school-summary {
    grid-template-columns: 1fr;
  }

  .escola-actions,
  .hero-actions,
  .join-actions {
    flex-direction: column;
  }

  .escola-actions .btn,
  .hero-actions .btn,
  .join-actions .btn {
    width: 100%;
  }

  .map-embed,
  .map-embed iframe {
    min-height: 320px !important;
    height: 320px !important;
  }
}

@media (max-width: 520px) {
  .container {
    width: min(100% - 28px, 1180px);
  }

  .navbar {
    width: min(100% - 28px, 1180px);
  }

  .brand small {
    display: none;
  }

  .brand-icon {
    width: 42px;
    height: 42px;
  }

  .section {
    padding: 58px 0 !important;
  }

  .hero-copy p:not(.eyebrow),
  .escola-lead,
  .showcase-head p {
    font-size: 16px !important;
  }

  .escola-hero-card {
    border-radius: 28px !important;
  }

  .escola-important div {
    grid-template-columns: 1fr !important;
  }

  .school-price-card {
    align-items: flex-start;
  }

  .school-price-card strong {
    font-size: 22px !important;
  }

  .school-total strong,
  .total-box strong {
    font-size: 26px !important;
  }

  .modal-card {
    width: calc(100% - 20px) !important;
    margin: 10px auto !important;
    border-radius: 24px !important;
  }
}


/* ==========================================================
   HEADER PRO V2 - net, separat i amb menú lateral en mòbil
   ========================================================== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 500;
  background: rgba(255,255,255,.94) !important;
  border-bottom: 1px solid #E6EEF6 !important;
  box-shadow: 0 8px 28px rgba(7, 29, 51, .045);
}

.navbar {
  width: min(1200px, calc(100% - 44px)) !important;
  min-height: 88px !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.brand {
  min-width: max-content;
}

.brand-icon {
  width: 52px !important;
  height: 52px !important;
  border-radius: 18px !important;
  background: #0C447C !important;
  box-shadow: 0 12px 28px rgba(12,68,124,.18) !important;
  font-size: 22px;
}

.brand-text strong {
  color: #0A1F33;
  font-size: 17px;
  letter-spacing: -.02em;
}

.brand-text small {
  color: #6E8397;
  font-size: 13px;
}

.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px !important;
  margin-left: auto;
  font-weight: 850;
}

.nav-links a {
  color: #18354D !important;
  text-decoration: none;
  font-size: 14px !important;
  line-height: 1;
  padding: 13px 12px !important;
  border-radius: 999px;
  transition: background .16s ease, color .16s ease, transform .16s ease;
  white-space: nowrap;
}

.nav-links a:hover {
  background: #EEF7FF;
  color: #0C447C !important;
}

.nav-links .nav-cta {
  background: #0C447C !important;
  color: white !important;
  padding: 14px 20px !important;
  margin-left: 8px;
  box-shadow: 0 12px 26px rgba(12,68,124,.18) !important;
}

.nav-links .nav-cta:hover {
  background: #073763 !important;
  transform: translateY(-1px);
}

.drawer-head,
.nav-backdrop {
  display: none;
}

.nav-toggle {
  display: none;
  width: 48px;
  height: 48px;
  border: 1px solid #DDEAF4 !important;
  background: white !important;
  border-radius: 16px;
  padding: 0;
  place-items: center;
  box-shadow: 0 10px 24px rgba(7, 29, 51, .08);
}

.nav-toggle span {
  display: block;
  width: 21px;
  height: 2px;
  background: #0A1F33;
  border-radius: 999px;
  transition: transform .18s ease, opacity .18s ease;
}

.nav-toggle span + span {
  margin-top: 5px;
}

.nav-toggle.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-toggle.open span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

body.menu-open {
  overflow: hidden;
}

/* Desktop mitjà: compacte abans de passar a drawer */
@media (max-width: 1120px) {
  .navbar {
    width: min(100% - 32px, 1200px) !important;
  }

  .nav-links a {
    font-size: 13px !important;
    padding: 12px 9px !important;
  }

  .nav-links .nav-cta {
    padding: 13px 16px !important;
  }
}

/* Drawer lateral */
@media (max-width: 980px) {
  .navbar {
    min-height: 76px !important;
  }

  .brand-icon {
    width: 46px !important;
    height: 46px !important;
  }

  .nav-toggle {
    display: grid !important;
    z-index: 610;
  }

  .nav-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(7, 29, 51, .45);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease;
    z-index: 580;
  }

  .nav-backdrop.open {
    opacity: 1;
    pointer-events: auto;
  }

  .nav-links {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    bottom: 0;
    width: min(390px, 88vw);
    height: 100vh;
    display: flex !important;
    flex-direction: column;
    align-items: stretch !important;
    justify-content: flex-start;
    gap: 8px !important;
    padding: 22px !important;
    background: #FFFFFF !important;
    border-left: 1px solid #E6EEF6;
    border-radius: 0 !important;
    box-shadow: -28px 0 80px rgba(7, 29, 51, .20) !important;
    transform: translateX(105%);
    transition: transform .22s ease;
    z-index: 600;
    overflow-y: auto;
  }

  .nav-links.open {
    transform: translateX(0);
  }

  .drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 4px 2px 18px;
    margin-bottom: 8px;
    border-bottom: 1px solid #E6EEF6;
    color: #0A1F33;
    font-weight: 950;
    font-size: 20px;
  }

  .drawer-close {
    width: 42px;
    height: 42px;
    border: 1px solid #DDEAF4;
    background: #F6FBFF;
    border-radius: 14px;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #0A1F33;
  }

  .nav-links a {
    font-size: 17px !important;
    padding: 16px 15px !important;
    border-radius: 16px;
    color: #0A1F33 !important;
  }

  .nav-links a:hover {
    background: #EAF5FF;
  }

  .nav-links .nav-cta {
    margin-left: 0;
    margin-top: 10px;
    text-align: center;
    padding: 17px 18px !important;
    border-radius: 18px;
  }
}

@media (max-width: 520px) {
  .navbar {
    width: min(100% - 24px, 1200px) !important;
  }

  .brand-text strong {
    font-size: 15px;
  }

  .brand-text small {
    display: block !important;
    font-size: 12px;
  }

  .nav-links {
    width: min(360px, 92vw);
  }
}


/* ==========================================================
   HERO PRO V2 - portada amb foto i sense quadre informatiu antic
   ========================================================== */
.hero-cover {
  position: relative;
  min-height: calc(100vh - 88px);
  display: flex;
  align-items: center;
  padding: clamp(92px, 10vw, 150px) 0 !important;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(6,28,51,.96), rgba(7,55,99,.88) 48%, rgba(45,143,211,.82)) !important;
}

.hero-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(159,227,255,.22), transparent 28%),
    linear-gradient(90deg, rgba(6,28,51,.92) 0%, rgba(6,28,51,.72) 46%, rgba(6,28,51,.30) 100%);
  z-index: 1;
}

.hero-photo-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-photo-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .38;
  filter: saturate(1.08) contrast(1.04);
}

.hero-cover-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .72fr);
  gap: clamp(34px, 6vw, 78px);
  align-items: center;
}

.hero-cover .hero-copy {
  max-width: 760px;
}

.hero-cover h1 {
  margin: 0;
  font-size: clamp(54px, 8vw, 104px) !important;
  line-height: .9 !important;
  letter-spacing: -.08em !important;
  color: white;
  text-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.hero-cover .hero-copy p:not(.eyebrow) {
  max-width: 690px;
  font-size: clamp(18px, 2vw, 25px) !important;
  line-height: 1.55;
  color: rgba(255,255,255,.92) !important;
}

.hero-cover .hero-actions {
  margin-top: 30px;
}

.hero-cover .btn {
  background: white !important;
  color: #073763 !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.18) !important;
}

.hero-cover .btn-light {
  background: rgba(255,255,255,.13) !important;
  color: white !important;
  border: 1px solid rgba(255,255,255,.28);
  backdrop-filter: blur(12px);
}

.hero-feature {
  position: relative;
  border-radius: 38px;
  overflow: hidden;
  min-height: 520px;
  box-shadow: 0 38px 110px rgba(0,0,0,.30);
  border: 1px solid rgba(255,255,255,.26);
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(14px);
}

.hero-feature-photo {
  position: absolute;
  inset: 0;
}

.hero-feature-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-feature::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(6,28,51,0) 26%, rgba(6,28,51,.42) 60%, rgba(6,28,51,.95) 100%);
}

.hero-feature-content {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 30px;
  color: white;
}

.hero-feature-content span {
  display: inline-flex;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.28);
  backdrop-filter: blur(12px);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .11em;
  font-weight: 950;
}

.hero-feature-content h2 {
  margin: 16px 0 10px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1;
  letter-spacing: -.05em;
  color: white;
}

.hero-feature-content p {
  margin: 0;
  color: rgba(255,255,255,.82);
  font-size: 16px;
}

@media (max-width: 980px) {
  .hero-cover {
    min-height: auto;
    padding: 76px 0 64px !important;
  }

  .hero-cover-grid {
    grid-template-columns: 1fr;
  }

  .hero-feature {
    min-height: 360px;
    border-radius: 30px;
  }

  .hero-cover h1 {
    font-size: clamp(46px, 13vw, 78px) !important;
  }
}

@media (max-width: 520px) {
  .hero-cover {
    padding-top: 58px !important;
  }

  .hero-feature {
    min-height: 330px;
  }

  .hero-feature-content {
    padding: 22px;
  }

  .hero-feature-content h2 {
    font-size: 30px;
  }
}


/* ==========================================================
   ANIMACIONS PRO + HERO CLEAN FINAL
   ========================================================== */
.hero-cover {
  isolation: isolate;
}

.hero-cover .hero-actions .btn {
  min-width: 150px;
}

.hero-feature {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.30) !important;
  box-shadow: 0 40px 120px rgba(0,0,0,.28) !important;
  overflow: hidden;
  transform-origin: center;
  animation: heroCardIn 1.1s cubic-bezier(.16, 1, .3, 1) both .18s;
}

.hero-feature::after {
  display: none !important;
}

.hero-feature-photo img {
  border-radius: 38px;
  transform: scale(1.02);
  animation: photoFloat 7s ease-in-out infinite alternate;
  filter: saturate(1.05) contrast(1.03);
}

.hero-feature-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 38px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.28);
  pointer-events: none;
}

.hero-copy .eyebrow,
.hero-copy h1,
.hero-copy p,
.hero-copy .hero-actions {
  animation: heroTextIn .9s cubic-bezier(.16, 1, .3, 1) both;
}

.hero-copy .eyebrow { animation-delay: .05s; }
.hero-copy h1 { animation-delay: .14s; }
.hero-copy p { animation-delay: .24s; }
.hero-copy .hero-actions { animation-delay: .34s; }

@keyframes heroTextIn {
  from {
    opacity: 0;
    transform: translate3d(0, 26px, 0);
    filter: blur(8px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}

@keyframes heroCardIn {
  from {
    opacity: 0;
    transform: translate3d(46px, 34px, 0) scale(.94);
    filter: blur(12px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }
}

@keyframes photoFloat {
  from {
    transform: scale(1.02) translate3d(0, 0, 0);
  }
  to {
    transform: scale(1.065) translate3d(-10px, -8px, 0);
  }
}

/* Scroll reveal global */
.reveal {
  opacity: 0;
  transform: translate3d(0, 34px, 0) scale(.985);
  filter: blur(8px);
  transition:
    opacity .85s cubic-bezier(.16, 1, .3, 1),
    transform .85s cubic-bezier(.16, 1, .3, 1),
    filter .85s cubic-bezier(.16, 1, .3, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform, filter;
}

.reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

/* Hover premium cards */
.facility-card,
.card,
.form-card,
.calendar-card-pro,
.events-panel,
.stats-card,
.escola-hero-card,
.school-price-card,
.turn-card,
.quote-card {
  transition:
    transform .24s cubic-bezier(.16, 1, .3, 1),
    box-shadow .24s cubic-bezier(.16, 1, .3, 1),
    border-color .24s ease,
    background .24s ease !important;
}

@media (hover: hover) and (pointer: fine) {
  .facility-card:hover,
  .card:hover,
  .form-card:hover,
  .calendar-card-pro:hover,
  .events-panel:hover,
  .stats-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 90px rgba(7,55,99,.17) !important;
  }
}

/* Buttons */
.btn,
.carousel-btn,
.social-links a {
  transition:
    transform .18s cubic-bezier(.16, 1, .3, 1),
    box-shadow .18s ease,
    background .18s ease !important;
}

.btn:hover,
.carousel-btn:hover,
.social-links a:hover {
  transform: translateY(-2px);
}

/* Muletes smoother */
.muleta-slide {
  transition:
    transform .26s cubic-bezier(.16, 1, .3, 1),
    box-shadow .26s ease !important;
}

.muleta-slide:hover {
  transform: translateY(-10px) scale(1.015);
}

/* Calendar pulse on event days */
.calendar-day.has-event .event-dot {
  animation: pulseDot 1.8s ease-in-out infinite;
}

@keyframes pulseDot {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.65); opacity: .55; }
}

/* Escola section micro-animation */
.escola-mini-grid div,
.escola-important div,
.programa-tags span {
  transition: transform .2s ease, box-shadow .2s ease;
}

.escola-mini-grid div:hover,
.escola-important div:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 46px rgba(7,55,99,.12);
}

.programa-tags span:hover {
  transform: translateY(-2px);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }

  .reveal {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }

  .hero-feature,
  .hero-photo-bg img {
    transform: none !important;
  }
}

@media(max-width:980px) {
  .hero-feature {
    min-height: 340px !important;
  }

  .hero-feature-photo img {
    border-radius: 30px;
  }
}

@media(max-width:520px) {
  .hero-cover .hero-actions .btn {
    width: 100%;
  }

  .hero-feature {
    min-height: 300px !important;
  }
}

/* ── Àrea privada (peu de pàgina) ─────────────────────── */
.footer-gestio-link {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  text-decoration: none;
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 20px;
  transition: color .2s, border-color .2s;
  margin-left: auto;
}
.footer-gestio-link:hover {
  color: rgba(255,255,255,.7);
  border-color: rgba(255,255,255,.35);
}

/* ═══════════════════════════════════════════════════════════
   MILLORES VISUALS V2
   ═══════════════════════════════════════════════════════════ */

/* Google Font */
body { font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }

/* ── Botó transitions ──────────────────────────────────────── */
.btn {
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
@media (hover: hover) and (pointer: fine) {
  .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 44px rgba(7,29,51,.28) !important;
  }
}
.btn:active { transform: translateY(0); }

.btn.loading-btn {
  opacity: .65;
  pointer-events: none;
  position: relative;
}
.btn.loading-btn::after {
  content: "";
  width: 14px; height: 14px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: inline-block;
  margin-left: 8px;
  vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Inputs millores ───────────────────────────────────────── */
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--river);
  box-shadow: 0 0 0 3px rgba(46,139,203,.18);
  transition: border-color .2s, box-shadow .2s;
}

/* ── Nav actiu ─────────────────────────────────────────────── */
.nav-links a.nav-active {
  color: var(--navy) !important;
  font-weight: 950;
}
.nav-links a.nav-active::after {
  content: "";
  display: block;
  height: 2px;
  border-radius: 999px;
  background: var(--navy);
  margin-top: 2px;
}

/* ── Facility card visuals (sense imatges) ─────────────────── */
.card-visual {
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  position: relative;
  overflow: hidden;
}
.card-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .92;
}
.card-visual span { position: relative; z-index: 1; filter: drop-shadow(0 8px 24px rgba(0,0,0,.18)); }
.cv-piscina::before  { background: linear-gradient(135deg, #0ea5e9, #38bdf8 50%, #7dd3fc); }
.cv-gimnas::before   { background: linear-gradient(135deg, #0C447C, #185FA5 50%, #2E8BCB); }
.cv-embarcador::before { background: linear-gradient(135deg, #064e7a, #0C447C 40%, #1a6ea0); }
.cv-bar::before      { background: linear-gradient(135deg, #92400e, #b45309 50%, #d97706); }

/* ── Hero river feature ────────────────────────────────────── */
.hero-river-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, #051728 0%, #0a2d52 40%, #0e4a80 65%, #1e6fa8 100%);
  overflow: hidden;
}
.river-wave {
  position: absolute;
  left: -20%;
  right: -20%;
  height: 200px;
  border-radius: 50%;
  opacity: .28;
}
.river-wave-1 { bottom: -60px; background: rgba(46,139,203,.7); animation: waveMove 6s ease-in-out infinite; }
.river-wave-2 { bottom: -90px; background: rgba(30,111,168,.5); animation: waveMove 8s ease-in-out infinite reverse; }
.river-wave-3 { bottom: -120px; background: rgba(14,74,128,.6); animation: waveMove 10s ease-in-out infinite; }
@keyframes waveMove {
  0%, 100% { transform: translateX(0) scaleY(1); }
  50% { transform: translateX(4%) scaleY(1.06); }
}

.hero-feature-inner {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(255,255,255,.07);
}
.hero-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
  text-align: center;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.hero-stat strong {
  display: block;
  font-size: clamp(28px, 3.5vw, 46px);
  font-weight: 900;
  color: white;
  line-height: 1;
  letter-spacing: -.04em;
}
.hero-stat span {
  display: block;
  font-size: 11px;
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 6px;
  font-weight: 700;
}

/* ── Escola visual CSS ─────────────────────────────────────── */
.escola-visual-bg {
  width: 100%;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 22px 56px rgba(12,68,124,.18);
  position: relative;
}
/* Quan no hi ha foto: el placeholder té el degradat blau i les icones */
.escola-visual-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3.15;
  background: linear-gradient(135deg, #071D33 0%, #0C447C 45%, #2E8BCB 100%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.escola-visual-wave {
  position: absolute;
  bottom: -30px;
  left: -20%;
  right: -20%;
  height: 160px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  animation: waveMove 7s ease-in-out infinite;
}
.escola-visual-icons {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 18px;
  justify-content: center;
  font-size: 56px;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.35));
}

/* ── Social links millorats ────────────────────────────────── */
.social-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 14px;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease;
}
.social-link:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(0,0,0,.22); }
.social-instagram { background: linear-gradient(135deg, #833ab4, #fd1d1d, #fcb045); color: white !important; }
.social-facebook  { background: #1877f2; color: white !important; }
.social-whatsapp  { background: #25D366; color: white !important; }

/* ── Footer millorat ───────────────────────────────────────── */
/* OBSOLET 2E - revisar i esborrar al final · substituït per la
   variant mobile-first al final del fitxer
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  padding: 60px 0 40px;
}
*/
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5, 24px);
  padding: var(--sp-7, 40px) 0 var(--sp-5, 24px);
}
@media (min-width: 640px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
}
@media (min-width: 1024px) {
  .footer-grid {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 48px;
    padding: 60px 0 40px;
  }
}
.footer-brand p {
  color: rgba(255,255,255,.58);
  font-size: 14px;
  line-height: 1.7;
  margin: 16px 0 20px;
  max-width: 280px;
}
.footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  color: white;
}
.footer-logo strong { display: block; font-size: 17px; }
.footer-logo small  { color: rgba(255,255,255,.55); font-size: 12px; }
.footer-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-links h4 {
  margin: 0 0 8px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.45);
  font-weight: 800;
}
.footer-links a, .footer-links span {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  font-size: 14px;
  transition: color .15s;
}
.footer-links a:hover { color: white; }
.footer-socials { margin-top: 0 !important; }
.footer-socials .social-link { font-size: 12px; padding: 8px 13px; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding: 20px 0;
}
.footer-bottom-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-bottom p {
  margin: 0;
  font-size: 13px;
  color: rgba(255,255,255,.38);
}
.footer-bottom a { color: rgba(255,255,255,.5); text-decoration: none; font-size: 13px; }
.footer-bottom a:hover { color: rgba(255,255,255,.85); }

@media (max-width: 820px) {
  .footer-grid { grid-template-columns: 1fr; gap: 32px; padding: 40px 0 24px; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
}

/* ── Form message millorat ─────────────────────────────────── */
.form-message { min-height: 20px; transition: all .2s; }
.form-message.msg-ok   { color: #15803d; }
.form-message.msg-err  { color: #dc2626; }
.form-message.msg-send { color: var(--muted); }

/* ── Page load transition ──────────────────────────────────── */
body { opacity: 1 !important; }

/* ════════════════════════════════════════════════════════════
   HERO · Split data-led (Editorial Fluvial · Direcció C)
   ══════════════════════════════════════════════════════════ */
.hero-split{
  position:relative;
  background:var(--canvas);
  padding:clamp(70px,10vw,140px) 0 clamp(60px,7vw,100px);
  overflow:hidden;
}
.hero-split:before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 8% 20%, rgba(14,165,233,.06), transparent 40%),
    radial-gradient(circle at 92% 80%, rgba(10,42,78,.04), transparent 50%);
  pointer-events:none;
}
.hero-split-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(40px,6vw,90px);
  align-items:center;
}
@media(max-width:900px){
  .hero-split-grid{grid-template-columns:1fr;gap:40px}
}
.hero-split-eyebrow{
  font-family:var(--font-sans);
  font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--cyan);
  margin:0 0 24px;
}
.hero-split-title{
  font-family:var(--font-display);
  font-size:clamp(48px,7.2vw,108px);
  font-weight:700;
  line-height:.92;letter-spacing:-.045em;
  color:var(--ink);
  margin:0 0 28px;
}
.hero-split-title .accent{color:var(--cyan);font-style:normal}
.hero-split-lead{
  font-family:var(--font-sans);
  font-size:clamp(17px,1.4vw,20px);
  line-height:1.55;color:var(--muted);
  max-width:480px;margin:0 0 36px;
}
.hero-split-actions{display:flex;flex-wrap:wrap;gap:12px}
.hero-split .btn-dark{
  background:var(--ink);color:#fff!important;
  padding:14px 26px;border-radius:999px;
  font-family:var(--font-sans);font-weight:600;font-size:15px;
  text-decoration:none;display:inline-flex;align-items:center;
  box-shadow:0 12px 30px rgba(6,24,39,.18);
  transition:transform .2s ease,box-shadow .2s ease;
}
.hero-split .btn-dark:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(6,24,39,.25)}
.hero-split .btn-outline{
  background:#fff;color:var(--ink)!important;
  padding:13px 26px;border-radius:999px;
  border:1px solid var(--border);
  font-family:var(--font-sans);font-weight:600;font-size:15px;
  text-decoration:none;display:inline-flex;align-items:center;
  transition:border-color .2s ease,transform .2s ease;
}
.hero-split .btn-outline:hover{border-color:var(--ink);transform:translateY(-2px)}

/* Visual dret · card + KPIs */
.hero-split-visual{display:flex;flex-direction:column;gap:18px}
.hero-split-card{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  aspect-ratio:5/3;
  box-shadow:0 30px 80px rgba(10,42,78,.18),0 0 0 1px rgba(255,255,255,.4) inset;
}
.hero-split-card .hero-split-loc{
  position:absolute;top:20px;left:24px;z-index:2;
  font-family:var(--font-sans);
  font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;
  color:rgba(255,255,255,.85);
}
.hero-split-waves{display:block;width:100%;height:100%}
.hero-split-kpis{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
}
.hkpi{
  background:#fff;border:1px solid var(--border);
  border-radius:18px;padding:22px 24px;
  font-family:var(--font-sans);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
@media (hover: hover) and (pointer: fine) {
  .hkpi:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(10,42,78,.08); border-color: transparent; }
}
.hkpi strong{
  display:block;
  font-family:var(--font-display);
  font-size:42px;font-weight:700;
  letter-spacing:-.03em;color:var(--ink);
  line-height:1;margin-bottom:6px;
}
.hkpi span{font-size:13px;color:var(--muted);font-weight:500}
.hkpi-accent{
  background:var(--cyan);
  border-color:var(--cyan);
}
.hkpi-accent strong{color:#fff}
.hkpi-accent span{color:rgba(255,255,255,.92)}
.hkpi-accent:hover{box-shadow:0 16px 36px rgba(14,165,233,.35)}

/* ════════════════════════════════════════════════════════════
   MULETES · Editorial photo grid amb duotone fluvial
   ══════════════════════════════════════════════════════════ */
.muletes-editorial{
  background:var(--canvas);
  padding:clamp(70px,9vw,120px) 0;
}
.muletes-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;margin-bottom:48px;flex-wrap:wrap;
}
.muletes-title{
  font-family:var(--font-display);
  font-size:clamp(40px,5.5vw,72px);
  font-weight:600;
  letter-spacing:-.05em;line-height:.95;
  color:var(--ink);margin:14px 0 0;
}
.muletes-lead{
  max-width:380px;
  font-size:15px;line-height:1.55;
  color:var(--muted);margin:0;
}
.muletes-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:repeat(2,1fr);
  gap:18px;
  height:560px;
}
@media(max-width:900px){
  .muletes-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;height:auto}
  .muleta-hero{grid-row:auto !important;grid-column:1 / -1}
}
@media(max-width:560px){
  .muletes-grid{grid-template-columns:1fr}
  .muleta-card{aspect-ratio:4/3}
}
.muleta-card{
  position:relative;
  border-radius:20px;overflow:hidden;
  box-shadow:0 18px 50px rgba(10,42,78,.12);
  transition:transform .35s ease,box-shadow .35s ease;
}
.muleta-card:hover{
  transform:translateY(-4px);
  box-shadow:0 28px 70px rgba(10,42,78,.22);
}
.muleta-hero{grid-row:1 / -1}
.muleta-card[data-tone="0"]{background:linear-gradient(135deg,#9FE3FF,#1E6FB8)}
.muleta-card[data-tone="1"]{background:linear-gradient(135deg,#A8DDF7,#0A2A4E)}
.muleta-card[data-tone="2"]{background:linear-gradient(135deg,#0EA5E9,#061827)}
.muleta-card[data-tone="3"]{background:linear-gradient(135deg,#7BC9F0,#0A2A4E)}
.muleta-bg{
  position:absolute;inset:0;width:100%;height:100%;
  mix-blend-mode:screen;opacity:.7;
}
.muleta-meta{
  position:absolute;left:0;right:0;bottom:0;
  padding:24px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(6,24,39,.7));
}
.muleta-kicker{
  display:block;
  font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:#9FE3FF;
  margin-bottom:8px;
}
.muleta-name{
  font-family:var(--font-display);
  font-size:32px;font-weight:600;
  letter-spacing:-.04em;line-height:1;
  margin:0 0 14px;
}
.muleta-hero .muleta-name{font-size:clamp(40px,4.2vw,56px)}
.muleta-tags{display:flex;flex-wrap:wrap;gap:8px}
.muleta-tag{
  padding:5px 12px;border-radius:999px;
  background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  font-size:12px;font-weight:500;color:#fff;
}
.muleta-tag-mono{font-family:'Sora',monospace;font-weight:600}

/* ════════════════════════════════════════════════════════════
   ALTA SOCI · Editorial form amb stepper sticky
   ══════════════════════════════════════════════════════════ */
body.alta-page{
  background:var(--canvas) !important;
  color:var(--ink);
  min-height:100vh;
  padding:0 !important;
}
.alta-topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px clamp(20px,5vw,48px);
  background:rgba(247,243,236,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(10,42,78,.08);
}
.alta-back{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;font-size:14px;
  color:var(--ink);text-decoration:none;
  padding:10px 16px;border-radius:999px;
  background:rgba(10,42,78,.06);
  transition:background .2s ease;
}
.alta-back:hover{background:rgba(10,42,78,.12)}
.alta-brand{display:flex;align-items:center;gap:12px}
.alta-logo{
  width:42px;height:42px;border-radius:50%;
  overflow:hidden;background:#fff;
  box-shadow:0 4px 14px rgba(10,42,78,.14);
}
.alta-logo img{width:100%;height:100%;object-fit:contain}
.alta-brand-text{display:flex;flex-direction:column;line-height:1.15}
.alta-brand-text strong{font-size:14px;font-weight:700;color:var(--ink)}
.alta-brand-text span{font-size:12px;color:var(--muted);font-style:italic}

.alta-shell{
  max-width:1180px;margin:0 auto;
  padding:clamp(40px,6vw,80px) clamp(20px,5vw,48px) 120px;
}

/* Hero */
.alta-hero{
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:48px;align-items:start;
  margin-bottom:64px;
}
@media(max-width:900px){.alta-hero{grid-template-columns:1fr}}
.alta-hero-inner .section-tag{
  font-size:11px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent);margin:0 0 16px;
}
.alta-title{
  font-family:var(--font-display);
  font-size:clamp(48px,7vw,96px);
  font-weight:600;letter-spacing:-.05em;line-height:.92;
  color:var(--ink);margin:0 0 20px;
}
.alta-title em{font-style:italic;color:var(--accent);font-weight:500}
.alta-lead{
  font-size:17px;line-height:1.55;color:var(--muted);
  max-width:520px;margin:0;
}

/* Stepper sticky */
.alta-stepper{
  position:sticky;top:96px;
  background:#fff;border-radius:18px;
  padding:24px;
  box-shadow:0 10px 40px rgba(10,42,78,.08);
  border:1px solid rgba(10,42,78,.06);
}
.alta-stepper ol{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:6px;
}
.alta-stepper li{
  display:flex;align-items:center;gap:14px;
  padding:12px 14px;border-radius:12px;
  cursor:default;
  transition:background .25s ease,color .25s ease;
  position:relative;
}
.alta-stepper li::before{
  content:"";position:absolute;left:24px;top:48px;
  width:2px;height:14px;background:rgba(10,42,78,.12);
}
.alta-stepper li:last-child::before{display:none}
.alta-step-num{
  font-family:var(--font-display);
  font-size:18px;font-weight:600;
  color:rgba(10,42,78,.4);
  letter-spacing:-.02em;
  min-width:28px;
  transition:color .25s ease;
}
.alta-step-label{
  font-size:14px;font-weight:600;color:var(--muted);
  transition:color .25s ease;
}
.alta-stepper li.is-active{background:rgba(14,165,233,.08)}
.alta-stepper li.is-active .alta-step-num{color:var(--accent)}
.alta-stepper li.is-active .alta-step-label{color:var(--ink)}
@media(max-width:900px){
  .alta-stepper{position:static}
  .alta-stepper ol{flex-direction:row;flex-wrap:wrap;gap:8px}
  .alta-stepper li::before{display:none}
  .alta-stepper li{padding:8px 12px}
}

/* Form blocks */
.alta-form{display:flex;flex-direction:column;gap:32px}
.alta-block{
  background:#fff;
  border-radius:24px;
  padding:clamp(28px,4vw,48px);
  box-shadow:0 12px 50px rgba(10,42,78,.06);
  border:1px solid rgba(10,42,78,.05);
}
.alta-block-head{
  display:flex;gap:18px;align-items:flex-start;
  margin-bottom:32px;
  padding-bottom:24px;
  border-bottom:1px solid rgba(10,42,78,.08);
}
.alta-block-num{
  font-family:var(--font-display);
  font-size:44px;font-weight:600;
  color:var(--accent);
  letter-spacing:-.04em;line-height:.9;
}
.alta-block-head h2{
  font-family:var(--font-display);
  font-size:28px;font-weight:600;
  letter-spacing:-.03em;line-height:1;
  color:var(--ink);margin:0 0 6px;
}
.alta-block-head p{
  font-size:14px;color:var(--muted);margin:0;
}

/* Grid + fields */
.alta-grid{display:grid;gap:18px;margin-bottom:18px}
.alta-grid:last-child{margin-bottom:0}
.alta-grid-2{grid-template-columns:1fr 1fr}
.alta-grid-3{grid-template-columns:repeat(3,1fr)}
.alta-grid-4{grid-template-columns:repeat(4,1fr)}
.alta-grid-address{grid-template-columns:2fr .6fr .6fr .6fr .6fr}
@media(max-width:720px){
  .alta-grid-2,.alta-grid-3,.alta-grid-4,.alta-grid-address{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .alta-grid-2,.alta-grid-3,.alta-grid-4,.alta-grid-address{grid-template-columns:1fr}
}
.alta-field{display:flex;flex-direction:column;gap:6px}
.alta-field>span{
  font-size:12px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--muted);
}
.alta-field>span em{color:var(--accent);font-style:normal}
.alta-field input,
.alta-field textarea{
  font-family:inherit;font-size:15px;color:var(--ink);
  padding:14px 16px;
  background:rgba(10,42,78,.03);
  border:1.5px solid transparent;
  border-radius:12px;
  transition:border-color .2s ease,background .2s ease;
  outline:none;
}
.alta-field input:focus,
.alta-field textarea:focus{
  border-color:var(--accent);
  background:#fff;
}
.alta-field input::placeholder,
.alta-field textarea::placeholder{color:rgba(10,42,78,.35)}
.alta-field textarea{resize:vertical;min-height:90px}
.alta-field-iban input{font-family:'Sora',monospace;letter-spacing:.04em}
.alta-hint{font-size:12px;color:var(--muted);margin-top:4px}

/* Quotes cards */
.quota-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.quota-card{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;gap:24px;
  padding:24px 28px;
  background:#fff;
  border:2px solid rgba(10,42,78,.08);
  border-radius:18px;
  cursor:pointer;
  transition:all .25s ease;
  position:relative;
}
.quota-card:hover{
  border-color:rgba(14,165,233,.4);
  transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(10,42,78,.08);
}
.quota-card.is-selected{
  border-color:var(--accent);
  background:linear-gradient(135deg,rgba(14,165,233,.04),rgba(14,165,233,.08));
  box-shadow:0 16px 40px rgba(14,165,233,.18);
}
.quota-icon{
  width:54px;height:54px;border-radius:14px;
  background:rgba(14,165,233,.08);
  color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s ease,transform .25s ease;
}
.quota-icon svg{width:28px;height:28px}
.quota-card.is-selected .quota-icon{
  background:var(--accent);color:#fff;transform:scale(1.05);
}
.quota-body{display:flex;flex-direction:column;gap:4px}
.quota-kicker{
  font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}
.quota-name{
  font-family:var(--font-display);
  font-size:22px;font-weight:600;
  letter-spacing:-.02em;line-height:1;
  color:var(--ink);margin:2px 0 4px;
}
.quota-desc{
  font-size:13px;color:var(--muted);margin:0;line-height:1.4;
}
.quota-cobr{
  font-size:12px;color:var(--accent);font-weight:600;margin-top:4px;
}
.quota-price{
  display:flex;flex-direction:column;align-items:flex-end;
  font-family:var(--font-display);
  line-height:1;
}
.quota-price strong{
  font-size:42px;font-weight:600;
  letter-spacing:-.04em;color:var(--ink);
}
.quota-price span{
  font-size:12px;color:var(--muted);
  font-family:'Inter',sans-serif;font-weight:500;
  letter-spacing:.02em;margin-top:4px;
}
.quota-check{
  width:32px;height:32px;border-radius:50%;
  border:2px solid rgba(10,42,78,.15);
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  color:transparent;
  transition:all .25s ease;
}
.quota-check svg{width:18px;height:18px}
.quota-card.is-selected .quota-check{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
@media(max-width:680px){
  .quota-card{grid-template-columns:auto 1fr auto;gap:16px;padding:20px}
  .quota-check{display:none}
}

/* Total */
.quota-total{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:24px 28px;
  background:linear-gradient(135deg,var(--ink),#0F3D6E);
  color:#fff;border-radius:18px;
}
.quota-total-label{
  display:block;font-size:13px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.65);
}
.quota-total-hint{
  display:block;font-size:13px;color:rgba(255,255,255,.55);
  margin-top:4px;
}
.quota-total-amount{
  font-family:var(--font-display);
  font-size:48px;font-weight:600;
  letter-spacing:-.04em;
  color:#fff;
}

/* Legal block */
.alta-block-legal{background:rgba(10,42,78,.02)}
.alta-legal-card{
  display:flex;flex-direction:column;gap:16px;
  font-size:14px;line-height:1.55;color:var(--ink-soft);
}
.alta-legal-details{
  border:1px solid rgba(10,42,78,.1);
  border-radius:12px;padding:14px 18px;
  background:#fff;
}
.alta-legal-details summary{
  cursor:pointer;font-weight:600;color:var(--accent);
  list-style:none;
}
.alta-legal-details summary::-webkit-details-marker{display:none}
.alta-legal-details[open] summary{margin-bottom:12px}
.alta-legal-details>div{font-size:13px;color:var(--muted);line-height:1.55}
.alta-legal-details p{margin:0 0 10px}
.alta-accept{
  display:flex;gap:12px;align-items:flex-start;
  padding:18px;background:#fff;border-radius:12px;
  border:1.5px solid rgba(10,42,78,.1);
  cursor:pointer;
}
.alta-accept input{
  width:20px;height:20px;margin-top:2px;
  accent-color:var(--accent);cursor:pointer;flex-shrink:0;
}
.alta-accept span{font-size:14px;line-height:1.5}

/* Actions */
.alta-actions{
  display:flex;justify-content:flex-end;gap:12px;
  margin-top:24px;
  padding:24px;
  position:sticky;bottom:16px;
  background:rgba(247,243,236,.92);
  backdrop-filter:blur(12px);
  border-radius:18px;
  box-shadow:0 -4px 30px rgba(10,42,78,.08);
  border:1px solid rgba(10,42,78,.06);
}
.alta-actions .btn{
  padding:14px 28px;border-radius:999px;
  font-weight:600;font-size:15px;
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;border:none;cursor:pointer;
  transition:all .2s ease;
}
.alta-actions .btn-soft{
  background:rgba(10,42,78,.08);color:var(--ink);
}
.alta-actions .btn-soft:hover{background:rgba(10,42,78,.14)}
.alta-actions .btn-primary{
  background:var(--accent);color:#fff;
  box-shadow:0 8px 24px rgba(14,165,233,.32);
}
.alta-actions .btn-primary:hover{
  background:var(--accent-deep);
  box-shadow:0 12px 32px rgba(14,165,233,.44);
  transform:translateY(-1px);
}
.alta-final-msg{margin-top:16px;text-align:right}

/* ── Seccions dinàmiques ───────────────────────────────────── */
.seccio-dinamica {
  padding: clamp(48px, 6vw, 88px) 0;
  border-top: 1px solid var(--line);
}
.seccio-dinamica .section-title {
  margin-bottom: 18px;
}
.seccio-dinamica .section-intro {
  max-width: 720px;
  font-size: clamp(15px, 2vw, 17px);
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 28px;
}
.sec-fotos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
  margin-top: 20px;
}
.sec-foto-item {
  aspect-ratio: 4/3;
  border-radius: 16px;
  overflow: hidden;
  background: #f0f4f8;
}
.sec-foto-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease;
}
.sec-foto-item:hover img { transform: scale(1.04); }

/* ── Galeries dinàmiques ───────────────────────────────────── */
.galeries-section {
  padding: clamp(48px, 6vw, 88px) 0;
  background: var(--bg-alt);
}
.galeries-grid {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin-top: 28px;
}
.galeria-card {
  background: #fff;
  border-radius: 20px;
  padding: 24px 26px;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--line);
}
.galeria-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--line);
}
.subgaleria {
  margin-bottom: 20px;
}
.subgaleria-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.subgaleria-fotos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.subgal-foto {
  aspect-ratio: 4/3;
  border-radius: 10px;
  overflow: hidden;
  display: block;
  background: #f0f4f8;
}
.subgal-foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease;
}
.subgal-foto:hover img { transform: scale(1.06); }

/* ════════════════════════════════════════════════════════════
   ESCOLA DE REM — Formulari públic redissenyat (estil gestió)
   ════════════════════════════════════════════════════════════ */
.school-page {
  background: #eef2f7 !important;
  padding: 22px 16px !important;
  color: #2C2C2A;
  font-family: 'Segoe UI', system-ui, sans-serif !important;
}
.school-shell {
  width: min(1100px, 100%) !important;
  margin: 0 auto !important;
}

/* Top bar amb estil del topbar de gestió */
.school-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: linear-gradient(90deg, #092f56, #0C447C 35%, #1560a8) !important;
  color: #fff !important;
  padding: 12px 18px !important;
  border-radius: 12px !important;
  margin-bottom: 14px !important;
  box-shadow: 0 4px 20px rgba(9,47,86,.3) !important;
}
.school-back {
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  opacity: .9 !important;
  text-decoration: none !important;
}
.school-back:hover { opacity: 1 !important; }
.school-brand {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: #fff !important;
  text-align: right !important;
}
.school-logo {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #fff !important;
  color: #0C447C !important;
  font-size: 18px !important;
  display: grid !important;
  place-items: center !important;
  border: none !important;
}
.school-brand strong {
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: .01em !important;
}
.school-brand span {
  font-size: 11px !important;
  opacity: .8 !important;
}

/* Hero (capçalera del formulari) */
.school-hero-form {
  background: #fff !important;
  border: 1px solid rgba(181,212,244,.5) !important;
  border-radius: 16px !important;
  padding: 22px 26px !important;
  box-shadow: 0 4px 16px rgba(12,68,124,.07) !important;
  margin-bottom: 14px !important;
  grid-template-columns: 1.4fr .6fr !important;
  gap: 22px !important;
  align-items: center !important;
}
.school-hero-form .section-tag {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  color: #185FA5 !important;
  margin: 0 0 8px !important;
}
.school-hero-form h1 {
  font-size: 26px !important;
  margin: 0 0 8px !important;
  color: #0C447C !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  line-height: 1.15 !important;
}
.school-hero-form p {
  font-size: 13px !important;
  color: #5F5E5A !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}
.school-summary { display: grid !important; gap: 6px !important; }
.school-summary span {
  background: #E6F1FB !important;
  color: #0C447C !important;
  border: 1px solid #B5D4F4 !important;
  font-size: 12px !important;
  padding: 9px 12px !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
}

/* Formulari principal */
.school-form {
  background: #fff !important;
  border: 1px solid rgba(181,212,244,.5) !important;
  border-radius: 16px !important;
  padding: 20px !important;
  box-shadow: 0 4px 16px rgba(12,68,124,.07) !important;
  display: grid !important;
  gap: 16px !important;
}

.form-section {
  background: #fff !important;
  border: 1px solid #e0e8f4 !important;
  border-radius: 12px !important;
  padding: 18px 20px !important;
}

.form-section-title {
  display: flex !important;
  gap: 12px !important;
  align-items: center !important;
  margin-bottom: 14px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid #e0e8f4 !important;
}
.form-section-title > span {
  flex: 0 0 30px !important;
  height: 30px !important;
  border-radius: 8px !important;
  background: linear-gradient(135deg, #0C447C, #185FA5) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  display: grid !important;
  place-items: center !important;
}
.form-section-title h2 {
  font-size: 14px !important;
  margin: 0 !important;
  color: #0C447C !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.form-section-title p {
  font-size: 11px !important;
  color: #5F5E5A !important;
  margin: 2px 0 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 500 !important;
}

/* Camps de formulari */
.school-form label {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #5F5E5A !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  display: grid !important;
  gap: 5px !important;
}
.school-form input:not([type="radio"]):not([type="checkbox"]),
.school-form select,
.school-form textarea {
  border: 1.5px solid #D3D1C7 !important;
  border-radius: 8px !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #2C2C2A !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  background: #fff !important;
  transition: border-color .15s, box-shadow .15s !important;
  width: 100% !important;
}
.school-form input:not([type="radio"]):not([type="checkbox"]):focus,
.school-form select:focus,
.school-form textarea:focus {
  border-color: #185FA5 !important;
  box-shadow: 0 0 0 3px rgba(24,95,165,.12) !important;
  outline: none !important;
}

/* Amaga els radios/checkboxes que han de quedar invisibles dins targes */
.school-form .visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.school-form input::placeholder,
.school-form textarea::placeholder {
  color: #b3bfd0 !important;
  font-weight: 400 !important;
}
.field-grid { gap: 12px !important; margin-top: 10px !important; }

/* Cartes de preu i torn */
.pricing-modern {
  gap: 16px !important;
  grid-template-columns: 1fr 1fr !important;
}
.pricing-group {
  gap: 8px !important;
  background: #f8fafc !important;
  border: 1px solid #e0e8f4 !important;
  border-radius: 12px !important;
  padding: 14px !important;
}
.pricing-group h3 {
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: #fff !important;
  font-weight: 700 !important;
  padding: 7px 12px !important;
  border-bottom: none !important;
  margin: 0 0 4px !important;
  background: linear-gradient(135deg, #0C447C, #185FA5) !important;
  border-radius: 8px !important;
  text-align: center !important;
}
.school-price-card,
.turn-card {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-direction: row !important;
  gap: 12px !important;
  border: 1.5px solid #e0e8f4 !important;
  border-radius: 10px !important;
  padding: 11px 14px !important;
  min-height: 52px !important;
  background: #fff !important;
  transition: all .15s !important;
  box-shadow: none !important;
  cursor: pointer !important;
}
.school-price-card:hover,
.turn-card:hover {
  border-color: #185FA5 !important;
  background: #fff !important;
  transform: none !important;
  box-shadow: 0 2px 8px rgba(12,68,124,.08) !important;
}
.school-price-card:has(input:checked),
.turn-card:has(input:checked) {
  border-color: #0C447C !important;
  background: #E6F1FB !important;
  box-shadow: 0 2px 10px rgba(12,68,124,.18) !important;
}
.school-price-card > span,
.turn-card > span {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: #2C2C2A !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  flex: 1 !important;
  display: block !important;
}
.school-price-card small {
  display: block !important;
  font-size: 11px !important;
  color: #5F5E5A !important;
  font-weight: 500 !important;
  margin-top: 2px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.school-price-card strong {
  font-size: 18px !important;
  color: #0C447C !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.turn-title {
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: #0C447C !important;
  font-weight: 700 !important;
  margin: 22px 0 0 !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid #e0e8f4 !important;
}
.turn-modern {
  margin-top: 12px !important;
  gap: 12px !important;
  grid-template-columns: 1fr 1fr !important;
}
.turn-card {
  background: #f8fafc !important;
  border: 1.5px dashed #b5d4f4 !important;
  justify-content: center !important;
  position: relative !important;
  min-height: 56px !important;
}
.turn-card:hover {
  background: #fff !important;
  border: 1.5px dashed #185FA5 !important;
}
.turn-card:has(input:checked) {
  background: linear-gradient(135deg, #0C447C, #185FA5) !important;
  border: 1.5px solid #0C447C !important;
  box-shadow: 0 4px 14px rgba(12,68,124,.28) !important;
}
.turn-card:has(input:checked) > span {
  color: #fff !important;
  font-weight: 800 !important;
}
.turn-card:has(input:checked)::after {
  content: "✓";
  position: absolute !important;
  right: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  background: rgba(255,255,255,.18) !important;
  width: 26px !important;
  height: 26px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 50% !important;
  border: 1.5px solid rgba(255,255,255,.35) !important;
}
.turn-card > span {
  flex: 0 0 auto !important;
  text-align: center !important;
}

/* Total */
.school-total {
  background: linear-gradient(135deg, #0C447C, #185FA5) !important;
  color: #fff !important;
  padding: 14px 18px !important;
  border-radius: 10px !important;
  margin-top: 14px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}
.school-total span {
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  opacity: .92 !important;
  color: #fff !important;
}
.school-total strong {
  font-size: 22px !important;
  color: #fff !important;
  font-weight: 800 !important;
}

/* Caixa legal */
.school-legal {
  background: #fbfdff !important;
  border: 1px solid #e0e8f4 !important;
  border-radius: 10px !important;
  padding: 16px !important;
  gap: 12px !important;
}
.school-legal p {
  font-size: 12px !important;
  color: #5F5E5A !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}
.school-legal p strong { color: #0C447C !important; }
.school-legal details {
  border: 1px solid #e0e8f4 !important;
  border-radius: 8px !important;
}
.school-legal summary {
  font-size: 12px !important;
  padding: 10px 12px !important;
  color: #185FA5 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.school-legal details div {
  font-size: 12px !important;
  color: #5F5E5A !important;
  padding: 0 12px 12px !important;
  display: grid !important;
  gap: 8px !important;
}

.legal-accept {
  background: #E6F1FB !important;
  padding: 12px 14px !important;
  border-radius: 8px !important;
  display: flex !important;
  gap: 10px !important;
  font-size: 12px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 600 !important;
  color: #0C447C !important;
  align-items: center !important;
  border: 1px solid #B5D4F4 !important;
  line-height: 1.4 !important;
}
.legal-accept input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  accent-color: #0C447C !important;
  cursor: pointer !important;
}
.legal-accept span {
  display: block !important;
  flex: 1 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Talla samarreta més estreta + observacions ample, balancejades */
.field-grid.cols-2.talla-obs {
  grid-template-columns: 220px 1fr !important;
  align-items: start !important;
}

/* ── Botó «Demanar informació» a la home ─────────────────── */
.btn.btn-info {
  background: #fff !important;
  color: #0C447C !important;
  border: 2px solid #0C447C !important;
  font-weight: 900 !important;
  box-shadow: 0 6px 18px rgba(12,68,124,.15) !important;
  transition: all .18s ease !important;
}
.btn.btn-info:hover {
  background: #0C447C !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 26px rgba(12,68,124,.28) !important;
}

/* Botons sticky */
.school-actions-sticky {
  margin-top: 6px !important;
  padding: 14px 0 6px !important;
  background: transparent !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
}
.school-actions-sticky .btn {
  font-size: 13px !important;
  padding: 10px 20px !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.school-actions-sticky .btn:not(.btn-soft) {
  background: linear-gradient(135deg, #0C447C, #185FA5) !important;
  color: #fff !important;
}
.school-actions-sticky .btn-soft {
  background: #fff !important;
  color: #5F5E5A !important;
  border: 1.5px solid #D3D1C7 !important;
}

.school-final-msg {
  text-align: right !important;
  font-size: 13px !important;
  margin-top: 8px !important;
}

/* Mòbil */
@media (max-width: 900px) {
  .school-hero-form { grid-template-columns: 1fr !important; }
  .school-page { padding: 14px 10px !important; }
  .school-top { padding: 10px 14px !important; }
  .school-form { padding: 16px !important; }
  .form-section { padding: 14px 16px !important; }
  .pricing-modern, .turn-modern { grid-template-columns: 1fr !important; }
  .field-grid.cols-3, .field-grid.cols-2, .field-grid.address-grid {
    grid-template-columns: 1fr !important;
  }
  .school-hero-form h1 { font-size: 22px !important; }
}

/* ── Logo del Club al header/footer (img dins .brand-icon) ── */
.brand-icon {
  background: #fff !important;
  padding: 3px;
  overflow: hidden;
}
.brand-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: inherit;
}

/* ── Imatges de Llagut / Batel a la secció Rem ─────────── */
.competition-cards article {
  overflow: hidden;
  padding: 0 !important;
}
.competition-cards .comp-img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(135deg, #082c54, #1a6bbf);
}
.competition-cards .comp-body {
  padding: 18px 22px 22px;
}
.competition-cards .comp-body h3 {
  margin: 0 0 6px;
  font-size: 22px;
  color: var(--ink);
}
.competition-cards .comp-body p {
  margin: 0;
  color: var(--muted);
}

/* ── Calendari interactiu ────────────────────────────────── */
.calendar-day {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all .18s ease;
  user-select: none;
}
.calendar-day .day-num {
  display: block !important;
  font-weight: 800 !important;
  font-size: 17px !important;
  line-height: 1 !important;
  color: inherit !important;
}
.calendar-day.today .day-num,
.calendar-day.today .event-dot,
.calendar-day.today .event-count { color: #fff !important; }
.calendar-day.has-event {
  cursor: pointer;
  background: linear-gradient(135deg, #EAF5FF, #ffffff);
  border-color: #A9D8F8;
  box-shadow: 0 2px 6px rgba(12,68,124,.06);
}
.calendar-day.has-event:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #DCEEFF, #F4FAFF);
  border-color: #2E8BCB;
  box-shadow: 0 8px 18px rgba(12,68,124,.18);
}
.calendar-day.today {
  background: linear-gradient(135deg, #0C447C, #2E8BCB);
  color: #fff;
  border-color: #0C447C;
  box-shadow: 0 6px 14px rgba(12,68,124,.28);
}
.calendar-day.today .day-num { color: #fff; }
.calendar-day.today.has-event { color: #fff; }
.calendar-day.today.has-event:hover { background: linear-gradient(135deg, #07335E, #1F76B6); }
.calendar-day.selected {
  outline: 3px solid #2E8BCB;
  outline-offset: -2px;
}
.calendar-day .event-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--blue);
  position: absolute;
  right: 8px;
  bottom: 8px;
}
.calendar-day.today .event-dot { background: #fff; }
.calendar-day .event-count {
  position: absolute;
  right: 6px;
  bottom: 6px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: var(--river);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  display: grid;
  place-items: center;
  box-shadow: 0 2px 6px rgba(12,68,124,.3);
}
.calendar-day.today .event-count {
  background: #fff;
  color: var(--navy);
}
.event-item.today-event {
  border-left: 4px solid var(--river);
  background: linear-gradient(135deg, #EAF5FF, #fff);
}
.event-item.highlight-event {
  border-left: 4px solid var(--river);
  background: #fff;
  box-shadow: 0 6px 16px rgba(12,68,124,.12);
  animation: pulseHi .8s ease-out;
}
@keyframes pulseHi {
  0%   { transform: scale(.97); box-shadow: 0 0 0 rgba(46,139,203,.6); }
  50%  { transform: scale(1.01); box-shadow: 0 0 0 8px rgba(46,139,203,0); }
  100% { transform: scale(1);    box-shadow: 0 6px 16px rgba(12,68,124,.12); }
}

/* ══════════════════════════════════════════════════════════════
   MOBILE POLISH — targets tàctils, anti-zoom iOS, smooth scroll
   ══════════════════════════════════════════════════════════════ */

/* Tipografia base mòbil i previsió de jank d'scroll */
html { scroll-padding-top: 92px; }

/* Smooth scroll i contenció a iOS dins de modals/drawers */
.modal-card, .nav-links, .muletes-carousel {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* Imatges responsives i bloqueig de layout shifts */
img { max-width: 100%; height: auto; }

/* Focus visible global per accessibilitat (teclat) */
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 2px;
  border-radius: 8px;
}

/* Carousel · transform-based marquee (suau, sense scrollbar)
   Sobreescriu el comportament inicial scroll-based del bloc minified. */
.muletes-carousel {
  overflow: hidden !important;          /* el track es mou amb transform, no amb scroll */
  scroll-behavior: auto !important;
  scroll-snap-type: none !important;
  cursor: grab;
  touch-action: pan-y;                  /* permet scroll vertical, capturem horitzontal */
}
.muletes-carousel.dragging { cursor: grabbing; }
.carousel-track {
  will-change: transform;
  transform: translate3d(0,0,0);
  backface-visibility: hidden;
}
.muleta-slide {
  scroll-snap-align: none;
  transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s ease;
}
@media (hover: hover) and (pointer: fine) {
  .muleta-slide:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 36px 80px rgba(7,55,99,.28) !important;
    z-index: 1;
  }
}
.muleta-slide .slide-img {
  transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.muleta-slide:hover .slide-img { transform: scale(1.07); }
@media (prefers-reduced-motion: reduce) {
  .muleta-slide:hover { transform: none; }
  .muleta-slide:hover .slide-img { transform: none; }
}

/* ── Mòbil (≤820px): anti-zoom iOS i targets tàctils ─────────── */
@media(max-width:820px){
  /* iOS NO fa zoom auto si l'input és ≥16px */
  input, select, textarea, .quote-input { font-size: 16px !important; }

  /* Botons: alçada tàctil mínima 48px */
  .btn, .btn-light, .btn-soft, .close-link {
    min-height: 48px;
    padding: 14px 20px;
    font-size: 15px;
  }

  /* Drawer del menú no tapa contingut: scroll si calen molts links */
  .nav-links {
    max-height: calc(100vh - 100px);
    overflow-y: auto;
  }
  .nav-links a {
    padding: 14px 8px;
    min-height: 48px;
    display: flex;
    align-items: center;
  }

  /* Modal cards: mai més gran que la pantalla menys safe-area */
  .modal-card {
    max-height: 90vh;
    width: min(900px, calc(100% - 24px));
    margin: 12px auto;
  }

  /* Forms: labels una mica més grans, inputs més respiració */
  label { font-size: 14px; }
  input, select, textarea { padding: 14px 14px; }
  .form-row { gap: 10px; }
}

/* ── Smartphones petits (≤420px) ─────────────────────────────── */
@media(max-width:420px){
  .container, .navbar { width: calc(100% - 28px); }
  .hero { padding: 70px 0 !important; }
  .section { padding: 56px 0 !important; }
  .modal-img { height: 220px; }
  .alta-form { padding: 16px; }
  .alta-actions { gap: 8px; }
  .alta-actions .btn { padding: 14px 12px; font-size: 14px; }
}

/* === EDITORIAL FLUVIAL · refinaments puntuals === */
.hero h1,
.showcase-head h2,
.section h2,
.alta-header h1,
.modal-body h2 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -.045em;
}

.hero h1 { letter-spacing: -.05em; line-height: .92; }

/* CTA fluvial puntual (per l'únic CTA principal) */
.btn-cyan {
  background: var(--cyan) !important;
  color: #fff !important;
  box-shadow: 0 12px 30px rgba(14,165,233,.25);
}

/* Eyebrow + section-tag amb cyan en lloc del blau pàl·lid */
.eyebrow, .section-tag {
  color: var(--cyan);
  font-weight: 600;
  letter-spacing: .14em;
}

/* === BOTONS GLOBALS · variants de l'editorial fluvial === */
/* (definits sense scope perquè funcionin a qualsevol secció — sobreescriuen el .btn base) */
.btn-dark {
  background: var(--ink) !important;
  color: #fff !important;
  border-radius: 999px;
  padding: 14px 26px;
  font-weight: 600 !important;
  font-size: 15px;
  box-shadow: 0 12px 30px rgba(6,24,39,.18);
  transition: transform .2s ease, box-shadow .2s ease;
  border: 0;
}
.btn-dark:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(6,24,39,.25); }

.btn-outline {
  background: #fff !important;
  color: var(--ink) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 999px;
  padding: 13px 26px;
  font-weight: 600 !important;
  font-size: 15px;
  box-shadow: none !important;
  transition: border-color .2s ease, transform .2s ease;
}
.btn-outline:hover { border-color: var(--ink) !important; transform: translateY(-2px); }

.btn-soft {
  background: rgba(10,42,78,.06) !important;
  color: var(--ink) !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px;
  padding: 13px 24px;
  font-weight: 600 !important;
  font-size: 14px;
  box-shadow: none !important;
  transition: background .2s ease;
}
.btn-soft:hover { background: rgba(10,42,78,.12) !important; }

.btn-light {
  background: #fff !important;
  color: var(--ink) !important;
  border: 1px solid var(--border) !important;
  border-radius: 999px;
  padding: 13px 24px;
  font-weight: 600 !important;
  box-shadow: none !important;
}
.btn-light:hover { background: rgba(10,42,78,.04) !important; }

/* === ESCOLA DE REM · estètica IDÈNTICA al formulari d'alta de soci === */
/* Fons editorial i tipografia Inter (mateix que alta-page) */
body.school-page {
  background: linear-gradient(180deg, #F6F8FB, #EFF5FB) !important;
  font-family: var(--font-sans) !important;
  color: var(--ink) !important;
  padding: 0 !important;
  margin: 0 !important;
}
.school-shell {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Form-section blocks com a alta-block */
.school-form .form-section {
  background: #fff !important;
  border-radius: 24px !important;
  padding: clamp(28px, 4vw, 48px) !important;
  box-shadow: 0 12px 50px rgba(10,42,78,.06) !important;
  border: 1px solid rgba(10,42,78,.05) !important;
  margin-bottom: 24px !important;
}
.school-form .form-section-title {
  display: flex !important;
  gap: 18px !important;
  align-items: flex-start !important;
  margin-bottom: 32px !important;
  padding-bottom: 24px !important;
  border-bottom: 1px solid rgba(10,42,78,.08) !important;
}
.school-form .form-section-title > span:first-child {
  font-family: var(--font-display) !important;
  font-size: 44px !important;
  font-weight: 600 !important;
  color: var(--cyan) !important;
  letter-spacing: -.04em !important;
  line-height: .9 !important;
  background: none !important;
  border: 0 !important;
  padding: 0 !important;
  display: inline-block !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  flex-shrink: 0;
}
.school-form .form-section-title h2 {
  font-family: var(--font-display) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  letter-spacing: -.03em !important;
  line-height: 1 !important;
  color: var(--ink) !important;
  margin: 0 0 6px !important;
  text-transform: none !important;
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.school-form .form-section-title p {
  font-size: 14px !important;
  color: var(--muted) !important;
  margin: 0 !important;
}

/* Field grids com a alta-grid */
.school-form .field-grid {
  display: grid !important;
  gap: 18px !important;
  margin-bottom: 18px !important;
}
.school-form .field-grid:last-child { margin-bottom: 0 !important; }
.school-form .field-grid.cols-2 { grid-template-columns: 1fr 1fr !important; }
.school-form .field-grid.cols-3 { grid-template-columns: repeat(3, 1fr) !important; }
.school-form .field-grid.cols-4 { grid-template-columns: repeat(4, 1fr) !important; }
@media(max-width: 720px) {
  .school-form .field-grid.cols-2,
  .school-form .field-grid.cols-3,
  .school-form .field-grid.cols-4 {
    grid-template-columns: 1fr !important;
  }
}

/* Labels com a alta */
.school-form label {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.school-form label input,
.school-form label select,
.school-form label textarea {
  background: #FAFCFE !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 13px 14px !important;
  font-family: var(--font-sans) !important;
  font-size: 15px !important;
  color: var(--ink) !important;
  font-weight: 400 !important;
  outline: 0 !important;
  transition: border-color .15s, box-shadow .15s !important;
}
.school-form label input:focus,
.school-form label select:focus,
.school-form label textarea:focus {
  border-color: var(--cyan) !important;
  box-shadow: 0 0 0 3px rgba(14,165,233,.12) !important;
  background: #fff !important;
}

/* Card principal */
.school-shell {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  padding: 0 !important;
}

/* Top bar */
/* Topbar com a alta-topbar (sticky, glass, gradients) */
.school-top {
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
  background: rgba(247,250,253,.92) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  border-bottom: 1px solid rgba(10,42,78,.08) !important;
  padding: 16px clamp(20px, 5vw, 48px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  border-radius: 0 !important;
  flex-wrap: wrap;
}
.school-back {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: var(--ink) !important;
  text-decoration: none !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  background: rgba(10,42,78,.06) !important;
  border: 0 !important;
  box-shadow: none !important;
  transition: background .2s ease !important;
}
.school-back:hover {
  background: rgba(10,42,78,.12) !important;
  border: 0 !important;
}
.school-brand { display: flex; align-items: center; gap: 12px; }
.school-logo {
  width: 42px !important; height: 42px !important;
  border-radius: 50% !important;
  background: #fff !important;
  overflow: hidden !important;
  box-shadow: 0 4px 14px rgba(10,42,78,.14) !important;
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
  color: var(--ink) !important;
}
.school-logo img {
  width: 100% !important; height: 100% !important; object-fit: contain !important;
}
.school-brand > div { display: flex; flex-direction: column; line-height: 1.15; }
.school-brand strong {
  font-size: 14px !important; font-weight: 700 !important;
  color: var(--ink) !important; font-family: var(--font-sans) !important;
}
.school-brand span {
  font-size: 12px !important; color: var(--muted) !important;
  font-style: italic; font-weight: 400 !important;
  letter-spacing: 0 !important;
}

/* Shell central com a alta-shell */
.school-shell {
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: clamp(40px, 6vw, 80px) clamp(20px, 5vw, 48px) 120px !important;
  background: transparent !important;
}

/* Hero del formulari com a alta-hero (split 1.4fr 1fr amb resum a la dreta) */
.school-hero-form {
  display: grid !important;
  grid-template-columns: 1.4fr 1fr !important;
  gap: 48px !important;
  align-items: start !important;
  margin-bottom: 64px !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}
@media (max-width: 900px) {
  .school-hero-form { grid-template-columns: 1fr !important; gap: 28px !important; }
}
.school-hero-form .section-tag {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .2em !important;
  text-transform: uppercase !important;
  color: var(--cyan) !important;
  margin: 0 0 16px !important;
}
.school-hero-form h1 {
  font-family: var(--font-display) !important;
  font-size: clamp(48px, 7vw, 96px) !important;
  font-weight: 600 !important;
  letter-spacing: -.05em !important;
  line-height: .92 !important;
  color: var(--ink) !important;
  margin: 0 0 20px !important;
}
.school-hero-form p {
  font-size: 17px !important;
  line-height: 1.55 !important;
  color: var(--muted) !important;
  max-width: 520px !important;
  margin: 0 !important;
  text-align: justify;
}
.school-hero-form p strong { color: var(--ink); font-weight: 700; }

/* Resum lateral com a alta-stepper (sticky card) */
.school-summary {
  position: sticky !important;
  top: 96px !important;
  background: #fff !important;
  border: 1px solid rgba(10,42,78,.06) !important;
  border-radius: 18px !important;
  padding: 24px !important;
  box-shadow: 0 10px 40px rgba(10,42,78,.08) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
.school-summary span {
  color: var(--ink) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(10,42,78,.06) !important;
  text-transform: none !important;
}
.school-summary span:last-child { border-bottom: 0 !important; }

/* Form (sense card-fons; cada section.form-section ja és card via les regles d'amunt) */
.school-form {
  background: transparent !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}
.school-form fieldset {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  padding: 22px 24px !important;
  background: #FAFCFE !important;
}
.school-form legend, .school-form h2, .school-form .school-section-title {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ink);
  font-size: 18px;
  letter-spacing: -.02em;
  padding: 0 8px;
}
.school-form label {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
}
.school-form input, .school-form select, .school-form textarea {
  background: #FAFCFE !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 13px 14px !important;
  font-family: var(--font-sans) !important;
  font-size: 15px !important;
  color: var(--ink) !important;
  transition: border-color .15s, box-shadow .15s;
}
.school-form input:focus, .school-form select:focus, .school-form textarea:focus {
  border-color: var(--cyan) !important;
  box-shadow: 0 0 0 3px rgba(14,165,233,.12) !important;
  outline: 0 !important;
}

/* Quota cards (preus de l'escola) */
.school-price-card {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  padding: 18px 18px !important;
  background: #fff !important;
  cursor: pointer;
  transition: all .18s;
}
.school-price-card:hover {
  border-color: var(--cyan) !important;
  transform: translateY(-2px);
}
.school-price-card:has(.school-check:checked) {
  border-color: var(--cyan) !important;
  background: linear-gradient(135deg, rgba(14,165,233,.08), #fff) !important;
  box-shadow: 0 14px 40px rgba(14,165,233,.14) !important;
}
.school-price-card span { font-size: 14px; font-weight: 600; color: var(--ink); }
.school-price-card small { color: var(--muted); }
.school-price-card strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  color: var(--cyan);
  letter-spacing: -.03em;
}

/* Total */
.school-total {
  background: linear-gradient(135deg, var(--ink), #0F3D6E) !important;
  color: #fff !important;
  border-radius: var(--radius-md) !important;
  padding: 22px 26px !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.school-total strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 38px;
  letter-spacing: -.04em;
  color: #fff;
}

/* Legal */
.school-legal {
  background: rgba(10,42,78,.02) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  padding: 18px 22px !important;
}
.school-legal summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--cyan) !important;
  list-style: none;
}
.school-legal summary::-webkit-details-marker { display: none; }

/* Actions sticky */
.school-actions-sticky {
  display: flex !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  margin-top: 12px !important;
  padding: 16px 44px 28px !important;
  position: sticky !important;
  bottom: 0 !important;
  background: rgba(255,255,255,.92) !important;
  backdrop-filter: blur(12px) !important;
  border-top: 1px solid var(--border) !important;
}
.school-actions-sticky .btn:not(.btn-soft):not(.btn-outline) {
  background: var(--cyan) !important;
  color: #fff !important;
  box-shadow: 0 8px 24px rgba(14,165,233,.32) !important;
  border-radius: 999px !important;
  padding: 14px 28px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  border: 0 !important;
}
.school-actions-sticky .btn:not(.btn-soft):not(.btn-outline):hover {
  background: var(--cyan-2) !important;
  box-shadow: 0 12px 32px rgba(14,165,233,.44) !important;
  transform: translateY(-1px);
}
.school-final-msg { margin-top: 14px; text-align: right; }

/* ════════════════════════════════════════════════════════════════════
   EDITORIAL FLUVIAL · POLISH GLOBAL
   Aplica el sistema visual a tot el lloc públic (cap excepció)
   ════════════════════════════════════════════════════════════════════ */

/* ── Tipografia base ─────────────────────────────────────────────── */
body {
  font-family: var(--font-sans) !important;
  font-weight: 400 !important;
  color: var(--text);
  background: var(--canvas) !important;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display) !important;
  font-weight: 600 !important;
  color: var(--ink);
  letter-spacing: -.035em;
  line-height: 1.05;
}
h1 { letter-spacing: -.05em; line-height: .95; }
h2 { letter-spacing: -.045em; }

/* Strong/bold = 700 (no 900) */
strong, b { font-weight: 700; }

/* ── Eyebrow + section-tag uniforme ──────────────────────────────── */
.eyebrow,
.section-tag,
.hero-split-eyebrow {
  color: var(--cyan) !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  font-size: 12px !important;
  margin-bottom: 14px !important;
}

/* ── Header / navbar ─────────────────────────────────────────────── */
.site-header {
  background: rgba(255,255,255,.85) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-bottom: 1px solid var(--border) !important;
}
.brand strong {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -.02em;
  font-size: 16px;
}
.brand small {
  color: var(--muted);
  font-size: 11px;
  letter-spacing: .04em;
}
.brand-icon {
  background: linear-gradient(135deg, var(--ink), var(--blue)) !important;
  border-radius: 12px !important;
  width: 44px !important;
  height: 44px !important;
  box-shadow: 0 12px 28px rgba(10,42,78,.20) !important;
}
.nav-links a {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 14px;
  color: var(--ink) !important;
  transition: color .15s;
}
.nav-links a:not(.nav-cta):hover { color: var(--cyan) !important; }
.nav-links a.nav-active:not(.nav-cta) { color: var(--cyan) !important; }
.nav-cta {
  background: var(--cyan) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 10px 18px !important;
  box-shadow: 0 8px 22px rgba(14,165,233,.28);
  font-weight: 600 !important;
}
.nav-cta:hover { background: var(--cyan-2) !important; color: #fff !important; }
/* Estat actiu (scroll-spy): el CTA cyan manté text blanc, no l'enfosqueix */
.nav-cta.nav-active,
.nav-links a.nav-cta.nav-active {
  background: var(--cyan-2) !important;
  color: #fff !important;
}

/* ── Botó base reset (eliminar font-weight 900) ──────────────────── */
.btn {
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
}

/* ── Seccions: respiració editorial ──────────────────────────────── */
.section {
  padding: clamp(72px, 9vw, 120px) 0 !important;
  background: #fff;
}
.section-soft { background: var(--soft) !important; }
.section h2 {
  font-size: clamp(36px, 5vw, 56px) !important;
  margin-bottom: 18px !important;
  color: var(--ink) !important;
}
.intro {
  color: var(--muted) !important;
  font-size: 17px;
  line-height: 1.6;
  max-width: 720px;
}

/* ── Cards (sistema unificat) ────────────────────────────────────── */
.facility-card,
.form-card,
.stats-card,
.events-panel,
.calendar-card-pro,
.competition-cards article {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-soft) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}
@media (hover: hover) and (pointer: fine) {
  .facility-card:hover,
  .competition-cards article:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-card) !important;
  }
}
.stats-card {
  background: linear-gradient(180deg, #fff, var(--soft)) !important;
}
.stats-card div {
  background: #fff !important;
  border-radius: var(--radius-md) !important;
  padding: 18px !important;
  border: 1px solid var(--border);
}
.stats-card strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  color: var(--ink);
  letter-spacing: -.03em;
}
.stats-card span {
  color: var(--muted);
  font-size: 13px;
}

/* Facility cards · header amb ic·loneta */
.facility-card .card-visual {
  height: 180px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--soft), var(--sky-2));
  border-bottom: 1px solid var(--border);
}
.facility-card .card-visual span {
  font-size: 56px;
  filter: drop-shadow(0 10px 20px rgba(10,42,78,.10));
}
.facility-card > div:not(.card-visual) {
  padding: 24px 22px !important;
}
.facility-card h3 {
  font-size: 22px;
  margin: 6px 0 8px !important;
  color: var(--ink);
}
.facility-card p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}

/* ── Calendar editorial ──────────────────────────────────────────── */
.calendar-card-pro {
  padding: 24px !important;
}
.calendar-header button {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  padding: 9px 14px !important;
  cursor: pointer;
  transition: border-color .15s;
}
.calendar-header button:hover { border-color: var(--cyan) !important; }
.calendar-weekdays span {
  color: var(--muted) !important;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.calendar-day {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
}

/* ── Modal editorial ─────────────────────────────────────────────── */
.modal-card {
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-strong) !important;
}
.modal-img {
  background: linear-gradient(135deg, var(--cyan), var(--navy)) !important;
}
.modal-body h2 {
  font-family: var(--font-display) !important;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 42px) !important;
  letter-spacing: -.04em;
}
.modal-body p { color: var(--muted) !important; }
.modal-actions {
  background: var(--soft) !important;
  color: var(--ink) !important;
  border-radius: var(--radius-md) !important;
  border: 1px solid var(--border);
  font-weight: 500 !important;
}

/* ── Forms web (reserva piragües, info soci, rem, escola info) ──── */
.form-card {
  padding: 28px !important;
}
.form-card label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: .03em;
}
.form-card input,
.form-card select,
.form-card textarea {
  background: #FAFCFE !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 13px 14px !important;
  font-family: var(--font-sans) !important;
  font-size: 15px !important;
  color: var(--ink) !important;
  transition: border-color .15s, box-shadow .15s;
}
.form-card input:focus,
.form-card select:focus,
.form-card textarea:focus {
  border-color: var(--cyan) !important;
  box-shadow: 0 0 0 3px rgba(14,165,233,.12) !important;
  outline: 0 !important;
}
.form-message {
  font-family: var(--font-sans);
  font-weight: 600;
  color: var(--ink);
}
.form-message.msg-ok { color: #0F7A3D; }
.form-message.msg-err { color: #A61E1E; }
.form-message.msg-send { color: var(--cyan); }

/* ── Join highlight (CTA panel) ──────────────────────────────────── */
.join-highlight {
  background: linear-gradient(135deg, var(--ink), var(--navy)) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--radius-lg) !important;
  padding: 32px !important;
  box-shadow: var(--shadow-card) !important;
}
.join-highlight strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  letter-spacing: -.03em;
  color: #fff;
}
.join-highlight span {
  color: var(--aqua) !important;
  font-size: 14px;
  margin-top: 10px;
}

/* ── Availability cards (piragües) ───────────────────────────────── */
.availability div {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  padding: 20px !important;
  text-align: center;
}
.availability strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 32px;
  color: var(--cyan);
  letter-spacing: -.04em;
}
.availability span { color: var(--muted) !important; }

/* ── Footer editorial ────────────────────────────────────────────── */
.site-footer {
  background: var(--ink) !important;
  color: #fff !important;
  padding: 48px 0 32px !important;
}
.site-footer a { color: rgba(255,255,255,.78) !important; }
.site-footer a:hover { color: var(--aqua) !important; }
.footer-content { gap: 24px; }
.social-links a {
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 11px 18px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  border: 1px solid rgba(255,255,255,.12);
  transition: all .15s;
}
.social-links a:hover {
  background: var(--cyan) !important;
  border-color: var(--cyan) !important;
}

/* ── Map embed ───────────────────────────────────────────────────── */
.map-embed {
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-soft) !important;
  overflow: hidden;
}

/* ── Section dinàmiques (CMS) ────────────────────────────────────── */
.seccio-dinamica {
  padding: clamp(56px, 7vw, 96px) 0;
  background: #fff;
}
.seccio-dinamica:nth-child(even) { background: var(--soft); }
.seccio-dinamica .section-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(32px, 4vw, 48px);
  letter-spacing: -.04em;
  color: var(--ink);
  margin-bottom: 18px;
}
.seccio-dinamica .section-intro {
  color: var(--muted);
  font-size: 17px;
  line-height: 1.6;
  max-width: 720px;
  margin-bottom: 32px;
}
.sec-fotos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}
.sec-foto-item {
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease;
}
.sec-foto-item:hover { transform: scale(1.02); }
.sec-foto-item img { width: 100%; height: 100%; object-fit: cover; }

/* ── Galeries dinàmiques ─────────────────────────────────────────── */
.galeries-section {
  padding: clamp(72px, 9vw, 120px) 0;
  background: var(--canvas);
}
.galeria-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-soft);
  margin-bottom: 24px;
}
.galeria-title {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ink);
  font-size: 24px;
  margin-bottom: 20px;
  letter-spacing: -.025em;
}
.subgaleria-title {
  color: var(--cyan);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  margin-bottom: 14px;
}
.subgaleria-fotos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 8px;
}
.subgal-foto {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.subgal-foto img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .3s ease;
}

/* ── Hero KPIs · evita flash inicial mentre Firestore carrega ────── */
.hero-split-kpis[data-cms-pending="true"] {
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
}
.hero-split-kpis {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .4s ease, transform .4s ease;
}

/* ── Hero card stats (4 KPIs costat dret) ────────────────────────── */
.hero-split-kpis .hkpi {
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.6);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  box-shadow: 0 10px 30px rgba(10,42,78,.06);
}
.hero-split-kpis .hkpi strong {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 28px;
  letter-spacing: -.03em;
  color: var(--ink);
  display: block;
  line-height: 1;
}
.hero-split-kpis .hkpi span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  margin-top: 6px;
  display: block;
}
.hero-split-kpis .hkpi-accent {
  background: linear-gradient(135deg, var(--cyan), var(--navy)) !important;
  border: 0 !important;
  color: #fff !important;
}
.hero-split-kpis .hkpi-accent strong { color: #fff !important; }
.hero-split-kpis .hkpi-accent span { color: var(--aqua) !important; }

/* ── Eliminar tons càlids residuals ──────────────────────────────── */
.section-soft { background: var(--soft) !important; }
.modal-actions { background: var(--soft) !important; color: var(--ink) !important; }

/* ── Form messages ───────────────────────────────────────────────── */
.msg-send { color: var(--cyan) !important; }
.msg-ok { color: #0F7A3D !important; }
.msg-err { color: #A61E1E !important; }

/* ── Reveal animations més subtils ───────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Reduced motion respect */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ── Mobile spacing ──────────────────────────────────────────────── */
@media(max-width: 820px){
  .section h2 { font-size: clamp(28px, 8vw, 40px) !important; }
  .modal-card { border-radius: var(--radius-md) !important; }
  .form-card { padding: 22px !important; }
  .join-highlight { padding: 24px !important; }
}

/* ════════════════════════════════════════════════════════════════════
   BURGER + DRAWER MÒBIL · WEB PÚBLICA · RESET COMPLET v2
   Enfocament robust: flex column, transform-only, sense `position:absolute`
   ════════════════════════════════════════════════════════════════════ */

/* Per defecte (desktop) el burger no es veu */
.nav-toggle { display: none !important; }
.nav-backdrop { display: none !important; }
.drawer-head { display: none !important; }

/* Mòbil ≤980px: cobreix el rang complet de l'antic CSS i el sobreescriu */
@media(max-width: 980px) {

  /* ── Burger 44×44 amb spans en flex column (sense absolute) ─ */
  .nav-toggle,
  .navbar .nav-toggle,
  header .nav-toggle {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: transparent;
    z-index: 210 !important;
    transition: background .2s ease !important;
    position: relative !important;
    box-shadow: none !important;
    place-items: center !important;
    color: var(--ink) !important;
    font-size: 0 !important;
  }
  .nav-toggle:hover { background: rgba(10,42,78,.06) !important; }
  .nav-toggle:active { background: rgba(10,42,78,.10) !important; }

  /* 3 barres simples — només transform per animar */
  .nav-toggle span,
  .navbar .nav-toggle span {
    display: block !important;
    width: 22px !important;
    height: 2px !important;
    background: var(--ink) !important;
    border-radius: 2px !important;
    transform-origin: center !important;
    transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .2s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
    flex-shrink: 0 !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }

  /* Estat OBERT — el burger queda OCULT (la X la veu només a dins del drawer) */
  .nav-toggle.open,
  .navbar .nav-toggle.open,
  header .nav-toggle.open {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity .15s ease !important;
  }

  /* ── Backdrop (capa fosca darrere del drawer) ─────────────── */
  .nav-backdrop,
  body .nav-backdrop {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(6,24,39,.5) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    z-index: 590 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity .35s ease, visibility .35s ease !important;
    transform: none !important;
    width: auto !important;
    height: auto !important;
  }
  .nav-backdrop.open,
  body .nav-backdrop.open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  /* ── Drawer lateral des de la DRETA — altura COMPLETA ─────── */
  .nav-links,
  header .nav-links,
  .navbar .nav-links {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: min(360px, 88vw) !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: -20px 0 60px rgba(6,24,39,.20) !important;
    transform: translateX(100%) !important;
    transition: transform .35s cubic-bezier(.4,0,.2,1) !important;
    z-index: 600 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior: contain !important;
    gap: 0 !important;
    visibility: visible !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .nav-links.open,
  header .nav-links.open,
  .navbar .nav-links.open {
    transform: translateX(0) !important;
  }
  /* Forçar visibilitat dels items del menú (sobreescriu qualsevol display:none) */
  .nav-links a {
    display: flex !important;
    visibility: visible !important;
  }

  /* Capçalera del drawer */
  .drawer-head {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 22px 24px !important;
    background: linear-gradient(135deg, var(--cyan), var(--navy)) !important;
    color: #fff !important;
    border: 0 !important;
    flex-shrink: 0 !important;
  }
  .drawer-head span {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--aqua);
  }
  .drawer-close {
    width: 40px !important;
    height: 40px !important;
    background: rgba(255,255,255,.18) !important;
    border: 1px solid rgba(255,255,255,.24) !important;
    border-radius: 10px !important;
    color: #fff !important;
    font-size: 22px !important;
    cursor: pointer !important;
    line-height: 1 !important;
    display: grid !important;
    place-items: center !important;
    transition: background .15s !important;
    padding: 0 !important;
  }
  .drawer-close:hover { background: rgba(255,255,255,.28) !important; }

  /* Items del menú */
  .nav-links a {
    display: flex !important;
    align-items: center !important;
    padding: 18px 24px !important;
    font-family: var(--font-sans) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--ink) !important;
    text-decoration: none !important;
    border-bottom: 1px solid var(--border) !important;
    background: #fff !important;
    border-radius: 0 !important;
    transition: background .15s, color .15s, padding-left .15s !important;
    min-height: 56px !important;
  }
  .nav-links a:hover,
  .nav-links a:focus-visible {
    background: var(--soft) !important;
    color: var(--cyan) !important;
    padding-left: 28px !important;
  }
  .nav-links a.nav-active {
    color: var(--cyan) !important;
    background: rgba(14,165,233,.06) !important;
    border-left: 3px solid var(--cyan) !important;
    padding-left: 21px !important;
  }

  /* CTA Contacte: destacat al peu del drawer */
  .nav-links a.nav-cta {
    margin: 18px 24px 24px !important;
    padding: 16px 24px !important;
    background: var(--cyan) !important;
    color: #fff !important;
    border: 0 !important;
    border-radius: 999px !important;
    text-align: center !important;
    justify-content: center !important;
    box-shadow: 0 12px 28px rgba(14,165,233,.30) !important;
    border-bottom: 0 !important;
    min-height: 52px !important;
  }
  .nav-links a.nav-cta:hover {
    background: var(--cyan-2) !important;
    padding-left: 24px !important;
    transform: translateY(-1px);
  }

  /* Body lock quan drawer obert */
  body.menu-open {
    overflow: hidden !important;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .nav-links, .nav-backdrop, .nav-toggle span { transition: none !important; }
}

/* ════════════════════════════════════════════════════════════════════
   NAV ACTIVE · només negreta, sense underline ni canvi de color
   ════════════════════════════════════════════════════════════════════ */
.nav-links a.nav-active::after,
.nav-links a.nav-active::before {
  display: none !important;
  content: none !important;
}
.nav-links a.nav-active:not(.nav-cta) {
  font-weight: 800 !important;
  color: var(--ink) !important;
  border-bottom: 0 !important;
  background: transparent !important;
}
.nav-submenu a.nav-active {
  font-weight: 800 !important;
  color: var(--ink) !important;
  background: transparent !important;
  border-bottom: 1px solid var(--border) !important;
}
.nav-submenu a.nav-active::before {
  background: var(--ink) !important;
  opacity: .6 !important;
}
/* Trigger del grup actiu només pesa més, sense color change */
.nav-group:has(.nav-active) .nav-group-trigger {
  font-weight: 800 !important;
  color: var(--ink) !important;
}

/* ════════════════════════════════════════════════════════════════════
   HERO MÒBIL · títol amb mida adequada (no s'ha de partir paraules)
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  .hero-split-title,
  .hero h1 {
    font-size: clamp(34px, 8.5vw, 56px) !important;
    line-height: 1 !important;
    letter-spacing: -.04em !important;
    word-break: normal !important;
    overflow-wrap: break-word;
    hyphens: none !important;
  }
  .hero-split-eyebrow,
  .eyebrow {
    font-size: 11px !important;
  }
  .hero-split-lead {
    font-size: 15px !important;
  }
}
@media (max-width: 420px) {
  .hero-split-title,
  .hero h1 {
    font-size: 34px !important;
  }
}

/* ════════════════════════════════════════════════════════════════════
   NAV GROUPS · dropdowns desktop + llistat indented al drawer mòbil
   ════════════════════════════════════════════════════════════════════ */

/* DESKTOP (>980px) — dropdowns amb hover/focus */
@media (min-width: 981px) {
  .nav-group {
    position: relative;
    display: inline-flex;
    align-items: center;
  }
  .nav-group-trigger {
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
    cursor: pointer;
  }
  .nav-group-trigger::after {
    content: '';
    width: 6px; height: 6px;
    margin-left: 4px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-2px);
    opacity: .5;
    transition: transform .2s ease, opacity .2s ease;
  }
  .nav-group:hover .nav-group-trigger::after,
  .nav-group:focus-within .nav-group-trigger::after {
    opacity: 1;
    transform: rotate(225deg) translateY(2px);
  }

  /* Submenu desplegable */
  .nav-submenu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 240px;
    padding: 8px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow-card);
    display: flex;
    flex-direction: column;
    gap: 2px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 110;
    margin-top: 4px;
  }
  /* Pont invisible per evitar que es tanqui al moure el ratolí entre trigger i submenu */
  .nav-group::before {
    content: '';
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    height: 12px;
  }
  .nav-group:hover .nav-submenu,
  .nav-group:focus-within .nav-submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
  }
  .nav-submenu a {
    display: block;
    padding: 11px 16px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink) !important;
    text-decoration: none;
    transition: background .15s, color .15s;
    white-space: nowrap;
  }
  .nav-submenu a:hover {
    background: var(--soft);
    color: var(--cyan) !important;
  }
}

/* Estat actiu (scroll-spy) dins del submenu desktop · sense underline lletja */
@media (min-width: 981px) {
  .nav-submenu a.nav-active {
    background: var(--soft) !important;
    color: var(--cyan) !important;
    border-bottom: 0 !important;
  }
  /* Trigger del grup actiu: només color cyan, sense subratllat */
  .nav-group:has(.nav-active) .nav-group-trigger {
    color: var(--cyan) !important;
  }
}

/* MÒBIL (drawer ≤980px) — submenu sempre visible amb indentació */
@media (max-width: 980px) {
  .nav-group {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  .nav-group-trigger {
    background: var(--soft) !important;
    color: var(--cyan) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    padding: 14px 24px !important;
    min-height: 0 !important;
    border-bottom: 1px solid var(--border) !important;
  }
  .nav-group-trigger::after { display: none !important; }
  .nav-group-trigger:hover {
    padding-left: 24px !important;
    background: var(--soft) !important;
    color: var(--cyan) !important;
  }
  .nav-submenu {
    display: flex !important;
    flex-direction: column;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    position: static !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    min-width: 0 !important;
  }
  .nav-submenu a {
    padding: 16px 24px 16px 40px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: var(--ink) !important;
    border-bottom: 1px solid var(--border) !important;
    display: flex !important;
    align-items: center;
    min-height: 52px !important;
  }
  .nav-submenu a::before {
    content: '';
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--cyan);
    margin-right: 12px;
    opacity: .5;
  }
  .nav-submenu a:hover,
  .nav-submenu a:focus-visible {
    background: var(--soft) !important;
    color: var(--cyan) !important;
    padding-left: 44px !important;
  }
  /* Item actiu (scroll-spy) al drawer mòbil — sense subratllat lleig */
  .nav-submenu a.nav-active {
    background: var(--soft) !important;
    color: var(--cyan) !important;
    border-bottom: 1px solid var(--border) !important;
  }
  .nav-submenu a.nav-active::before {
    background: var(--cyan) !important;
    opacity: 1 !important;
  }
}

/* ════════════════════════════════════════════════════════════════════
   HISTÒRIA · pàgina pròpia amb blocs modulars (text + foto reordenables)
   ════════════════════════════════════════════════════════════════════ */
.subpage-body {
  background: linear-gradient(180deg, #F6F8FB, #EFF5FB) !important;
  min-height: 100vh;
}
.historia-content {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.historia-block {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: 0 8px 30px rgba(10,42,78,.05);
  overflow: hidden;
}
.historia-text-block {
  padding: clamp(24px, 3vw, 36px);
  font-size: 17px;
  line-height: 1.65;
  color: var(--text);
}
.historia-text-block p {
  margin: 0 0 16px;
  text-align: justify;
  hyphens: auto;
}
.historia-text-block p:last-child { margin-bottom: 0; }
.historia-photo-block {
  padding: 0;
  margin: 0;
}
.historia-photo-block img {
  width: 100%;
  display: block;
  aspect-ratio: 16/9;
  object-fit: cover;
  background: linear-gradient(135deg, var(--cyan), var(--navy));
}
.historia-caption {
  padding: 12px 18px;
  font-size: 13px;
  color: var(--muted);
  font-style: italic;
  border-top: 1px solid var(--border);
  background: var(--soft);
}
@media (max-width: 540px) {
  .historia-text-block { font-size: 15.5px; line-height: 1.6; }
  .historia-photo-block img { aspect-ratio: 4/3; }
}

/* ════════════════════════════════════════════════════════════════════
   DOCUMENTS · normatives, inscripcions, llibres
   ════════════════════════════════════════════════════════════════════ */
.documents-grups {
  display: grid;
  gap: 32px;
  margin-top: 32px;
}
.docs-grup-titol {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -.025em;
  color: var(--ink);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.docs-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
}
.doc-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px 18px;
  text-decoration: none;
  color: var(--ink);
  box-shadow: 0 4px 14px rgba(10,42,78,.04);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.doc-item:hover {
  transform: translateY(-2px);
  border-color: var(--cyan);
  box-shadow: 0 14px 30px rgba(14,165,233,.10);
}
.doc-icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--cyan), var(--navy));
  color: #fff;
  border-radius: 11px;
  flex-shrink: 0;
}
.doc-icon svg { width: 22px; height: 22px; }
.doc-meta {
  display: flex; flex-direction: column; gap: 3px;
  min-width: 0;
}
.doc-meta strong {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 14px;
  line-height: 1.3;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
}
.doc-desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
}
.doc-size {
  font-family: var(--font-mono, monospace);
  font-size: 10px;
  color: var(--cyan);
  font-weight: 600;
  letter-spacing: .04em;
  margin-top: 2px;
}
.doc-action {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  background: var(--soft);
  color: var(--ink);
  border-radius: 10px;
  flex-shrink: 0;
  transition: background .15s, color .15s;
}
.doc-action svg { width: 18px; height: 18px; }
.doc-item:hover .doc-action { background: var(--cyan); color: #fff; }
@media(max-width: 480px){
  .doc-item { padding: 14px 14px; gap: 10px; }
  .doc-icon { width: 38px; height: 38px; }
  .doc-meta strong { font-size: 13px; }
}

/* ════════════════════════════════════════════════════════════════════
   TEXTOS JUSTIFICATS · paràgrafs llargs (no titles, no eyebrows, no UI)
   ════════════════════════════════════════════════════════════════════ */
.intro,
.section p,
.modal-body p,
.school-hero-form p,
#quisom-textos p,
.seccio-dinamica .section-intro,
.hero-split-lead,
.muletes-lead,
.galeria-card p,
.hero-copy p:not(.eyebrow),
.alta-form > p,
.escola-copy p {
  text-align: justify !important;
  text-justify: inter-word;
  hyphens: auto;
}

/* No justificar elements UI ni titulars */
h1, h2, h3, h4, h5, h6,
.eyebrow, .section-tag, .hero-split-eyebrow,
button, .btn, label, input, select, textarea,
.nav-links a, .nbadge, .bdg, .qt,
.kpi *, .hkpi *, .stats-card *,
.facility-card h3, .availability *,
.modal-actions, .form-message,
.muleta-name, .muleta-tag, .muleta-kicker,
.calendar-day, .event-item span {
  text-align: inherit !important;
  hyphens: manual;
}

/* ════════════════════════════════════════════════════════════════════
   MULETES · noms blancs sobre el gradient navy/cyan del card
   (regla global h1-h6 els posa ink — aquí els forcem blanc)
   ════════════════════════════════════════════════════════════════════ */
.slide-content h3,
.muleta-slide .slide-content h3,
.muleta-card .muleta-name,
.muleta-card .muleta-meta h3 {
  color: #fff !important;
  text-shadow: 0 4px 16px rgba(0,0,0,.35);
}
.slide-placeholder strong,
.slide-placeholder .boat,
.muleta-card .muleta-kicker,
.muleta-card .muleta-tag {
  color: #fff !important;
}
.slide-content,
.slide-content p,
.slide-content .slide-kicker,
.slide-footer,
.slide-footer span {
  color: #fff !important;
}


/* ════════════════════════════════════════════════════════════════════
   PÀGINES LEGALS · estil compartit de avis-legal / privacitat / cookies
   ════════════════════════════════════════════════════════════════════ */
.legal-doc {
  background: #fff;
  border: 1px solid var(--line, #E6EEF6);
  border-radius: 24px;
  padding: clamp(28px, 4vw, 48px);
  box-shadow: 0 18px 48px rgba(7,55,99,.08);
  color: var(--ink, #0A2A4E);
  line-height: 1.7;
}
.legal-doc h2 {
  font-family: var(--font-display, ui-sans-serif), Sora, "Inter", sans-serif;
  font-weight: 600;
  font-size: clamp(20px, 2.4vw, 26px);
  letter-spacing: -.02em;
  color: var(--ink, #0A2A4E);
  margin: 36px 0 14px;
  padding-top: 8px;
  border-top: 1px solid #EAF1F8;
}
.legal-doc h2:first-child { border-top: 0; padding-top: 0; margin-top: 0; }
.legal-doc p { margin: 0 0 14px; color: #2C3E55; }
.legal-doc ul {
  margin: 0 0 18px;
  padding-left: 22px;
}
.legal-doc ul li { margin: 6px 0; color: #2C3E55; }
.legal-doc a {
  color: var(--cyan, #0EA5E9);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.legal-doc a:hover { color: var(--navy, #0A2A4E); }
.legal-doc strong { color: var(--ink, #0A2A4E); font-weight: 700; }
.legal-doc em { color: var(--muted, #5A6F86); font-style: italic; }
.legal-doc code {
  background: #F4F8FD;
  border: 1px solid #E0EAF4;
  border-radius: 6px;
  padding: 1px 7px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .9em;
  color: var(--navy, #0A2A4E);
}
.legal-doc .legal-updated {
  margin-top: 36px;
  padding-top: 18px;
  border-top: 1px dashed #E0EAF4;
  color: var(--muted, #5A6F86);
  font-size: 13px;
  font-style: italic;
}

/* Taula de cookies */
.cookies-table-wrap {
  overflow-x: auto;
  margin: 0 0 22px;
  border-radius: 14px;
  border: 1px solid #E6EEF6;
  -webkit-overflow-scrolling: touch;
}
.cookies-table {
  width: 100

/* ════════════════════════════════════════════════════════════════════
   PÀGINES LEGALS · estil compartit (avis-legal / privacitat / cookies)
   ════════════════════════════════════════════════════════════════════ */
.legal-doc {
  background: #fff;
  border: 1px solid var(--line, #E6EEF6);
  border-radius: 24px;
  padding: clamp(28px, 4vw, 48px);
  box-shadow: 0 18px 48px rgba(7,55,99,.08);
  color: var(--ink, #0A2A4E);
  line-height: 1.7;
}
.legal-doc h2 {
  font-family: var(--font-display, "Sora"), "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(20px, 2.4vw, 26px);
  letter-spacing: -.02em;
  color: var(--ink, #0A2A4E);
  margin: 36px 0 14px;
  padding-top: 8px;
  border-top: 1px solid #EAF1F8;
}
.legal-doc h2:first-child { border-top: 0; padding-top: 0; margin-top: 0; }
.legal-doc p { margin: 0 0 14px; color: #2C3E55; }
.legal-doc ul { margin: 0 0 18px; padding-left: 22px; }
.legal-doc ul li { margin: 6px 0; color: #2C3E55; }
.legal-doc a {
  color: var(--cyan, #0EA5E9);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.legal-doc a:hover { color: var(--navy, #0A2A4E); }
.legal-doc strong { color: var(--ink, #0A2A4E); font-weight: 700; }
.legal-doc em { color: var(--muted, #5A6F86); font-style: italic; }
.legal-doc code {
  background: #F4F8FD;
  border: 1px solid #E0EAF4;
  border-radius: 6px;
  padding: 1px 7px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .9em;
  color: var(--navy, #0A2A4E);
}
.legal-doc .legal-updated {
  margin-top: 36px;
  padding-top: 18px;
  border-top: 1px dashed #E0EAF4;
  color: var(--muted, #5A6F86);
  font-size: 13px;
  font-style: italic;
}

/* Taula de cookies */
.cookies-table-wrap {
  overflow-x: auto;
  margin: 0 0 22px;
  border-radius: 14px;
  border: 1px solid #E6EEF6;
  -webkit-overflow-scrolling: touch;
}
.cookies-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  min-width: 560px;
}
.cookies-table thead th {
  background: linear-gradient(180deg, #F2F8FE, #E8F1FB);
  color: var(--navy, #0A2A4E);
  text-align: left;
  font-weight: 700;
  padding: 12px 14px;
  border-bottom: 1px solid #DCE7F3;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.cookies-table tbody td {
  padding: 12px 14px;
  border-bottom: 1px solid #EEF3F9;
  vertical-align: top;
  color: #2C3E55;
}
.cookies-table tbody tr:last-child td { border-bottom: 0; }
.cookies-table tbody tr:hover { background: #FAFCFE; }
.cookies-table code { font-size: 12px; }

/* Cookie banner · modal centrat amb backdrop fosc.
   Apareix al mig de la pantalla amb una capa fosca darrere quan
   l'usuari encara no ha donat consentiment. */
.cookie-banner {
  position: fixed !important;
  inset: 0 !important;
  z-index: 700 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  background: rgba(7, 29, 51, .55) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  opacity: 0;
  transition: opacity .35s ease;
}
.cookie-banner.show {
  display: flex !important;
  opacity: 1;
}
.cookie-banner > * {
  /* Cap fill agafa més espai del que cal */
  flex: none;
}
/* Caixa interna del banner (els fills <p> i <button> queden agrupats
   en una caixa visual centrada, no enganxats a la vora) */
.cookie-banner::before {
  content: "";
  position: absolute;
  inset: 50% 50% 50% 50%;
  z-index: 0;
}
.cookie-banner p,
.cookie-banner button {
  position: relative;
  z-index: 1;
}
.cookie-banner p {
  background: #fff;
  color: var(--ink, #0A2A4E);
  border-radius: 18px 18px 0 0;
  padding: 24px 28px;
  margin: 0;
  max-width: 480px;
  width: 100%;
  font-size: 14px;
  line-height: 1.55;
  box-shadow: 0 24px 60px rgba(6,24,39,.35);
  text-align: center;
}
.cookie-banner a {
  color: var(--cyan, #0EA5E9);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookie-banner a:hover { color: var(--navy, #0A2A4E); }
.cookie-banner button {
  background: var(--cyan, #0EA5E9);
  color: #fff;
  border: 0;
  border-radius: 0 0 18px 18px;
  padding: 14px 28px;
  font-weight: 700;
  cursor: pointer;
  font-size: 14px;
  width: 100%;
  max-width: 480px;
  transition: background .15s ease;
  margin: 0;
}
.cookie-banner button:hover { background: #0284C7; }
@media (min-width: 540px) {
  /* A pantalles més grans, separem text i botó com a card amb
     botó dins (no enganxat sota). */
  .cookie-banner p {
    border-radius: 18px;
    padding: 28px 32px 22px;
  }
  .cookie-banner button {
    border-radius: 999px;
    padding: 12px 28px;
    width: auto;
    margin-top: -10px;
    box-shadow: 0 12px 30px rgba(14,165,233,.4);
  }
  .cookie-banner.show {
    flex-direction: column;
    gap: 14px;
  }
}


/* OBSOLET 2C-bis · El FAB de WhatsApp s'ha tret del HTML i s'ha integrat
   a les seccions .social-links com Instagram/Facebook. Bloc comentat,
   esborrar al final de la fase 2.
.fab-whatsapp {
  position: fixed;
  right: clamp(14px, 3vw, 28px);
  bottom: clamp(14px, 3vw, 28px);
  z-index: 650;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  padding: 14px 18px 14px 14px;
  border-radius: 999px;
  box-shadow: 0 18px 38px rgba(37,211,102,.40), 0 4px 12px rgba(0,0,0,.18);
  transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s ease, background .25s ease;
}
@media (hover: hover) and (pointer: fine) {
  .fab-whatsapp:hover {
    background: #1EB855;
    transform: translateY(-3px) scale(1.03);
    box-shadow: 0 24px 50px rgba(37,211,102,.50), 0 6px 18px rgba(0,0,0,.20);
    color: #fff;
  }
}
.fab-whatsapp svg { width: 22px; height: 22px; flex-shrink: 0; }
.fab-whatsapp .fab-label { white-space: nowrap; }
@media (max-width: 540px) {
  .fab-whatsapp .fab-label { display: none; }
  .fab-whatsapp { padding: 14px; }
}
*/
@media print {
  .cookie-banner { display: none !important; }
}

/* ════════════════════════════════════════════════════════════════════
   COMPTADORS ANIMATS · usa data-target a l'element <strong>
   ════════════════════════════════════════════════════════════════════ */
.hkpi[data-counted="true"] strong { transition: color .3s ease; }


/* ════════════════════════════════════════════════════════════════════
   NOTÍCIES · cards modernes amb imatge top + títol + resum
   ════════════════════════════════════════════════════════════════════ */
.noticies-section {
  background:
    radial-gradient(circle at 88% 12%, rgba(159,227,255,.18), transparent 32%),
    linear-gradient(180deg, #FFFFFF 0%, #F4FAFF 100%);
}
.noticies-head {
  text-align: left;
  margin-bottom: 36px;
  max-width: 760px;
}
.noticies-title {
  font-family: var(--font-display, 'Sora'), 'Inter', sans-serif;
  font-weight: 600;
  font-size: clamp(36px, 5.5vw, 60px);
  letter-spacing: -.045em;
  line-height: 1.02;
  color: var(--ink, #0A2A4E);
  margin: 6px 0 14px;
}
.noticies-title .accent { color: var(--cyan, #0EA5E9); }
.noticies-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.noticia-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line, #E6EEF6);
  border-radius: 24px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s ease, border-color .25s ease;
  box-shadow: 0 8px 24px rgba(7,55,99,.06);
}
@media (hover: hover) and (pointer: fine) {
  .noticia-card.noticia-link:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 60px rgba(7,55,99,.14);
    border-color: rgba(14,165,233,.30);
  }
}
.noticia-media {
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, #0C447C, #2E8BCB);
  overflow: hidden;
}
.noticia-media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.noticia-card.noticia-link:hover .noticia-media img { transform: scale(1.05); }
.noticia-media-empty {
  display: grid; place-items: center;
  color: rgba(255,255,255,.55);
}
.noticia-media-empty svg { width: 56px; height: 56px; }
.noticia-body {
  padding: 18px 22px 22px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.noticia-date {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--cyan, #0EA5E9);
}
.noticia-title {
  font-family: var(--font-display, 'Sora'), 'Inter', sans-serif;
  font-weight: 600;
  font-size: clamp(18px, 2.2vw, 22px);
  letter-spacing: -.02em;
  line-height: 1.2;
  color: var(--ink, #0A2A4E);
  margin: 0;
}
.noticia-summary {
  font-size: 14px;
  line-height: 1.55;
  color: var(--muted, #5A6B82);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.noticia-cta {
  margin-top: auto;
  padding-top: 8px;
  font-size: 13px; font-weight: 700;
  color: var(--cyan, #0EA5E9);
}

/* ════════════════════════════════════════════════════════════════════
   NEWSLETTER · camp al footer
   ════════════════════════════════════════════════════════════════════ */
.newsletter-form {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  width: 100%;
  max-width: 100%;
}
@media (min-width: 1024px) {
  .newsletter-form { max-width: 320px; }
}
.newsletter-form input[type="email"] {
  flex: 1;
  min-width: 0;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
  color: #fff;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color .15s ease, background .15s ease;
}
.newsletter-form input[type="email"]::placeholder { color: rgba(255,255,255,.55); }
.newsletter-form input[type="email"]:focus {
  border-color: var(--cyan, #0EA5E9);
  background: rgba(255,255,255,.16);
}
.newsletter-form button,
.newsletter-form button[type="submit"],
.newsletter-form #nlBtn {
  background: var(--cyan, #0EA5E9) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 10px 18px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  cursor: pointer;
  flex-shrink: 0;
  min-height: 0;
  transition: background .15s ease, transform .15s ease;
  box-shadow: 0 6px 16px rgba(14,165,233,.35);
}
@media (hover: hover) and (pointer: fine) {
  .newsletter-form button:hover { background: #0284C7 !important; transform: translateY(-1px); }
}
.newsletter-form button:disabled { opacity: .55; cursor: not-allowed; transform: none; }
.newsletter-msg {
  font-size: 12px;
  margin-top: 6px;
  color: #9FE3FF;
}
.newsletter-msg.err { color: #FCA5A5; }


/* ════════════════════════════════════════════════════════════════════
   RESET HOVER · Fase 2A · evita estats "stuck" en dispositius tàctils
   En telèfons sense punter capable de hover, neutralitzem els
   efectes de translate i ombres que podrien quedar-se enganxats
   després d'un toc. Els canvis de color de :hover es gestionen
   pel propi navegador via :active a touch.
   ════════════════════════════════════════════════════════════════════ */
@media (hover: none) {
  *:hover {
    transform: none !important;
    box-shadow: revert !important;
  }
}


/* ════════════════════════════════════════════════════════════════════
   TAP TARGETS · Fase 2A · 44px mínim per a enllaços tipus "tornar"
   .school-back i .alta-back són <a>, no <button>: la base no
   els aplica min-height. Aquí els forcem 44px amb contingut
   centrat verticalment perquè es puguin tocar amb el dit.
   ════════════════════════════════════════════════════════════════════ */
.school-back,
.alta-back {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
}


/* ════════════════════════════════════════════════════════════════════
   MODALS WEB PÚBLICA · MOBILE-FIRST · Fase 2C-bis
   ────────────────────────────────────────────────────────────────────
   Modificadors per a .modal-card (web pública):
     .modal-card--full → full-screen mòbil, centrat desktop (muleta)
     .modal-card--sm   → caixa petita centrada totes mides (info escola)

   Patró equivalent al backoffice (Fase 2C). Aprofita tokens i
   guanya cascada per especificitat amb classe modificadora.
   ════════════════════════════════════════════════════════════════════ */

/* .modal-img: aspect-ratio 4/3 (boats acostumen a ser horitzontals)
   amb max-height proporcional al viewport. Substitueix els height
   fixos (420px desktop, 220px mòbil) per un comportament fluid. */
.modal-card--full .modal-img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  max-height: 40dvh;
  object-fit: cover;
}

/* ── Mòbil base (< 768px) · full-screen ────────────────────────── */
.modal.open .modal-card.modal-card--full {
  width: 100%;
  height: 100dvh;
  max-width: none;
  max-height: 100dvh;
  border-radius: 0 !important;
  margin: 0;
  display: flex;
  flex-direction: column;
}

.modal-card--full .modal-close {
  position: sticky;
  top: 12px;
  z-index: 5;
  align-self: flex-end;
  margin-right: 12px;
}

.modal-card--full .modal-body {
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.modal-card--full .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 5;
  margin: 0;
  padding-bottom: max(12px, env(safe-area-inset-bottom));
}

/* ── Tablet+ (≥ 768px) · centrat com abans ──────────────────────── */
@media (min-width: 768px) {
  .modal.open .modal-card.modal-card--full {
    width: min(900px, calc(100% - 34px));
    height: auto;
    max-height: 90vh;
    border-radius: var(--radius-lg, 24px) !important;
    margin: 20px auto;
    display: block;
  }
  .modal-card--full .modal-img {
    aspect-ratio: 16 / 10;
    max-height: 50vh;
  }
  .modal-card--full .modal-close { position: absolute; top: 16px; right: 16px; }
  .modal-card--full .modal-body { flex: none; overflow-y: visible; }
  .modal-card--full .modal-actions { position: static; padding-bottom: 12px; }
}

/* ── modal-card--sm: petit centrat sempre ───────────────────────── */
.modal.open .modal-card.modal-card--sm {
  width: auto;
  max-width: calc(100% - 32px);
  max-height: 90dvh;
  margin: clamp(20px, 8vh, 60px) auto;
  border-radius: var(--radius-md, 18px) !important;
  display: block;
}
.modal-card--sm .modal-body {
  max-height: calc(90dvh - 80px);
  overflow-y: auto;
}
@media (min-width: 768px) {
  .modal.open .modal-card.modal-card--sm {
    max-width: 480px;
  }
}
