/* ============================================================
   Sicília 2026 — full d'estil
   ============================================================ */
:root{
  --bg:#17110c; --bg2:#211a13; --bg3:#2a2118;
  --line:rgba(205,163,90,.22); --line-soft:rgba(205,163,90,.12);
  --gold:#cda35a; --gold-soft:#e6c98a; --cream:#f3ead9;
  --text:#d8cdba; --muted:#9a8f7d;
  --serif:'Playfair Display',Georgia,serif;
  --body:'EB Garamond',Georgia,serif;
  --mono:'Space Mono',ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:var(--body);font-size:19px;line-height:1.72;-webkit-font-smoothing:antialiased}
a{color:var(--gold-soft);text-decoration:none;border-bottom:1px solid var(--line)}
a:hover{color:var(--cream)}
img{display:block;max-width:100%}
.wrap{max-width:980px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold)}
h2.sec{font-family:var(--serif);color:var(--cream);font-weight:700;
  font-size:clamp(28px,4vw,40px);margin:0 0 4px;letter-spacing:.01em}
.sec-rule{height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin:14px 0 36px;border:0}
section{padding:64px 0}
.intro{color:var(--muted);font-style:italic;max-width:720px;margin:-14px 0 30px}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:90vh;display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(180deg,rgba(23,17,12,.35),rgba(23,17,12,.55) 45%,rgba(23,17,12,.96)),
    var(--hero-img, #211a13) center/cover no-repeat}
.hero-inner{max-width:980px;margin:0 auto;padding:0 24px 60px;width:100%}
.hero h1{font-family:var(--serif);color:var(--cream);font-weight:700;margin:.18em 0 0;line-height:.96;
  font-size:clamp(56px,12vw,128px)}
.hero h1 em{display:block;font-style:italic;color:var(--gold);
  background:linear-gradient(90deg,var(--gold-soft),var(--gold));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .route-line{font-family:var(--body);font-style:italic;color:var(--cream);
  font-size:clamp(18px,2.4vw,24px);margin:18px 0 4px}
.hero .sub{font-family:var(--body);color:var(--muted);font-style:italic;font-size:clamp(15px,1.8vw,18px)}
.stats{display:flex;flex-wrap:wrap;gap:26px 44px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.stat .n{font-family:var(--serif);color:var(--cream);font-size:clamp(26px,3.6vw,38px);font-weight:700;line-height:1}
.stat .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:7px}
.gallery{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:30px}
.gallery img{aspect-ratio:1/1;object-fit:cover;border-radius:3px;cursor:zoom-in;
  filter:saturate(.95) brightness(.92);transition:filter .25s,transform .35s}
.gallery img:hover{filter:none;transform:scale(1.04)}
@media(max-width:680px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:430px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ---------- ROUTE RIBBON ---------- */
.ribbon{display:flex;align-items:stretch;flex-wrap:wrap;gap:10px;background:var(--bg2);
  border:1px solid var(--line);border-radius:12px;padding:26px 22px}
.node{flex:1 1 150px;text-align:center;min-width:130px}
.node .num{width:38px;height:38px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;
  justify-content:center;font-family:var(--mono);font-weight:700;color:var(--bg);
  background:linear-gradient(135deg,var(--gold-soft),var(--gold))}
.node .city{font-family:var(--serif);color:var(--cream);font-size:21px;font-weight:700}
.node .nights{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.node .dates{color:var(--muted);font-size:14px;margin-top:2px}
.conn{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:22px;padding:0 2px;flex:0 0 auto}
.conn small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--muted);text-align:center;line-height:1.3;margin-top:2px}
@media(max-width:680px){.ribbon{flex-direction:column}.conn{transform:rotate(90deg);padding:6px 0}.conn small{display:none}}

/* ---------- ZONES (hotels + què veure a prop) ---------- */
.zone{background:var(--bg2);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:0 0 26px}
.zone-head{display:grid;grid-template-columns:1.05fr 1fr;gap:0}
@media(max-width:820px){.zone-head{grid-template-columns:1fr}}
.zone-shot{position:relative;aspect-ratio:16/11;overflow:hidden}
.zone-shot img{width:100%;height:100%;object-fit:cover;object-position:top center;background:#fff;cursor:zoom-in;transition:transform .4s}
.zone-shot:hover img{transform:scale(1.03)}
.zone-shot .badge{position:absolute;top:12px;left:12px;width:34px;height:34px;border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;color:var(--bg);
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));box-shadow:0 2px 10px rgba(0,0,0,.4)}
.zone-shot .nights-tag{position:absolute;bottom:12px;right:12px;font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--cream);background:rgba(23,17,12,.78);
  border:1px solid var(--line);padding:5px 10px;border-radius:20px}
