:root{
  --paper:#f6f2e9; --ink:#21302a; --ink-soft:#4a5a52;
  --festa:#d64f2a; --gold:#e0a43b; --pine:#2d5e48;
  --line:#e2dccb; --surface:#fffdf7; --surface-2:#efe9da;
  --shadow:0 1px 2px rgba(33,48,42,.06),0 8px 24px rgba(33,48,42,.06);
  --maxw:880px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif; font-size:17px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

/* ---------- TOPBAR ---------- */
.topbar{border-bottom:1px solid var(--line); background:rgba(246,242,233,.92); backdrop-filter:blur(8px); position:sticky; top:0; z-index:20}
.topbar-row{display:flex; align-items:center; gap:14px; padding:12px 0}
.back{display:inline-flex; align-items:center; gap:7px; text-decoration:none; font-size:.9rem; font-weight:600; color:var(--ink); border:1px solid var(--line); background:var(--surface); padding:7px 14px; border-radius:999px; transition:border-color .15s}
.back:hover{border-color:var(--ink-soft)}
.lang-switch{margin-left:auto; display:inline-flex; gap:3px; padding:3px; background:var(--surface); border:1px solid var(--line); border-radius:999px; box-shadow:var(--shadow)}
.lang-switch button{font:inherit; font-family:"Space Mono",monospace; font-size:.72rem; font-weight:700; letter-spacing:.06em; cursor:pointer; border:0; background:transparent; color:var(--ink-soft); padding:5px 10px; border-radius:999px; transition:background .15s,color .15s}
.lang-switch button:hover{color:var(--ink)}
.lang-switch button.lang-active{background:var(--ink); color:#f4efe2}

/* ---------- HERO ---------- */
.detail-hero{position:relative; overflow:hidden; padding:46px 0 30px; border-bottom:1px solid var(--line)}
.eyebrow{font-family:"Space Mono",monospace; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--festa); margin:0 0 14px; display:flex; align-items:center; gap:9px}
.eyebrow .pdot{width:10px; height:10px; border-radius:50%; display:inline-block}
.detail-hero h1{font-family:"Fraunces",serif; font-weight:600; font-size:clamp(2rem,5vw,3.2rem); line-height:1.04; letter-spacing:-.02em; margin:0 0 16px; max-width:18ch}
.badges{display:flex; flex-wrap:wrap; gap:10px; align-items:center}
.badge-date{display:inline-flex; align-items:center; gap:8px; background:var(--ink); color:#f4efe2; font-family:"Space Mono",monospace; font-size:.92rem; padding:9px 15px; border-radius:999px}
.badge-note{color:var(--ink-soft); font-size:.9rem}
.status{font-family:"Space Mono",monospace; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; padding:4px 10px; border-radius:999px; display:none}
.is-past .status{display:inline-block; background:var(--surface-2); color:var(--ink-soft)}
.is-past .detail-hero h1{opacity:.75}
.ridge{position:absolute; left:0; right:0; bottom:-1px; width:100%; height:70px; opacity:.5; pointer-events:none}

/* ---------- CONTINGUT ---------- */
main{padding:34px 0 50px}
.facts{display:grid; gap:14px; margin:0 0 30px}
.fact{display:grid; grid-template-columns:120px 1fr; gap:14px; align-items:start; padding:16px 0; border-bottom:1px solid var(--line)}
.fact-k{font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); padding-top:3px}
.fact-v{font-size:1.05rem}
.fact-v .place{font-weight:600}
.comu-link{display:inline-flex; align-items:center; gap:8px; margin-top:4px; text-decoration:none; font-weight:600; color:var(--pine); border-bottom:2px solid transparent; transition:border-color .15s}
.comu-link:hover{border-color:var(--pine)}
.comu-link .arr{font-family:"Space Mono",monospace}

.map-wrap{border:1px solid var(--line); border-radius:16px; overflow:hidden; box-shadow:var(--shadow); background:var(--surface-2)}
.map-wrap iframe{display:block; width:100%; height:360px; border:0}

.cta{display:inline-flex; align-items:center; gap:9px; margin-top:30px; background:var(--festa); color:#fff; text-decoration:none; font-weight:600; padding:12px 22px; border-radius:999px; transition:transform .15s, box-shadow .15s}
.cta:hover{transform:translateY(-2px); box-shadow:0 6px 18px rgba(214,79,42,.28)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line); padding:30px 0 50px; margin-top:30px; color:var(--ink-soft); font-size:.84rem}
.foot-note{margin:0; font-family:"Space Mono",monospace; font-size:.76rem}

@media (max-width:620px){
  .detail-hero{padding:34px 0 24px}
  .fact{grid-template-columns:1fr; gap:4px; padding:14px 0}
  .map-wrap iframe{height:280px}
}
@media (prefers-reduced-motion:reduce){*{transition:none !important; scroll-behavior:auto !important}}
:focus-visible{outline:2px solid var(--festa); outline-offset:2px; border-radius:4px}
