
:root{--paper:#fff;--soft:#f5f2ed;--ink:#222326;--muted:#66696f;--line:#d9d5cf;--burgundy:#8d0f35;--tile:#efe9df;--sand:#b89c74;--blue:#315a73;--green:#5e6e57;--shadow:0 12px 32px rgba(20,20,20,.10)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--ink);background:var(--soft);line-height:1.55}a{color:inherit}.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:1000;box-shadow:0 4px 12px rgba(0,0,0,.06)}.topbar{height:92px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(24px,5vw,72px);gap:28px}.logo{display:flex;align-items:center;gap:14px;text-decoration:none;min-width:230px}.mark{width:44px;height:44px;border:2px solid var(--burgundy);color:var(--burgundy);display:grid;place-items:center;font-weight:900}.logo strong{display:block;color:var(--burgundy);text-transform:uppercase;font-size:1.35rem;letter-spacing:.03em}.logo small{display:block;color:#333;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}.main-nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.main-nav a{text-transform:uppercase;text-decoration:none;font-weight:800;letter-spacing:.04em;font-size:.92rem;color:#333;padding:35px 0;border-bottom:5px solid transparent}.main-nav a:hover{color:var(--burgundy);border-bottom-color:var(--burgundy)}main{padding:0 clamp(24px,5vw,72px) 60px}.home-hero{background:#fff;margin:0 calc(clamp(24px,5vw,72px) * -1);padding:70px clamp(24px,5vw,72px) 56px;border-bottom:1px solid var(--line)}.kicker{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;font-weight:900;color:var(--burgundy);margin:0 0 12px}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(3.2rem,8vw,7.5rem);line-height:.88;letter-spacing:-.075em;margin-bottom:12px}.subtitle{font-size:clamp(1.55rem,3vw,2.8rem);line-height:1.05;font-weight:850;letter-spacing:-.04em;margin-bottom:18px}.lead{font-size:1.22rem;max-width:900px;color:var(--muted)}.section-title h2,.page-head h1{font-size:clamp(2.2rem,5vw,4.8rem);letter-spacing:-.065em;line-height:.95}.map-section,.directory-section,.home-summary,.page-head,.text-block,.method-grid,.kpi-grid,.case-layout{margin:38px 0}.map-wide{width:100%;height:620px;border:1px solid var(--line);box-shadow:var(--shadow);background:#ddd}.map-wide.tall{height:720px}.filters{display:flex;gap:9px;flex-wrap:wrap;margin:0 0 16px}.filter{border:1px solid var(--line);background:#fff;padding:9px 13px;font-weight:800;text-transform:uppercase;cursor:pointer}.filter.active,.filter:hover{background:var(--burgundy);color:#fff;border-color:var(--burgundy)}.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.location-card{background:#fff;border:1px solid var(--line);min-height:260px;padding:24px;display:flex;flex-direction:column;justify-content:space-between}.location-card h3{font-size:1.55rem;line-height:1.05;margin:0 0 14px}.card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}.button,.card-actions a{display:inline-flex;align-items:center;border:1px solid var(--burgundy);color:var(--burgundy);background:#fff;padding:10px 13px;text-decoration:none;font-weight:900;text-transform:uppercase;font-size:.82rem}.button.primary,.card-actions a:hover{background:var(--burgundy);color:#fff}.pagination{display:flex;gap:10px;justify-content:center;margin:24px 0}.pagination button{border:0;background:transparent;font-weight:900;font-size:1rem;padding:8px 10px;cursor:pointer}.pagination button.active{color:var(--burgundy)}.home-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.home-summary article,.text-block,.page-head,.case-main,.case-side{background:#fff;border:1px solid var(--line);padding:34px}.home-summary h2{font-size:1.8rem;line-height:1.05;letter-spacing:-.04em}.home-summary a{font-weight:900;color:var(--burgundy);text-decoration:none}.page{max-width:1280px;margin:auto;padding-top:42px}.page-head{border-left:12px solid var(--burgundy)}.text-block.two{display:grid;grid-template-columns:1fr 1fr;gap:28px}.method-grid,.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.method-grid article,.kpi-grid article{background:#fff;border:1px solid var(--line);padding:28px}.method-grid span,.number{display:block;color:var(--burgundy);font-size:2.4rem;font-weight:900}.case-hero{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px;background:#fff;border:1px solid var(--line);border-left:12px solid var(--burgundy);padding:46px;margin:42px 0 28px}.case-status{background:var(--burgundy);color:#fff;padding:24px;display:flex;flex-direction:column;justify-content:center}.case-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:20px}.data-card{border-bottom:1px solid var(--line);padding:18px 0}.data-card span{display:block;color:var(--muted);font-size:.9rem;text-transform:uppercase;letter-spacing:.06em}.data-card strong{display:block;font-size:1.8rem;line-height:1;color:var(--burgundy);margin:8px 0}.viewer-iframe{width:100%;height:620px;border:1px solid var(--line);background:#111}.viewer-large{border:1px dashed #aaa;background:#f3eee7;min-height:320px;padding:24px;display:grid;place-items:center;text-align:center;color:var(--muted);font-weight:800}.site-footer{background:#fff;border-top:1px solid var(--line);padding:28px clamp(24px,5vw,72px);display:flex;justify-content:space-between;color:var(--muted)}.custom-marker{width:18px;height:18px;border-radius:50%;background:var(--burgundy);border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.25)}.custom-marker.cala,.custom-marker.litoral{background:var(--blue)}.custom-marker.poble{background:var(--sand)}.leaflet-popup-content{font-family:Inter,Arial,sans-serif}.popup-title{font-weight:900;font-size:1.05rem;margin-bottom:4px}.popup-actions{display:flex;gap:6px;margin-top:10px}.popup-actions a{padding:6px 8px;border:1px solid var(--burgundy);color:var(--burgundy);text-decoration:none;font-weight:900;font-size:.75rem;text-transform:uppercase}@media(max-width:1100px){.cards-grid,.method-grid,.kpi-grid{grid-template-columns:repeat(2,1fr)}.home-summary,.case-layout,.case-hero{grid-template-columns:1fr}.main-nav{gap:12px}.main-nav a{font-size:.78rem}}@media(max-width:720px){.topbar{height:auto;padding:16px 20px;align-items:flex-start;flex-direction:column}.main-nav a{padding:8px 0}main{padding:0 16px 40px}.home-hero{padding:42px 16px;margin:0 -16px}.cards-grid,.home-summary,.method-grid,.kpi-grid,.text-block.two{grid-template-columns:1fr}.map-wide{height:480px}.site-footer{flex-direction:column;gap:10px}.viewer-iframe{height:420px}}

/* Afegir al final de css/style.css per a la pàgina tesi.html */
.article-body { background: #f5f1e8; }
.article-page { max-width: 1180px; margin: 0 auto; padding: 0 24px 72px; }
.article-hero { padding: 72px 0 38px; border-bottom: 1px solid rgba(31,35,40,.18); }
.article-hero h1 { max-width: 980px; font-size: clamp(3rem, 8vw, 7.2rem); line-height: .9; letter-spacing: -.06em; margin: 0 0 24px; color: #1f2328; }
.article-hero .lead { max-width: 820px; font-size: clamp(1.25rem, 2.2vw, 2rem); line-height: 1.25; color: #315a73; margin: 0 0 22px; }
.article-meta { display:flex; flex-wrap:wrap; gap:10px; font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; color:#5e6e57; }
.article-meta span { border:1px solid rgba(94,110,87,.28); padding:7px 10px; border-radius:999px; background:rgba(255,255,255,.35); }
.thesis-strip { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin:28px 0 48px; background:rgba(31,35,40,.14); border:1px solid rgba(31,35,40,.14); }
.thesis-strip > div { background:#fffaf0; padding:22px; }
.thesis-strip strong { display:block; margin-bottom:8px; color:#8c3b2f; text-transform:uppercase; font-size:.78rem; letter-spacing:.09em; }
.thesis-strip p { margin:0; line-height:1.45; }
.article-layout { display:grid; grid-template-columns:260px minmax(0, 1fr); gap:54px; align-items:start; }
.article-sidebar { position:sticky; top:96px; }
.toc { border-left:3px solid #315a73; padding:10px 0 10px 18px; }
.toc p { margin:0 0 12px; text-transform:uppercase; letter-spacing:.1em; font-size:.75rem; color:#8c3b2f; font-weight:700; }
.toc a { display:block; color:#1f2328; text-decoration:none; padding:7px 0; font-size:.92rem; line-height:1.25; }
.toc a:hover { color:#8c3b2f; }
.longform { max-width: 820px; }
.article-section { margin:0 0 58px; }
.article-section h2 { font-size: clamp(2rem, 4vw, 3.7rem); line-height:.98; letter-spacing:-.045em; margin:0 0 22px; color:#1f2328; }
.article-section h3 { font-size:1.15rem; margin:0 0 10px; color:#315a73; }
.article-section p, .article-section li { font-size:1.08rem; line-height:1.72; color:#25292e; }
.article-section p { margin:0 0 20px; }
.dropcap:first-letter { float:left; font-size:5.4rem; line-height:.82; padding:8px 10px 0 0; color:#8c3b2f; font-weight:800; }
.longform blockquote { margin:34px 0; padding:26px 30px; border-left:5px solid #8c3b2f; background:#fffaf0; }
.longform blockquote p { font-size:1.5rem; line-height:1.35; margin:0; color:#1f2328; font-weight:650; }
.data-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:32px 0; }
.data-card { background:#1f2328; color:#f5f1e8; border-radius:18px; padding:18px; min-height:138px; display:flex; flex-direction:column; justify-content:space-between; }
.data-card span { color:#b89c74; font-size:.86rem; text-transform:uppercase; letter-spacing:.08em; }
.data-card strong { font-size:2.35rem; line-height:1; letter-spacing:-.04em; }
.data-card small { color:rgba(245,241,232,.78); line-height:1.35; }
.table-wrap { overflow-x:auto; margin:34px 0; border:1px solid rgba(31,35,40,.16); background:#fffaf0; }
.evidence-table { width:100%; border-collapse:collapse; min-width:760px; }
.evidence-table caption { text-align:left; padding:16px 18px; font-weight:700; color:#8c3b2f; }
.evidence-table th, .evidence-table td { text-align:left; vertical-align:top; border-top:1px solid rgba(31,35,40,.14); padding:14px 16px; font-size:.94rem; line-height:1.45; }
.evidence-table th { background:rgba(49,90,115,.1); color:#1f2328; }
.context-box, .protocol-list { background:#fffaf0; border:1px solid rgba(49,90,115,.22); border-radius:22px; padding:26px; margin:30px 0; box-shadow:0 18px 40px rgba(31,35,40,.06); }
.context-box p, .protocol-list p { margin-bottom:0; }
.method-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin:32px 0; }
.method-grid > div { background:#fffaf0; border-top:4px solid #315a73; padding:20px; }
.method-grid p { margin:0; font-size:.98rem; line-height:1.55; }
.protocol-list ul { margin:0; padding-left:20px; }
.protocol-list li { margin-bottom:10px; }
.conclusion { border-top:1px solid rgba(31,35,40,.18); border-bottom:1px solid rgba(31,35,40,.18); padding:42px 0; }
.sources-section { font-size:.95rem; }
.sources-list { padding-left:20px; }
.sources-list li { margin-bottom:10px; font-size:.95rem; line-height:1.45; }
.sources-list a { color:#315a73; text-decoration-thickness:1px; text-underline-offset:3px; }
.sources-list a:hover { color:#8c3b2f; }
.main-nav a.active { color:#8c3b2f; font-weight:700; }
@media (max-width: 920px) {
  .article-layout { grid-template-columns:1fr; gap:20px; }
  .article-sidebar { position:static; order:-1; }
  .toc { display:grid; grid-template-columns:repeat(2,1fr); gap:0 18px; border-left:0; border-top:3px solid #315a73; padding:16px 0 0; }
  .toc p { grid-column:1 / -1; }
  .thesis-strip, .data-cards, .method-grid { grid-template-columns:1fr; }
  .article-page { padding-left:18px; padding-right:18px; }
}
@media (max-width: 560px) {
  .article-hero { padding-top:48px; }
  .toc { grid-template-columns:1fr; }
  .article-section p, .article-section li { font-size:1rem; line-height:1.65; }
  .longform blockquote p { font-size:1.25rem; }
}

/* === Mòduls d'anàlisi IA — Secrets públics === */
.ia-analysis-panel{background:#f5f1e8;border:1px solid rgba(31,35,40,.14);border-radius:22px;padding:24px;margin:34px 0;box-shadow:0 16px 40px rgba(31,35,40,.06)}
.ia-analysis-panel h3{margin-top:0;font-size:1.35rem}.ia-method-note{font-size:.95rem;color:#5f625f;line-height:1.55;margin:8px 0 18px}.ia-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:22px 0}.ia-stat{background:#fff;border:1px solid rgba(31,35,40,.12);border-radius:18px;padding:18px}.ia-stat span{display:block;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;color:#6d6f6d;margin-bottom:8px}.ia-stat strong{font-size:2rem;line-height:1;color:#1f2328}.ia-stat small{display:block;margin-top:8px;color:#555;line-height:1.35}.ia-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:28px 0}.ia-chart{background:#fff;border:1px solid rgba(31,35,40,.12);border-radius:18px;padding:20px}.ia-chart h4{margin:0 0 14px;font-size:1.05rem}.ia-bars{display:grid;gap:11px}.ia-bar-row{display:grid;grid-template-columns:160px 1fr 54px;align-items:center;gap:10px;font-size:.9rem}.ia-track{height:14px;background:#ebe5d9;border-radius:999px;overflow:hidden}.ia-fill{display:block;height:100%;background:#315a73;border-radius:999px}.ia-fill.warn{background:#8c3b2f}.ia-fill.green{background:#5e6e57}.ia-fill.sand{background:#b89c74}.ia-small-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:12px}.ia-small-table th,.ia-small-table td{border-bottom:1px solid rgba(31,35,40,.12);padding:9px 6px;text-align:left;vertical-align:top}.ia-small-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#6d6f6d}.ia-rank-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:16px 0}.ia-rank-item{display:flex;justify-content:space-between;gap:14px;background:#fff;border:1px solid rgba(31,35,40,.12);border-radius:14px;padding:12px 14px}.ia-rank-item strong{font-size:.95rem}.ia-rank-item span{font-variant-numeric:tabular-nums;color:#315a73;font-weight:700}.ia-reading-box{border-left:4px solid #8c3b2f;background:#fff;padding:18px 20px;border-radius:0 16px 16px 0;margin:24px 0}.ia-reading-box p{margin:.4rem 0}.ia-warning{background:#fff7ed;border:1px solid rgba(140,59,47,.25);border-radius:16px;padding:16px 18px;margin:20px 0}.ia-source-caption{font-size:.86rem;color:#666;margin-top:12px}.ia-chart-note{font-size:.82rem;color:#656565;margin-top:10px;line-height:1.4}@media(max-width:850px){.ia-stat-grid,.ia-charts-grid,.ia-rank-list{grid-template-columns:1fr}.ia-bar-row{grid-template-columns:115px 1fr 46px}.ia-analysis-panel{padding:18px}}
