/* Fonts auto-allotjades (Archivo + IBM Plex Sans), subsets latin i latin-ext.
   font-display:swap ja inclòs. Generat des de Google Fonts. */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-700-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-700-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-800-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-800-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-900-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/archivo-900-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(/assets/fonts/ibm-plex-sans-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root{
  --navy:#14213D; --navy-2:#1E2E50;
  --amber:#f7b926; --amber-soft:#FFDD7A; --orange:#F0890B;
  --surface:#FAFAF7; --paper:#FFFFFF;
  --ink:#14213D; --slate:#5A6478; --line:#E4E2DB;
  --maxw:1160px;
  --r:14px;
  --display:"Archivo",system-ui,sans-serif;
  --body:"IBM Plex Sans",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--surface);color:var(--ink);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
svg{stroke-linecap:round;stroke-linejoin:round}

/* ---------- Header ---------- */
header{
  position:sticky;top:0;z-index:60;
  background:rgba(250,250,247,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.bar{display:flex;align-items:center;gap:22px;height:72px}
/* Wordmark de text (logotip compartit header + footer).
   Per canviar el logotip, només cal tocar aquest bloc. */
.wordmark{font-family:var(--display);font-weight:800;font-size:25px;letter-spacing:-.02em;
  text-transform:lowercase;text-decoration:none;display:inline-block;line-height:1}
.wordmark span{color:var(--amber)}
.wordmark--light{color:var(--navy)}            /* header, sobre fons clar */
.wordmark--dark{color:#fff;margin-bottom:14px} /* footer, sobre navy */
nav{margin-left:auto;display:flex;gap:26px}
nav a{text-decoration:none;color:var(--navy);font-weight:500;font-size:15.5px;padding:6px 0;position:relative}
nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--amber);transition:right .25s ease}
nav a:hover::after{right:0}
.lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;background:var(--paper)}
.lang button{border:0;background:none;font-family:var(--body);font-size:13px;font-weight:600;color:var(--slate);padding:5px 11px;border-radius:999px;cursor:pointer;letter-spacing:.02em}
.lang button[aria-pressed="true"]{background:var(--navy);color:#fff}
.call-btn{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;text-decoration:none;font-weight:600;font-size:15px;padding:11px 17px;border-radius:999px;transition:transform .15s ease,background .2s ease}
.call-btn:hover{background:var(--orange);transform:translateY(-1px)}
.call-btn svg{width:17px;height:17px}
.nav-toggle{display:none}  /* visible només <680px (vegeu media query) */

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-img{position:absolute;inset:0;margin:0;background:#0c1730}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.hero-overlay{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(12,18,40,.62),rgba(12,18,40,.88))}
.hero-inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:104px 22px 88px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-soft);font-weight:600}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--amber)}
.hero h1{font-family:var(--display);font-weight:900;font-size:clamp(46px,8vw,92px);line-height:.95;letter-spacing:-.03em;margin:18px 0 0}
.hero .lede{font-size:clamp(18px,2.4vw,22px);max-width:30ch;color:#E9ECF4;margin:16px 0 0}
.board{margin:30px 0 34px;display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  background:rgba(8,12,28,.55);border:1px solid rgba(247,185,38,.30);border-radius:12px;padding:12px 16px;font-size:14px;font-weight:500}
.board .lbl{color:#9FB0CC;letter-spacing:.06em;font-size:12px;text-transform:uppercase}
.board .val{color:var(--amber-soft);font-weight:700}
.board .arrow{color:var(--amber);animation:slide 1.8s ease-in-out infinite}
@keyframes slide{0%,100%{transform:translateX(0);opacity:.55}50%{transform:translateX(5px);opacity:1}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-weight:600;border-radius:999px;padding:15px 24px;font-size:17px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}
.btn svg{width:19px;height:19px}
.btn-primary{background:var(--amber);color:var(--navy);box-shadow:0 8px 24px rgba(247,185,38,.36)}
.btn-primary:hover{transform:translateY(-2px);background:var(--amber-soft)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}

/* ---------- Sections ---------- */
.section{padding:84px 0}
.section h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,4vw,40px);line-height:1.05;letter-spacing:-.02em;margin:0}
.kicker{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);font-weight:700;margin:0 0 14px}

.intro{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:start}
.intro p.big{font-size:19px;color:var(--slate);margin:18px 0 0}
.promises{display:grid;gap:16px}
.promise{display:flex;gap:16px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px}
.promise .num{font-family:var(--display);font-weight:800;color:var(--amber);font-size:16px;flex:0 0 auto;padding-top:2px}
.promise h3{font-family:var(--display);font-weight:700;font-size:18px;margin:0 0 4px;letter-spacing:-.01em}
.promise p{margin:0;font-size:15.5px;color:var(--slate)}