.zone-info{padding:22px 26px}
.zone-info h3{font-family:var(--serif);color:var(--cream);font-size:26px;font-weight:700;margin:0}
.zone-info .when{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--gold);text-transform:uppercase;margin:4px 0 14px}
.zone-info .stay{font-size:16px;margin:0 0 12px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}
.zone-info .stay .label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:2px}
.rooms{list-style:none;padding:0;margin:0 0 12px;font-size:15.5px}
.rooms li{padding-left:18px;position:relative;color:var(--text)}
.rooms li::before{content:"›";position:absolute;left:0;color:var(--gold)}
.meta-line{font-size:14.5px;color:var(--muted);margin:8px 0 0;display:flex;gap:8px}
.meta-line .ic{color:var(--gold);flex:0 0 auto}
.zone-near{padding:6px 26px 26px}
.zone-near h4{font-family:var(--serif);color:var(--cream);font-size:20px;margin:18px 0 14px;display:flex;align-items:center;gap:9px}
.zone-near h4::before{content:"📍"}

/* què veure: llista */
.seelist{list-style:none;padding:0;margin:14px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:2px 26px}
@media(max-width:680px){.seelist{grid-template-columns:1fr}}
.seelist li{font-size:15px;line-height:1.5;padding:9px 0;border-top:1px solid var(--line-soft)}
.seelist b{color:var(--cream);font-weight:700}
.seelist .h{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:.04em;margin-right:6px}

/* ---------- CAROUSEL (reusable) ---------- */
.carousel{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg3);margin:0 0 8px}
.carousel-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}
.carousel-slide{flex:0 0 100%;position:relative;margin:0;min-width:0}
.carousel-slide img{width:100%;height:clamp(240px,40vw,400px);object-fit:cover;display:block;cursor:zoom-in}
.carousel-slide figcaption{position:absolute;left:0;bottom:0;width:100%;box-sizing:border-box;font-family:var(--mono);
  font-size:12px;letter-spacing:.05em;color:var(--cream);padding:32px 16px 14px;
  background:linear-gradient(180deg,transparent,rgba(23,17,12,.92))}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);background:rgba(23,17,12,.62);color:var(--cream);font-size:26px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:background .2s,color .2s;z-index:2}
.carousel-btn:hover{background:rgba(205,163,90,.92);color:var(--bg)}
.carousel-btn.prev{left:12px}.carousel-btn.next{right:12px}
.carousel-dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:2}
.carousel-dots button{width:8px;height:8px;border-radius:50%;border:0;padding:0;cursor:pointer;background:rgba(243,234,217,.45);transition:transform .2s,background .2s}
.carousel-dots button.active{background:var(--gold);transform:scale(1.35)}
.carousel-hint{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:right;margin:0 4px 18px}
@media(max-width:680px){.carousel-btn{width:38px;height:38px;font-size:22px}}

