/* app.css — stile della guida ospiti. Volutamente "app", diverso dal sito vetrina. */

:root{
  --paper:#fbfaf6;
  --sea:#14808f;
  --sea-deep:#0b5560;
  --sea-foam:#e3f0f0;
  --ink:#1f2d2c;
  --ink-soft:#5d6b69;
  --gold:#d99a3b;
  --coral:#e2664f;
  --line:rgba(31,45,44,.12);
  --display:"Fraunces","Iowan Old Style",Georgia,serif;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --maxw:760px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.6;-webkit-font-smoothing:antialiased;
  padding-bottom:5rem; /* spazio per la tabbar */
}
a{color:var(--sea-deep);}
img{max-width:100%;display:block;}
em{font-style:italic;}

/* ---- APP BAR (top) ---- */
.appbar{
  position:sticky;top:0;z-index:1100; /* sopra i pannelli/controlli Leaflet */
  display:flex;align-items:center;gap:.6rem;
  background:rgba(251,250,246,.9);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  padding:.8rem 1.2rem;padding-top:max(.8rem,env(safe-area-inset-top));
}
.appbar-back{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;margin-left:-.35rem;border-radius:50%;font-size:1.7rem;line-height:1;color:var(--sea-deep);text-decoration:none;flex:0 0 auto;}
.appbar-back:active{background:var(--sea-foam);}
.appbar-brand{font-family:var(--display);font-size:1.05rem;text-decoration:none;color:var(--sea-deep);}
.appbar-title{font-size:.8rem;color:var(--ink-soft);}

.screen{max-width:var(--maxw);margin:0 auto;}

/* ---- HERO ---- */
.hero{padding:2.6rem 1.4rem 2rem;}
.hero--sea{
  background:linear-gradient(160deg,var(--sea),var(--sea-deep));
  color:#fff;border-radius:0 0 22px 22px;
}
.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;font-weight:600;opacity:.85;margin:0 0 .7rem;}
.hero h1{font-family:var(--display);font-weight:400;font-size:clamp(2rem,7vw,2.8rem);line-height:1.06;margin:0 0 .7rem;}
.hero--sea h1 em{color:#ffe9c9;}
.hero h1 em{color:var(--sea-deep);}
.hero-sub{margin:0;max-width:44ch;opacity:.92;}
.hero:not(.hero--sea) .hero-sub{color:var(--ink-soft);}

/* ---- SECTIONS ---- */
.pad{padding:2rem 1.4rem .4rem;}
.label{text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;font-weight:600;color:var(--sea);margin:0 0 .4rem;}
.title{font-family:var(--display);font-weight:400;font-size:clamp(1.5rem,5vw,2rem);line-height:1.12;margin:0 0 .7rem;}
.title em{color:var(--sea-deep);}
.divider{width:44px;height:3px;background:var(--gold);border-radius:3px;margin:0 0 1.2rem;}
.lead{color:var(--ink-soft);max-width:60ch;margin:0 0 1rem;}

/* ---- PILLS (info rapide) ---- */
.pills{display:flex;flex-wrap:wrap;gap:.6rem;padding:1.2rem 1.4rem 0;}
.pill{
  flex:1 1 44%;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:.7rem .9rem;display:flex;align-items:center;gap:.6rem;
  box-shadow:0 6px 18px rgba(11,85,96,.06);
}
.pill .ic{font-size:1.2rem;}
.pill .k{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);}
.pill .v{font-weight:600;font-size:.9rem;word-break:break-word;}

/* ---- STEPS ---- */
.steps{counter-reset:s;list-style:none;padding:0;margin:0;display:grid;gap:.7rem;}
.steps li{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.9rem 1rem .9rem 3.2rem;}
.steps li::before{
  counter-increment:s;content:counter(s);
  position:absolute;left:.9rem;top:.9rem;width:1.6rem;height:1.6rem;border-radius:50%;
  background:var(--sea);color:#fff;font-weight:600;font-size:.8rem;
  display:flex;align-items:center;justify-content:center;
}
.steps li strong{display:block;margin-bottom:.1rem;}
.steps li span{color:var(--ink-soft);font-size:.9rem;}

