/* VisitPontedera.it — stylesheet */
:root{
  --green:#0e7a5f; --green-d:#0a5a46; --terra:#c8552b; --terra-d:#a33f1d;
  --cream:#fbf7ef; --ink:#23201c; --muted:#6c6357; --line:#e7ded0;
  --gold:#e0a92e; --white:#fff; --shadow:0 8px 30px rgba(40,30,10,.10);
  --radius:16px; --wrap:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);
  background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.15;margin:.2em 0 .4em;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.2rem)}
h3{font-size:1.25rem}
a{color:var(--green-d);text-decoration:none}
a:hover{text-decoration:underline}
p{margin:.4em 0 1em}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.muted{color:var(--muted)} .small{font-size:.85rem}
.bare{list-style:none;padding:0;margin:0}
.skip{position:absolute;left:-999px}.skip:focus{left:12px;top:12px;background:#fff;padding:8px;z-index:99;border-radius:8px}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,239,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.brand{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1.2rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{font-size:1.5rem}
.brand-text strong,.brand strong{color:var(--terra);font-weight:700}
.site-nav{display:flex;gap:.3rem;flex-wrap:wrap}
.site-nav a{padding:.5rem .8rem;border-radius:10px;color:var(--ink);font-weight:500;font-size:.97rem}
.site-nav a:hover{background:#fff;text-decoration:none}
.site-nav a[aria-current=page]{background:var(--green);color:#fff}
.nav-btn{display:none;font-size:1.5rem;cursor:pointer;padding:.2rem .6rem;border-radius:8px}
@media(max-width:820px){
  .nav-btn{display:block}
  .site-nav{display:none;width:100%;flex-direction:column;padding-top:.5rem}
  .nav-toggle:checked ~ .site-nav{display:flex}
  .header-inner{flex-wrap:wrap}
}

/* Hero */
.hero{position:relative;color:#fff;padding:5.5rem 0 4rem;text-align:center;overflow:hidden;
  background:linear-gradient(135deg,#0e7a5f 0%,#0a5a46 45%,#163b30 100%)}
.hero::after{content:"";position:absolute;inset:0;opacity:.12;
  background:radial-gradient(circle at 20% 30%,#fff 0,transparent 40%),radial-gradient(circle at 80% 70%,var(--gold) 0,transparent 45%)}
.hero .wrap{position:relative;z-index:1}
.hero h1{color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hero p.lead{font-size:1.2rem;max-width:680px;margin:0 auto 1.6rem;color:#eafff7}
.eyebrow{display:inline-block;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;
  font-weight:600;color:var(--gold);margin-bottom:.6rem}
.hero-cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:.4rem}

/* Hero / header con foto reale (overlay scuro per leggibilità) */
.hero.has-img,.page-hero.has-img{
  background-image:linear-gradient(rgba(10,40,30,.60),rgba(8,30,24,.74)),var(--bg);
  background-size:cover;background-position:center}
.hero.has-img::after{display:none}
.card-top.has-img{background-image:linear-gradient(rgba(10,40,30,.10),rgba(10,40,30,.45)),var(--bg);
  background-size:cover;background-position:center;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.area-visual.has-img{background-image:linear-gradient(rgba(15,30,25,.10),rgba(12,28,22,.62)),var(--bg);
  background-size:cover;background-position:center;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.figure-credit{font-size:.72rem;color:var(--muted);margin:.3rem 0 0}
.figure-credit a{color:var(--muted)}

/* Buttons */
.btn{display:inline-block;padding:.8rem 1.4rem;border-radius:999px;font-weight:600;
  border:2px solid transparent;cursor:pointer;transition:.15s;font-size:1rem}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--terra);color:#fff}
.btn-primary:hover{background:var(--terra-d)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d)}
.btn-sm{padding:.5rem 1rem;font-size:.9rem}

/* Sections */
section.block{padding:3.5rem 0}
.section-head{max-width:720px;margin-bottom:1.8rem}
.section-head .eyebrow{color:var(--terra)}
.lead{font-size:1.1rem;color:var(--muted)}

/* Cards grid */
.grid{display:grid;gap:1.3rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.18s}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(40,30,10,.16)}
.card-top{height:120px;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff}
.card-body{padding:1.1rem 1.2rem 1.3rem;flex:1;display:flex;flex-direction:column}
.card-body h3{margin-top:0}
.card-body p{color:var(--muted);font-size:.96rem;flex:1}
.card .tag{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;color:var(--green-d);background:#e7f4ee;padding:.2rem .6rem;border-radius:999px;margin-bottom:.6rem;align-self:flex-start}
.card-link{margin-top:.8rem;font-weight:600;color:var(--terra)}

/* gradient toppers */
.g-green{background:linear-gradient(135deg,#0e7a5f,#0a5a46)}
.g-terra{background:linear-gradient(135deg,#c8552b,#a33f1d)}
.g-gold{background:linear-gradient(135deg,#e0a92e,#c8552b)}
.g-blue{background:linear-gradient(135deg,#2c6fae,#163b30)}
.g-violet{background:linear-gradient(135deg,#6a4c93,#2c3e7a)}
.g-olive{background:linear-gradient(135deg,#7a8a3a,#3d5a2a)}

/* Hotel / listing rows */
.listing{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem 1.3rem;box-shadow:var(--shadow);display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}
.listing .l-main{flex:1;min-width:230px}
.listing h3{margin:0 0 .2rem}
.listing .stars{color:var(--gold);letter-spacing:.1em}
.listing .l-meta{font-size:.88rem;color:var(--muted)}
.listing .l-cta{display:flex;flex-direction:column;gap:.4rem;align-items:stretch}
.price-from{font-size:.8rem;color:var(--muted)}

/* Alt background */
.bg-soft{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bg-deep{background:#15332a;color:#e8f3ee}
.bg-deep h2,.bg-deep h3{color:#fff}
.bg-deep .lead{color:#bcd6cc}

/* Anchored area blocks (dintorni) */
.area{display:grid;grid-template-columns:1.1fr 1fr;gap:2rem;align-items:center;padding:2.5rem 0;border-bottom:1px solid var(--line)}
.area:nth-child(even){direction:rtl}.area:nth-child(even)>*{direction:ltr}
.area-visual{border-radius:var(--radius);min-height:240px;display:flex;align-items:flex-end;
  padding:1.2rem;color:#fff;box-shadow:var(--shadow);font-family:'Fraunces',serif;font-size:1.6rem;font-weight:700}
.area ul{padding-left:1.1rem;color:var(--muted)}
.area .dist{display:inline-flex;gap:.4rem;align-items:center;background:#e7f4ee;color:var(--green-d);
  font-weight:600;font-size:.85rem;padding:.3rem .7rem;border-radius:999px;margin-bottom:.6rem}
@media(max-width:760px){.area{grid-template-columns:1fr;direction:ltr!important}}

/* CTA strip */
.cta-strip{background:linear-gradient(120deg,var(--terra),var(--terra-d));color:#fff;border-radius:var(--radius);
  padding:2.2rem;text-align:center;box-shadow:var(--shadow)}
.cta-strip h2{color:#fff;margin-top:0}
.cta-strip p{color:#ffe9df;max-width:600px;margin:0 auto 1.2rem}

/* Events */
.event{display:flex;gap:1.1rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem 1.2rem;box-shadow:var(--shadow);align-items:flex-start}
.event .date{flex:0 0 64px;text-align:center;background:var(--green);color:#fff;border-radius:12px;padding:.5rem .2rem}
.event .date .m{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em}
.event .date .d{display:block;font-size:1.5rem;font-weight:700;font-family:'Fraunces',serif;line-height:1}
.event h3{margin:.1rem 0 .3rem}
.event p{margin:.2rem 0 0;color:var(--muted);font-size:.95rem}

/* Ads */
.ad-wrap{margin:2rem auto;text-align:center;max-width:var(--wrap)}
.ad-label{display:block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}

/* Breadcrumb / page hero */
.page-hero{background:linear-gradient(135deg,#0e7a5f,#15332a);color:#fff;padding:3rem 0 2.4rem}
.page-hero h1{color:#fff;margin:0}
.page-hero p{color:#cfeee2;max-width:680px;margin:.4rem 0 0}
.crumb{font-size:.85rem;color:#9fd3c1;margin-bottom:.4rem}
.crumb a{color:#cfeee2}

/* prose */
.prose{max-width:760px}
.prose h2{margin-top:2rem}
.prose ul{color:var(--ink)}
.callout{background:#fff;border-left:4px solid var(--gold);border-radius:10px;padding:1rem 1.2rem;box-shadow:var(--shadow);margin:1.4rem 0}

/* utils */
.center{text-align:center}
.mt0{margin-top:0}.mt2{margin-top:1.5rem}
.stack>*+*{margin-top:1rem}
.flex-cta{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center;margin-top:1.4rem}

/* FAQ */
.faq{max-width:820px;margin:1rem 0}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:.7rem;box-shadow:var(--shadow);overflow:hidden}
.faq-item summary{cursor:pointer;padding:1rem 1.2rem;font-weight:600;font-family:'Fraunces',serif;font-size:1.08rem;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--terra);font-weight:700;font-size:1.3rem;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-a{padding:0 1.2rem 1.1rem;color:var(--muted)}
.faq-a p{margin:.2rem 0 .6rem}

/* Info table (schede pratiche) */
.infobox{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem 1.3rem}
.infobox h3{margin-top:0}
.info-row{display:flex;gap:.6rem;padding:.45rem 0;border-bottom:1px dashed var(--line);font-size:.95rem}
.info-row:last-child{border-bottom:0}
.info-row .k{flex:0 0 130px;color:var(--muted);font-weight:600}
.info-row .v{flex:1}

/* Two-column guide layout */
.guide-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem;align-items:start}
@media(max-width:880px){.guide-grid{grid-template-columns:1fr}}
.sticky{position:sticky;top:84px}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.4rem 0 1rem}
.chip{background:#e7f4ee;color:var(--green-d);font-weight:600;font-size:.82rem;padding:.3rem .7rem;border-radius:999px}

/* Numbered list of POIs */
.poi{counter-reset:poi;list-style:none;padding:0;margin:1.2rem 0}
.poi>li{position:relative;padding:.2rem 0 1.1rem 3rem;border-left:2px solid var(--line);margin-left:1rem}
.poi>li::before{counter-increment:poi;content:counter(poi);position:absolute;left:-1rem;top:0;
  width:2rem;height:2rem;background:var(--green);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Fraunces',serif}
.poi>li:last-child{border-left-color:transparent}
.poi h3{margin:.1rem 0 .3rem}
.poi p{margin:.2rem 0;color:var(--muted)}

/* Itinerary timeline */
.timeline{list-style:none;padding:0;margin:1.2rem 0}
.timeline>li{display:flex;gap:1rem;padding-bottom:1.2rem}
.timeline .when{flex:0 0 92px;font-weight:700;color:var(--terra);font-family:'Fraunces',serif}
.timeline .what h3{margin:.1rem 0 .25rem}
.timeline .what p{margin:.1rem 0;color:var(--muted)}

/* Pills row of related links */
.related{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.related a{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.4rem .9rem;font-weight:600;font-size:.9rem;box-shadow:var(--shadow)}

/* prose wide tweaks */
.prose-wide{max-width:860px}
.prose h3{margin-top:1.4rem}
table.simple{width:100%;border-collapse:collapse;margin:1rem 0;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
table.simple th,table.simple td{padding:.7rem .9rem;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
table.simple th{background:#f3ede1;font-family:'Inter',sans-serif}

/* Footer */
.site-footer{background:#15201b;color:#cfd8d2;margin-top:3rem;padding:2.6rem 0 1.4rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:1.6rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 .7rem}
.site-footer a{color:#cfd8d2}.site-footer a:hover{color:#fff}
.brand--footer{color:#fff;margin-bottom:.6rem}
.footer-legal{border-top:1px solid #2a3a32;margin-top:1.8rem;padding-top:1.2rem}
.site-footer .muted{color:#9aa8a0}