/* ---------- ITINERARY ---------- */
.day{display:grid;grid-template-columns:240px 1fr;gap:26px;padding:26px 0;border-top:1px solid var(--line-soft)}
.day:first-of-type{border-top:0}
.day figure{margin:0;border-radius:10px;overflow:hidden;aspect-ratio:4/3}
.day figure img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:transform .4s}
.day figure:hover img{transform:scale(1.05)}
.day .daynum{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.day h3{font-family:var(--serif);color:var(--cream);font-size:25px;font-weight:700;margin:4px 0 6px;line-height:1.15}
.day p{margin:0 0 10px}
.day .strong{color:var(--cream)}
.tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:20px;margin:2px 6px 0 0}
.tag.rest{color:#bfe6c2;background:rgba(120,190,130,.12);border:1px solid rgba(120,190,130,.3)}
.tag.drive{color:var(--gold-soft);background:rgba(205,163,90,.1);border:1px solid var(--line)}
.tag.sleep{color:var(--muted);background:var(--bg3);border:1px solid var(--line-soft)}
@media(max-width:680px){.day{grid-template-columns:1fr}.day figure{aspect-ratio:16/9;max-height:240px}}

/* ---------- RECOMANATS (map) ---------- */
.routemap{margin:0 0 14px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.routemap img{width:100%;display:block;cursor:zoom-in}
.routecap{font-family:var(--body);font-size:15px;color:var(--text);background:var(--bg2);border:1px solid var(--line);
  border-radius:10px;padding:14px 18px;margin:0 0 30px;font-style:italic}
.routecap b{color:var(--gold-soft);font-style:normal}
.pins{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:680px){.pins{grid-template-columns:1fr}}
.pinbox{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:22px 24px}
.pinbox h4{font-family:var(--serif);color:var(--cream);font-size:20px;margin:0 0 4px}
.pinbox .note{color:var(--muted);font-style:italic;font-size:14.5px;margin:0 0 14px}
.pinlist{list-style:none;padding:0;margin:0}
.pinlist li{padding:7px 0 7px 22px;position:relative;border-top:1px solid var(--line-soft);font-size:16px}
.pinlist li:first-child{border-top:0}
.pinlist li::before{content:"📍";position:absolute;left:0;font-size:12px;top:9px}
.pinlist.off li::before{content:"○";color:var(--muted);left:4px}
.pinlist .where{color:var(--gold);font-family:var(--mono);font-size:11px;letter-spacing:.06em}

/* ---------- EXCURSIONS / VOTE ---------- */
.vote-id{margin:0 0 24px}
.vote-id label,.propose label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);display:block}
.vote-id input,.propose textarea{display:block;width:100%;max-width:360px;margin-top:7px;background:var(--bg2);
  border:1px solid var(--line);border-radius:8px;color:var(--cream);font-family:var(--body);font-size:16px;padding:11px 13px}