/* ---- CARDS ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem;}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.2rem;}
.card h3{margin:.1rem 0 .4rem;font-size:1rem;}
.card p{margin:0;color:var(--ink-soft);font-size:.9rem;}
.card .card-tag{font-style:italic;color:var(--sea);margin-bottom:.3rem;}
.card .card-tip{margin-top:.5rem;font-size:.85rem;color:var(--sea-deep);}

/* ---- RULES ---- */
.rules{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.6rem;}
.rule{display:flex;gap:.6rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.8rem .9rem;}
.rule .ic{font-size:1.1rem;}
.rule div{font-size:.9rem;}

/* ---- CHIPS ---- */
.chips{display:flex;flex-wrap:wrap;gap:.5rem;}
.chip-static{background:var(--sea-foam);color:var(--sea-deep);border-radius:999px;padding:.35rem .8rem;font-size:.8rem;font-weight:500;}

/* ---- LINK ROWS (prenotazioni, noleggi) ---- */
.links{display:grid;gap:.6rem;margin-top:.9rem;}
.link-row{display:flex;flex-direction:column;gap:.15rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.8rem 1rem;text-decoration:none;color:var(--ink);}
.link-row:active{border-color:var(--sea);}
.link-name{font-weight:600;font-size:.95rem;}
.link-note{font-size:.84rem;color:var(--ink-soft);}
/* Riga emergenza in evidenza (es. 112). */
.link-row--sos{border-color:var(--coral);background:rgba(226,102,79,.07);box-shadow:0 6px 16px rgba(226,102,79,.12);}
.link-row--sos .link-name{color:var(--coral);}
/* Riga con numero ancora da inserire: non cliccabile, in attesa. */
.link-row--todo{border-style:dashed;opacity:.7;}

/* ---- CODICI IDENTIFICATIVI (CIN/CIR) ---- */
.legal{text-align:center;font-size:.72rem;color:var(--ink-soft);letter-spacing:.04em;margin:1.4rem 1.4rem .4rem;}

/* ---- RISTORANTI ---- */
.resto-cat{font-weight:600;font-size:.9rem;color:var(--sea-deep);margin:1.1rem 0 .5rem;}

/* ---- NOTE ---- */
.note{background:var(--sea-foam);border:1px dashed var(--sea);color:var(--sea-deep);border-radius:12px;padding:.85rem 1rem;font-size:.88rem;margin-top:.8rem;}

/* ---- HOUSE LIST (home) ---- */
.house-list{display:grid;gap:1rem;}
.house-card{display:block;background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.3rem 1.4rem;text-decoration:none;color:var(--ink);box-shadow:0 8px 22px rgba(11,85,96,.07);}
.house-card h2{font-family:var(--display);font-weight:400;font-size:1.5rem;margin:.5rem 0 .4rem;}
.house-card p{color:var(--ink-soft);font-size:.92rem;margin:0 0 .7rem;}
.house-badge{display:inline-block;background:var(--gold);color:#3a2c12;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:.25rem .7rem;border-radius:999px;}
.house-specs{display:block;font-size:.8rem;color:var(--ink-soft);margin-bottom:.5rem;}
.house-go{font-size:.85rem;font-weight:600;color:var(--sea);}
.island-link{display:inline-block;margin-top:1rem;font-weight:600;color:var(--sea-deep);text-decoration:none;}

/* ---- WELCOME CARD (home pubblica, senza link alle case) ---- */
.welcome-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.4rem 1.5rem;box-shadow:0 8px 22px rgba(11,85,96,.07);}
.welcome-card h2{font-family:var(--display);font-weight:400;font-size:1.4rem;margin:0 0 .5rem;}
.welcome-card p{color:var(--ink-soft);font-size:.92rem;margin:0 0 1.1rem;}
.welcome-actions{display:flex;flex-wrap:wrap;gap:.6rem;}
.btn-primary,.btn-ghost{display:inline-block;text-decoration:none;font-weight:600;font-size:.9rem;border-radius:999px;padding:.6rem 1.1rem;}
.btn-primary{background:var(--sea);color:#fff;}
.btn-ghost{background:transparent;color:var(--sea-deep);border:1px solid var(--line);}
.btn-block{display:block;text-align:center;margin-top:1.2rem;padding:.85rem 1.1rem;font-size:.95rem;box-shadow:0 8px 20px rgba(11,85,96,.18);}

/* ---- HOME: hero + griglia guida isola ---- */
.hero--home{padding:2.8rem 1.4rem 2.4rem;}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem;margin-top:1rem;}
.feature-card{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.1rem 1.1rem 1.2rem;text-decoration:none;color:var(--ink);box-shadow:0 6px 18px rgba(11,85,96,.06);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;}
.feature-card:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(11,85,96,.12);border-color:rgba(20,128,143,.4);}
.fc-ic{display:flex;align-items:center;justify-content:center;width:2.6rem;height:2.6rem;border-radius:14px;background:var(--sea-foam);font-size:1.4rem;margin-bottom:.6rem;}
.feature-card h3{font-family:var(--display);font-weight:400;font-size:1.12rem;margin:0 0 .25rem;}
.feature-card p{margin:0;color:var(--ink-soft);font-size:.85rem;line-height:1.45;}