.services{background:var(--navy);color:#fff}
.services .kicker{color:var(--amber)}
.services h2{color:#fff}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
.card{background:var(--navy-2);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:24px 22px;transition:transform .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-4px);border-color:rgba(247,185,38,.55)}
.card .ico{width:46px;height:46px;border-radius:11px;background:rgba(247,185,38,.15);display:grid;place-items:center;margin-bottom:16px}
.card .ico svg{width:24px;height:24px;stroke:var(--amber);fill:none;stroke-width:1.8}
.card h3{font-family:var(--display);font-weight:700;font-size:17px;margin:0 0 6px;letter-spacing:-.01em}
.card p{margin:0;font-size:14.5px;color:#AEB9D0;line-height:1.5}

.gallery{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:150px;gap:10px;margin-top:42px}
.gallery a{display:block;overflow:hidden;border-radius:10px;background:#ddd}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery a:hover img{transform:scale(1.06)}
.gallery a:nth-child(1){grid-column:span 3;grid-row:span 2}
.gallery a:nth-child(2){grid-column:span 3}
.gallery a:nth-child(3){grid-column:span 2}
.gallery a:nth-child(4){grid-column:span 1}
.gallery a:nth-child(5){grid-column:span 3}
.gallery a:nth-child(6){grid-column:span 3}

.cta-band{background:linear-gradient(120deg,var(--amber),var(--orange));color:var(--navy);text-align:center}
.cta-band h2{color:var(--navy)}
.cta-band p{font-size:18px;margin:12px 0 26px;color:#4a3705}
.cta-band .btn-primary{background:var(--navy);color:#fff;box-shadow:0 10px 28px rgba(20,33,61,.3)}
.cta-band .btn-primary:hover{background:var(--navy-2)}

footer{background:var(--navy);color:#C7D0E2;padding:64px 0 28px;font-size:15px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:40px}
/* El wordmark del footer fa servir .wordmark.wordmark--dark (definit a dalt) */
.foot-about{color:#9FB0CC;max-width:34ch;margin:6px 0 0}
footer h4{font-family:var(--display);font-weight:700;color:#fff;font-size:14px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 16px}
footer a{color:#C7D0E2;text-decoration:none}
footer a:hover{color:var(--amber-soft)}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.contact-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:11px}
.contact-row svg{width:17px;height:17px;stroke:var(--amber);fill:none;stroke-width:1.9;flex:0 0 auto;margin-top:4px}
.contact-row .v{font-size:15px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:14px 24px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);margin-top:46px;padding-top:22px}
.copy{margin:0;font-size:13px;color:#8896B2}
@media (max-width:680px){
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .foot-bottom .legal-row{order:-1}
}

.mobile-call{display:none}

@media (max-width:900px){
  .intro{grid-template-columns:1fr;gap:34px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .gallery a:nth-child(n){grid-column:span 1;grid-row:span 1}
  .gallery a:nth-child(1){grid-column:span 2;grid-row:span 2}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .bar nav,.bar .call-btn,.bar .lang{display:none}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;
    width:44px;height:44px;min-width:44px;padding:0;border:0;background:transparent;color:var(--navy);cursor:pointer;border-radius:10px}
  .nav-toggle svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
  .section{padding:60px 0}
  .grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  body{padding-bottom:74px}
  .mobile-call{display:grid;grid-template-columns:1fr 1fr;gap:0;position:fixed;left:0;right:0;bottom:0;z-index:80;border-top:1px solid rgba(0,0,0,.1)}
  .mobile-call a{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;text-decoration:none;font-weight:600}
  .mobile-call svg{width:19px;height:19px}
  .mc-call{background:var(--amber);color:var(--navy)}
  .mc-wa{background:#25D366;color:#fff}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
}

/* ===== FAQ (accordion natiu <details>) ===== */
.faq-list{max-width:760px;margin:10px auto 0}
.faq-item{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;background:#fff;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 20px;font-family:var(--display);font-weight:700;
  font-size:17px;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:24px;line-height:1;color:var(--amber);font-weight:700;flex:0 0 auto}
.faq-item[open] summary::after{content:"–"}
.faq-item summary:hover{color:var(--orange)}
.faq-item summary:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
.faq-a{padding:0 20px 18px}
.faq-a p{margin:0;color:#3a4356;font-size:16px;line-height:1.65}

/* ===== Skip-link, header en scroll i menú mòbil ===== */
.skip-link{position:absolute;left:8px;top:-60px;z-index:1100;background:var(--navy);color:#fff;
  padding:10px 16px;border-radius:8px;text-decoration:none;font-weight:600;transition:top .2s ease}
.skip-link:focus{top:8px}

header{transition:box-shadow .25s ease,background .25s ease}
.bar{transition:height .25s ease}
header.scrolled{box-shadow:0 6px 22px rgba(12,18,40,.10)}
header.scrolled .bar{height:60px}

.drawer{position:fixed;inset:0;z-index:100;display:none;background:rgba(12,18,40,.55);opacity:0;transition:opacity .25s ease}
.drawer.open{display:block}
.drawer.show{opacity:1}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:#fff;
  box-shadow:-14px 0 44px rgba(12,18,40,.28);display:flex;flex-direction:column;gap:20px;
  padding:72px 24px 28px;overflow-y:auto;transform:translateX(100%);transition:transform .28s ease}
.drawer.show .drawer-panel{transform:translateX(0)}
.drawer-close{position:absolute;top:16px;right:16px;width:44px;height:44px;display:inline-flex;
  align-items:center;justify-content:center;border:0;background:transparent;color:var(--navy);cursor:pointer;border-radius:10px}
.drawer-close:hover{background:var(--paper)}
.drawer-close svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.drawer-nav{display:flex;flex-direction:column;gap:0;margin:0}
.drawer-nav a{font-family:var(--display);font-weight:700;font-size:22px;color:var(--navy);
  text-decoration:none;padding:14px 4px;border-bottom:1px solid var(--line)}
.drawer-nav a::after{display:none}
.drawer-nav a.active{color:var(--navy);box-shadow:inset 3px 0 0 0 var(--amber);padding-left:12px}
.drawer-lang{align-self:flex-start}
.drawer-call{width:100%;justify-content:center;margin-top:auto}
body.menu-open{overflow:hidden}
@media (min-width:681px){ .drawer{display:none !important} }

/* ===== Enllaços legals al footer ===== */
.legal-row{display:flex;flex-wrap:wrap;align-items:center;gap:4px 8px}
.legal-row a,.legal-row button{color:#8896B2;text-decoration:none;font-size:13px;
  background:none;border:0;padding:0;cursor:pointer;font-family:var(--body)}
.legal-row a:hover,.legal-row button:hover{color:var(--amber);text-decoration:underline}
.legal-row .sep{color:#5A6478;user-select:none}

/* ===== Formulari: checkbox privacitat, Turnstile, honeypot, missatges ===== */
.form-check{display:flex;gap:10px;align-items:flex-start;margin:4px 0 18px;font-size:14px;color:var(--slate);line-height:1.5}
.form-check input{flex:0 0 auto;width:18px;height:18px;margin-top:2px;accent-color:var(--navy)}
.form-check a{color:var(--navy);text-decoration:underline}
.cf-turnstile{margin:4px 0 18px}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-msg{padding:14px 16px;border-radius:10px;margin-bottom:18px;font-size:15px;line-height:1.5}
.form-msg.ok{background:#E8F5EC;color:#1C6B3A;border:1px solid #BFE3CC}
.form-msg.err{background:#FDECEC;color:#9A2020;border:1px solid #F3C0C0}

/* ===== Prosa pàgines legals ===== */
.prose h2{font-family:var(--display);font-weight:800;font-size:23px;color:var(--ink);margin:34px 0 12px;letter-spacing:-.01em}
.prose h3{font-weight:700;font-size:17px;color:var(--ink);margin:22px 0 8px}
.prose ul{margin:0 0 18px;padding-left:22px}
.prose li{margin:0 0 8px;color:#3a4356;font-size:17px;line-height:1.6}
.prose a{color:var(--navy);text-decoration:underline}
.prose .muted{color:var(--slate);font-size:14px}
.prose table{width:100%;border-collapse:collapse;margin:8px 0 24px;font-size:14.5px}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.prose th{background:var(--paper);font-weight:600;color:var(--ink)}

/* ===== Banner de consentiment de cookies ===== */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--navy);color:#fff;
  border-top:2px solid var(--amber);box-shadow:0 -8px 30px rgba(12,18,40,.28);
  transform:translateY(100%);transition:transform .3s ease}
.cc-banner.show{transform:translateY(0)}
.cc-inner{max-width:var(--maxw);margin:0 auto;padding:16px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cc-text{flex:1 1 320px;margin:0;font-size:14px;line-height:1.5;color:#E9ECF4}
.cc-text a{color:var(--amber-soft);text-decoration:underline}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}
.cc-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;
  font-family:var(--body);font-weight:600;font-size:14px;padding:11px 22px;border-radius:999px;
  cursor:pointer;border:0;min-height:44px;transition:background .2s ease,border-color .2s ease}
.cc-accept{background:var(--amber);color:var(--navy)}
.cc-accept:hover{background:var(--amber-soft)}
.cc-reject{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.cc-reject:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.cc-manage{background:transparent;color:#C7D0E2;border:1px solid rgba(255,255,255,.25)}
.cc-manage:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.06)}
@media (max-width:680px){
  .cc-banner{bottom:74px}            /* per sobre de la barra Truca/WhatsApp */
  .cc-actions{width:100%}
  .cc-btn{flex:1 1 0}
}

/* ---------- Pàgines internes ---------- */
.page-hero{background:var(--navy);color:#fff;padding:74px 0 60px;position:relative}
.page-hero .eyebrow{color:var(--amber-soft)}
.page-hero h1{font-family:var(--display);font-weight:900;font-size:clamp(34px,6vw,58px);line-height:1.02;letter-spacing:-.03em;margin:16px 0 0}
.page-hero p{color:#C7D0E2;font-size:18px;max-width:48ch;margin:14px 0 0}

nav a.active{color:var(--navy)}
nav a.active::after{right:0}

.prose{max-width:64ch}
.prose p{color:#3a4356;margin:0 0 18px;font-size:17.5px;line-height:1.65}
.prose p.lead{font-size:20px;color:var(--ink);font-weight:500}

/* Contacte */
.contact-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:44px;align-items:start}
.map-embed{border:0;width:100%;height:400px;border-radius:var(--r);display:block}
.form-field{display:block;margin-bottom:16px}
.form-field label{display:block;font-size:14px;font-weight:600;color:var(--slate);margin-bottom:6px}
.form-field input,.form-field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--body);font-size:16px;background:var(--paper);color:var(--ink)}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(247,185,38,.25)}
.form-field textarea{min-height:130px;resize:vertical}
.btn-submit{border:0;cursor:pointer;background:var(--navy);color:#fff;font-family:var(--body);font-weight:600;font-size:16px;padding:14px 28px;border-radius:999px;transition:background .2s ease,transform .15s ease}
.btn-submit:hover{background:var(--orange);transform:translateY(-1px)}

.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:38px}
.ccard{display:flex;gap:14px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;text-decoration:none;transition:border-color .2s ease,transform .15s ease}
.ccard:hover{border-color:var(--amber);transform:translateY(-2px)}
.ccard .ico{width:44px;height:44px;border-radius:11px;background:rgba(247,185,38,.15);display:grid;place-items:center;flex:0 0 auto}
.ccard .ico svg{width:22px;height:22px;stroke:var(--amber);fill:none;stroke-width:1.9}
.ccard .l{font-size:13px;color:var(--slate);display:block}
.ccard .v{font-weight:700;color:var(--ink)}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .contact-cards{grid-template-columns:1fr}
}

/* Enllaços interns (relacionats) */
.rel-links{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.rel-links .lbl{grid-column:1 / -1;font-size:13px;font-weight:600;color:var(--slate);letter-spacing:.02em}
.rel-links .btn{width:100%;justify-content:center}
.btn-dark{background:var(--navy);color:#fff;box-shadow:none}
.btn-dark:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
/* Primari de .rel-links en groc (llegible sobre el fons); acotat aquí perquè no
   afecti altres usos de .btn-dark (p. ex. la política de cookies). */
.rel-links .btn-dark{background:var(--amber);color:var(--navy);box-shadow:none}
.rel-links .btn-dark:hover{background:var(--orange);color:var(--navy);transform:translateY(-2px)}
@media (max-width:680px){
  .rel-links{grid-template-columns:1fr}
}

/* ===== Lightbox de galeria (sense llibreries) ===== */
.lb{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;
  background:rgba(12,18,40,.93);opacity:0;transition:opacity .25s ease}
.lb.open{display:flex}
.lb.show{opacity:1}
.lb-figure{position:relative;margin:0;display:flex;flex-direction:column;align-items:center;max-width:92vw}
.lb-img{max-width:92vw;max-height:80vh;width:auto;height:auto;display:block;border-radius:10px;
  background:var(--navy-2);box-shadow:0 24px 60px rgba(0,0,0,.55)}
.lb-counter{margin-top:14px;color:#E9ECF4;font-size:14px;font-weight:600;letter-spacing:.04em}
.lb-counter b{color:var(--amber-soft);font-weight:700}
.lb-btn{position:absolute;display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;min-width:44px;min-height:44px;padding:0;border:0;cursor:pointer;
  color:#fff;background:rgba(20,33,61,.72);border-radius:999px;
  transition:background .2s ease,transform .15s ease}
.lb-btn:hover{background:var(--amber);color:var(--navy)}
.lb-btn:focus-visible{outline:2px solid var(--amber);outline-offset:3px}
.lb-btn svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.lb-close{top:18px;right:18px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}
.lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.06)}
body.lb-lock{overflow:hidden}
@media (max-width:640px){
  .lb-prev{left:10px}.lb-next{right:10px}.lb-close{top:12px;right:12px}
  .lb-img{max-height:74vh}
}
@media (prefers-reduced-motion:reduce){
  .lb,.lb-btn,.lb-prev,.lb-next{transition:none}
}