.propose{margin:22px 0 0}.propose textarea{max-width:100%;resize:vertical}
.exc{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.exc{grid-template-columns:1fr}}
.exccard{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:22px 24px;display:flex;flex-direction:column}
.exchead{display:flex;align-items:flex-start;gap:13px;margin-bottom:11px}
.excicon{font-size:30px;line-height:1.1;flex:0 0 auto}
.exchead h3{font-family:var(--serif);color:var(--cream);font-size:21px;font-weight:700;margin:0;line-height:1.15}
.excmeta{font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:var(--gold);margin:4px 0 0;text-transform:uppercase}
.excbadge{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:20px;white-space:nowrap;align-self:flex-start}
.excbadge.rec{color:#bfe6c2;background:rgba(120,190,130,.14);border:1px solid rgba(120,190,130,.34)}
.excbadge.warn{color:#f0c9a8;background:rgba(205,120,80,.12);border:1px solid rgba(205,120,80,.4)}
.exccard p{font-size:15px;margin:0 0 12px;line-height:1.55}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:0 0 12px}
@media(max-width:520px){.proscons{grid-template-columns:1fr}}
.proscons ul{list-style:none;margin:0;padding:0;font-size:13.5px;line-height:1.45}
.proscons li{padding-left:19px;position:relative;margin-bottom:6px}
.pros li::before{content:"✓";position:absolute;left:0;color:#9bd6a6}
.cons li::before{content:"✗";position:absolute;left:0;color:#e0a07f}
.excprice{font-family:var(--mono);font-size:11.5px;color:var(--gold-soft);border-top:1px solid var(--line-soft);padding-top:11px;letter-spacing:.02em;line-height:1.5}
.etna-cost{width:100%;border-collapse:collapse;margin:0 0 12px;font-size:13.5px}
.etna-cost td{padding:7px 2px;border-top:1px solid var(--line-soft);color:var(--text)}
.etna-cost td:last-child{text-align:right;color:var(--gold-soft);font-family:var(--mono);white-space:nowrap}
.votebtns{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.votebtns button{flex:1 1 30%;background:var(--bg3);border:1px solid var(--line);color:var(--text);font-family:var(--mono);
  font-size:11.5px;letter-spacing:.02em;padding:10px 6px;border-radius:8px;cursor:pointer;transition:all .15s}
.votebtns button:hover{border-color:var(--gold);color:var(--cream)}
.votebtns button.sel{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--bg);border-color:var(--gold);font-weight:700}
.sharerow{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;align-items:center}
.sharebtn{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:var(--bg);border:0;font-family:var(--mono);
  font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;padding:13px 20px;border-radius:10px;cursor:pointer}
.sharebtn.alt{background:var(--bg2);color:var(--gold-soft);border:1px solid var(--line)}
.sharebtn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line-soft);font-weight:400}
.sharebtn:hover{filter:brightness(1.08)}
.votemsg{font-family:var(--mono);font-size:12px;color:#9bd6a6;margin-top:14px;min-height:16px}

/* ---------- FOOD / ON MENJAR ---------- */
.foodgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.foodgrid{grid-template-columns:1fr}}
.foodcat{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:20px 22px}
.foodcat h4{font-family:var(--serif);color:var(--cream);font-size:20px;margin:0 0 10px}
.foodcat ul{list-style:none;margin:0;padding:0}
.foodcat li{font-size:14.5px;line-height:1.5;padding:9px 0;border-top:1px solid var(--line-soft);color:var(--text)}
.foodcat li:first-child{border-top:0}
.foodcat b{color:var(--cream);font-weight:700}
.eat{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:26px}
@media(max-width:680px){.eat{grid-template-columns:1fr}}
.eatcard{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:16px 20px}
.eatcard h5{font-family:var(--serif);color:var(--cream);font-size:17px;margin:0 0 3px}
.eatcard .w{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.eatcard p{margin:6px 0 0;font-size:14px;color:var(--text)}

/* ---------- LOGISTICS ---------- */
.logi{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.logi{grid-template-columns:1fr}}
.card{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:20px 22px}
.card h4{font-family:var(--serif);color:var(--cream);font-size:19px;margin:0 0 6px;display:flex;align-items:center;gap:9px}
.card p{margin:0;font-size:15.5px;color:var(--text)}
.card.warn{border-color:rgba(205,120,80,.4);background:rgba(150,80,50,.1)}
.card.warn h4{color:#f0c9a8}

/* ---------- FOOTER ---------- */
footer{text-align:center;padding:70px 24px 90px;border-top:1px solid var(--line)}
footer .fin{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:clamp(22px,3.4vw,30px)}
footer .small{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ---------- LIGHTBOX ---------- */
img[data-zoom]{cursor:zoom-in}
.lb{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(10,7,4,.95);padding:24px}
.lb.open{display:flex}
.lb>img{max-width:94vw;max-height:86vh;object-fit:contain;border-radius:6px;box-shadow:0 12px 50px rgba(0,0,0,.6)}
.lb .lbcap{position:absolute;bottom:16px;left:0;width:100%;text-align:center;color:var(--cream);font-family:var(--mono);font-size:12px;letter-spacing:.08em;padding:0 20px}
.lb .lbcount{position:absolute;top:22px;left:0;width:100%;text-align:center;color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.2em}
.lb button{position:absolute;background:rgba(23,17,12,.62);border:1px solid var(--line);color:var(--cream);width:50px;height:50px;
  border-radius:50%;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.lb button:hover{background:var(--gold);color:var(--bg)}
.lb .lbclose{top:18px;right:18px}.lb .lbprev{left:14px;top:50%;transform:translateY(-50%)}.lb .lbnext{right:14px;top:50%;transform:translateY(-50%)}
@media(max-width:680px){.lb button{width:42px;height:42px;font-size:22px}}

/* ---------- MOBILE ---------- */
@media(max-width:680px){
  body{font-size:17px;line-height:1.65}
  section{padding:46px 0}
  .wrap{padding:0 18px}
  h2.sec{font-size:clamp(26px,7vw,34px)}
  .sec-rule{margin:12px 0 26px}
}

/* ============================================================
   v3 — fonts més grans i llegibles, més espaiat vertical,
        carrusels dins de targetes, comptador de vots,
        blocs amplis (ferri/parking), "on menjar" per zona
   ============================================================ */
body{font-size:20px;line-height:1.74}
section{padding:88px 0}
.sec-rule{margin:16px 0 40px}
.intro{font-size:18px;margin:-8px 0 36px}
.zone{margin-bottom:34px}

/* llegibilitat del text de contingut */
.seelist li{font-size:16px}
.foodcat li{font-size:15.5px}
.card p{font-size:16.5px;line-height:1.6}
.exccard p{font-size:16px}
.proscons ul{font-size:14.5px}
.day p{font-size:18px}
.pinlist li{font-size:16.5px}
.bmeta{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--gold);margin:0 0 8px}
.bnote{font-size:14.5px;color:var(--muted);margin:12px 0 0;padding-top:10px;border-top:1px solid var(--line-soft)}

/* nota dins de zona (Palermo) */
.zone-note{font-style:italic;color:var(--muted);font-size:16px;margin:0 0 8px;padding:12px 16px;background:var(--bg3);border-radius:8px}

/* mini-carrusel dins de targetes d'experiència (imatges més petites) */
.exccard .carousel{margin:0 0 14px}
.exccard .carousel-slide img{height:clamp(150px,26vw,195px)}

/* comptador de vots */
.votebtns button .cnt{display:inline-block;margin-left:6px;min-width:17px;padding:0 5px;border-radius:10px;
  background:rgba(205,163,90,.18);color:var(--gold-soft);font-weight:700;font-size:11px}
.votebtns button.has .cnt{background:var(--gold);color:var(--bg)}
.votebtns button.has{border-color:var(--gold)}

/* blocs amplis a logística */
.card.full{grid-column:1/-1}
.card-list{list-style:none;padding:0;margin:12px 0 0}
.card-list li{padding:10px 0 10px 22px;position:relative;border-top:1px solid var(--line-soft);font-size:16px;line-height:1.55}
.card-list li:first-child{border-top:0}
.card-list li::before{content:"›";position:absolute;left:2px;color:var(--gold);font-weight:700}
.parknote{margin:14px 0 0;font-size:15px;color:var(--gold-soft);font-style:italic;
  background:rgba(205,163,90,.08);border:1px solid var(--line-soft);border-radius:8px;padding:12px 14px}

/* "On menjar" per zona */
.subsec{font-family:var(--serif);color:var(--cream);font-size:clamp(22px,3vw,28px);font-weight:700;margin:48px 0 6px}
.eatgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
@media(max-width:680px){.eatgrid{grid-template-columns:1fr}}
.eatzone{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:18px 22px}
.eatzone h5{font-family:var(--serif);color:var(--gold-soft);font-size:19px;margin:0 0 8px}
.eatzone ul{list-style:none;margin:0;padding:0}
.eatzone li{font-size:15px;line-height:1.5;padding:8px 0;border-top:1px solid var(--line-soft);color:var(--text)}
.eatzone li:first-child{border-top:0}
.eatzone b{color:var(--cream);font-weight:700}

@media(max-width:680px){
  body{font-size:18px}
  section{padding:58px 0}
  .day p{font-size:17px}
}

/* ============================================================
   v4 — nav superior (amaga en scroll avall), pla hora a hora,
        pista de zoom a les imatges
   ============================================================ */
[id]{scroll-margin-top:66px}
.zoomhint{margin-left:auto;align-self:center;text-align:right;font-family:var(--mono);
  font-size:11.5px;line-height:1.55;letter-spacing:.03em;color:var(--gold);max-width:210px}
.zoomhint .ic{font-size:15px}
.mapshint{flex-basis:100%;margin:14px 0 0;text-align:left;max-width:none;align-self:flex-start}
@media(max-width:680px){.zoomhint{margin:16px 0 0;text-align:left;max-width:none;align-self:flex-start}}

.topnav{position:fixed;top:0;left:0;width:100%;z-index:600;
  background:rgba(23,17,12,.94);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);transform:translateY(-115%);transition:transform .32s ease}
.topnav.show{transform:translateY(0)}
.topnav-brand{display:none;font-family:var(--serif);color:var(--cream);font-size:17px;font-weight:700}
.topnav-toggle{display:none;background:rgba(205,163,90,.12);border:1px solid var(--gold);color:var(--gold-soft);
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  padding:9px 16px;border-radius:9px;cursor:pointer;white-space:nowrap}
.topnav-toggle:active{background:var(--gold);color:var(--bg)}
.topnav-links{display:flex;gap:4px;justify-content:center;padding:9px 12px}
.topnav-links a{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--text);border:0;padding:7px 13px;border-radius:20px;white-space:nowrap;transition:color .15s,background .15s}
.topnav-links a:hover,.topnav-links a:active{color:var(--bg);background:var(--gold)}
@media(max-width:700px){
  .topnav{transform:none!important;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:9px 16px}
  .topnav-brand{display:block}
  .topnav-toggle{display:flex;align-items:center;justify-content:center}
  .topnav-links{display:none;flex-direction:column;width:100%;gap:3px;padding:8px 0 4px;justify-content:flex-start}
  .topnav.open .topnav-links{display:flex}
  .topnav-links a{font-size:13.5px;padding:12px 12px;border-radius:8px;letter-spacing:.06em}
  .topnav-links a:hover,.topnav-links a:active{background:var(--bg3);color:var(--gold)}
}

.dayplan{margin:14px 0 0;border-top:1px solid var(--line-soft);padding-top:12px}
.dayplan summary{cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold);list-style:none;display:flex;align-items:center;gap:8px}
.dayplan summary::-webkit-details-marker{display:none}
.dayplan summary::before{content:"▸";transition:transform .2s;display:inline-block}
.dayplan[open] summary::before{transform:rotate(90deg)}
.dayplan summary:hover{color:var(--gold-soft)}
.timeline{list-style:none;margin:14px 0 4px;padding:0}
.timeline li{display:grid;grid-template-columns:88px 1fr;gap:12px;padding:8px 0;border-top:1px solid var(--line-soft);font-size:15.5px;line-height:1.5}
.timeline li:first-child{border-top:0}
.timeline .t{font-family:var(--mono);font-size:12px;color:var(--gold-soft);letter-spacing:.02em;padding-top:3px}
.timeline b{color:var(--cream);font-weight:700}
@media(max-width:680px){.timeline li{grid-template-columns:64px 1fr;gap:10px;font-size:15px}}

/* ============================================================
   v5 — afinaments NOMÉS per a mòbils petits (<500px)
   ============================================================ */
@media(max-width:500px){
  /* títol amb una mica d'aire a dalt */
  .hero h1{padding-top:30px}

  /* recorregut: una fila compacta per base (en lloc de blocs grans) */
  .ribbon{flex-direction:column;gap:0;padding:4px 18px}
  .conn{display:none}
  .node{display:grid;grid-template-columns:auto 1fr auto;column-gap:12px;row-gap:1px;align-items:center;
        text-align:left;width:100%;padding:13px 0;border-top:1px solid var(--line-soft)}
  .node:first-child{border-top:0}
  .node .num{grid-row:1/3;grid-column:1;margin:0;width:30px;height:30px;align-self:center}
  .node .city{grid-column:2;grid-row:1;font-size:18px}
  .node .nights{grid-column:3;grid-row:1;margin:0;white-space:nowrap}
  .node .dates{grid-column:2;grid-row:2;margin:0}

  /* lectura més còmoda dins de les caixes */
  .rooms{font-size:16px}
  .rooms li{padding:3px 0 3px 18px}
  .seelist li{font-size:16.5px;line-height:1.6;padding:12px 0}
  .seelist .h{display:inline-block;margin:0 7px 2px 0}
  .foodcat li,.eatzone li{font-size:16px;line-height:1.6;padding:11px 0}
  .card-list li{font-size:16.5px;line-height:1.6;padding:13px 0 13px 22px}
  .pinlist li{font-size:16.5px;line-height:1.5;padding:11px 0 11px 24px}
  .proscons ul{font-size:15px;line-height:1.55}
  .proscons li{margin-bottom:7px}
  .timeline li{font-size:15.5px;padding:10px 0}
}

/* ---------- PIN GOOGLE MAPS ---------- */
.gmap{display:inline-flex;align-items:center;vertical-align:-.18em;
  margin-left:.34em;border:0;line-height:1;opacity:.85;
  transition:opacity .15s,transform .15s}
.gmap svg{width:1.05em;height:1.05em;display:block;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.45))}
.gmap:hover{opacity:1;transform:translateY(-1px)}