/* ---- MAPPA ---- */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1rem;}
.chip{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:.42rem .9rem;font-size:.84rem;font-weight:500;cursor:pointer;font-family:var(--body);}
.chip[aria-pressed="true"]{background:var(--sea);color:#fff;border-color:var(--sea);}
/* Altezza limitata così la mappa resta tra header (sticky) e tabbar (fissa)
   e non finisce mai sotto la barra in basso. 100dvh tiene conto delle barre
   del browser su mobile. */
#map{height:min(56vh,calc(100dvh - 14rem));min-height:300px;margin-bottom:1rem;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 10px 28px rgba(11,85,96,.1);}
/* Mappa a tutto schermo: il nodo #map viene spostato (via JS) dentro questo overlay,
   figlio diretto di <body>, che copre il viewport sopra header e tabbar. La mappa
   riempie l'overlay al 100% — niente position:fixed sul #map (causava la sparizione). */
.map-fs-overlay{position:fixed;inset:0;z-index:2000;background:var(--sea-deep);}
.map-fs-overlay[hidden]{display:none;}
#map.is-fullscreen{width:100%;height:100%!important;max-height:none;min-height:0;margin:0;border:0;border-radius:0;}
/* Mentre la mappa è fullscreen blocca lo scroll della pagina sotto e nascondi la tabbar. */
body.has-fullscreen-map{overflow:hidden;}
body.has-fullscreen-map .tabbar{display:none;}
/* Pulsante schermo intero: eredita lo stile dei controlli Leaflet, solo l'icona. */
.map-fs a{font-size:1.15rem;font-weight:700;line-height:26px;text-align:center;}
.leaflet-popup-content{font-family:var(--body);margin:.7rem .9rem;}
.pop-cat{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--sea);font-weight:700;}
.pop-name{font-family:var(--display);font-size:1.05rem;margin:.1rem 0 .25rem;}
.pop-note{color:var(--ink-soft);font-size:.86rem;margin:0 0 .4rem;}
.pop-link{font-size:.8rem;font-weight:600;}

/* ---- TABBAR (bottom nav, stile app) ---- */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:1100; /* sopra i pannelli/controlli Leaflet */
  display:flex;justify-content:space-around;
  background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  padding:.4rem .2rem;padding-bottom:max(.4rem,env(safe-area-inset-bottom));
}
.tabbar a{
  display:flex;flex-direction:column;align-items:center;gap:.1rem;
  text-decoration:none;color:var(--ink-soft);font-size:1.2rem;flex:1;padding:.3rem 0;
}
.tabbar a span{font-size:.62rem;font-weight:600;}
.tabbar a:active{color:var(--sea);}

@media (min-width:640px){
  .pill{flex:1 1 22%;}
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
