/* ================================================================
   Ponte dei Sospiri — Guida di Venezia
   Unique editorial "Venetian lagoon" theme
   Palette: deep lagoon teal + Venetian gold + terracotta on warm paper
   ================================================================ */

:root{
  --ink:#10302e;          /* near-black lagoon green */
  --teal:#0d5c63;         /* primary */
  --teal-deep:#0a3d44;    /* header / footer */
  --teal-soft:#e7f0ef;    /* tints */
  --gold:#c8962f;         /* accent / CTA */
  --gold-soft:#e3bd6a;
  --gold-deep:#a6791f;
  --terracotta:#b8503a;   /* secondary accent */
  --paper:#f7f3ea;        /* page background */
  --cream:#fffdf8;        /* cards */
  --line:#e6ddcb;         /* hairlines */
  --muted:#5a6664;        /* secondary text */
  --shadow:0 12px 40px rgba(10,61,68,.12);
  --shadow-sm:0 4px 16px rgba(10,61,68,.08);
  --radius:14px;
  --maxw:1180px;
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);font-size:17px;line-height:1.7;
  color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.18;margin:0 0 .55em;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2rem,5.2vw,3.4rem)}
h2{font-size:clamp(1.55rem,3.4vw,2.3rem);margin-top:1.5em}
h3{font-size:clamp(1.18rem,2vw,1.45rem);margin-top:1.5em}
h4{font-size:1.08rem;margin-top:1.2em}
p{margin:0 0 1.05em}
ul,ol{padding-left:1.25em;margin:0 0 1.1em}
li{margin-bottom:.5em}
strong{color:var(--ink)}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
hr{border:0;border-top:1px solid var(--line);margin:2.4em 0}

.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:840px;margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 .6em}

/* ===================== Header ===================== */
.site-header{position:sticky;top:0;z-index:60;background:var(--teal-deep);
  box-shadow:0 2px 18px rgba(8,54,60,.28)}
.hdr-inner{display:flex;align-items:center;gap:18px;padding:11px 22px;max-width:var(--maxw);margin:0 auto}
.hdr-logo{flex:0 0 auto;display:flex;align-items:center}
.hdr-logo img{height:46px;width:auto}
.hdr-nav{margin-left:auto;display:flex;align-items:center;gap:22px}
.hdr-nav ul{display:flex;list-style:none;gap:20px;margin:0;padding:0}
.hdr-nav a{color:#e9efee;font-weight:500;font-size:.95rem;padding:4px 0;border-bottom:2px solid transparent}
.hdr-nav a:hover{color:#fff;text-decoration:none;border-bottom-color:var(--gold)}
.hdr-nav a.active{color:var(--gold-soft);border-bottom-color:var(--gold)}

/* language switcher */
.lang-switch{position:relative}
.lang-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);color:#f1f4f3;
  padding:8px 13px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body)}
.lang-btn:hover{background:rgba(255,255,255,.16)}
.lang-btn svg{width:14px;height:14px}
.lang-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);background:var(--cream);
  border:1px solid var(--line);border-radius:12px;min-width:220px;box-shadow:var(--shadow);
  max-height:66vh;overflow-y:auto;z-index:70;padding:6px}
.lang-menu.open{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.lang-menu a{display:block;padding:8px 12px;font-size:.88rem;color:var(--ink);border-radius:7px}
.lang-menu a:hover{background:var(--teal-soft);text-decoration:none}
.lang-menu a.active{background:var(--gold-soft);font-weight:700}

/* CTA buttons */
.cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#3a2a06;font-weight:700;
  padding:12px 20px;border-radius:10px;border:1px solid var(--gold-deep);
  transition:transform .15s,box-shadow .15s,filter .15s;font-size:.96rem;text-align:center;
  box-shadow:0 4px 14px rgba(200,150,47,.32)}
.cta-btn:hover{text-decoration:none;transform:translateY(-2px);filter:brightness(1.04);
  box-shadow:0 8px 22px rgba(200,150,47,.42)}
.cta-btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5);box-shadow:none}
.cta-btn.ghost:hover{background:rgba(255,255,255,.12)}
.cta-btn.solid-teal{background:linear-gradient(180deg,#0f6b73,var(--teal-deep));color:#fff;border-color:var(--teal-deep);box-shadow:0 4px 14px rgba(10,61,68,.3)}
.cta-btn.lg{padding:15px 28px;font-size:1.05rem}
.cta-btn.block{display:flex;width:100%}

.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:1.7rem;cursor:pointer;line-height:1;padding:4px 8px}

/* ===================== Hero ===================== */
.hero{position:relative;color:#fff;background:var(--teal-deep)}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(8,40,45,.92) 0%,rgba(8,40,45,.75) 38%,rgba(8,40,45,.30) 70%,rgba(8,40,45,.15) 100%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:64px 22px 72px;
  display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-copy{max-width:620px}
.hero-copy .eyebrow{color:var(--gold-soft)}
.hero h1{color:#fff;margin-bottom:.35em}
.hero-lead{font-size:1.15rem;color:#e7eeed;margin-bottom:1.4em;max-width:54ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:1.6em;font-size:.92rem;color:#cfe0de}
.hero-meta span{display:inline-flex;align-items:center;gap:7px}
.hero-meta svg{width:16px;height:16px;color:var(--gold-soft);flex:0 0 auto}

/* booking widget slot in hero */
.booking-card{background:var(--cream);color:var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:22px;border:1px solid var(--line)}
.booking-card h2{font-size:1.25rem;margin:0 0 .3em}
.booking-card .price{font-size:1.05rem;color:var(--muted);margin:0 0 1em}
.booking-card .price b{color:var(--terracotta);font-size:1.45rem;font-family:var(--font-display)}
.booking-slot{margin:14px 0}
.booking-slot:empty{display:none}
.booking-note{font-size:.8rem;color:var(--muted);margin:.6em 0 0;text-align:center}
.trust-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px;font-size:.82rem;color:var(--muted)}
.trust-row span{display:inline-flex;align-items:center;gap:6px}
.trust-row svg{width:15px;height:15px;color:var(--teal)}

/* hero mini-disclaimer chip */
.disc-chip{position:relative;display:inline-flex;align-items:center;gap:6px;margin-top:18px;
  font-size:.74rem;color:#bcd0ce;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  padding:5px 10px;border-radius:20px;cursor:help}
.disc-chip svg{width:13px;height:13px;color:var(--gold-soft)}
.disc-chip .disc-pop{display:none;position:absolute;bottom:calc(100% + 10px);left:0;width:min(320px,80vw);
  background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:12px 14px;
  font-size:.8rem;line-height:1.5;box-shadow:var(--shadow);z-index:5}
.disc-chip:hover .disc-pop,.disc-chip:focus-within .disc-pop{display:block}
.disc-chip .disc-pop b{color:var(--terracotta)}

/* ===================== Discovery widget band ===================== */
.discovery{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:42px 0}
.discovery h2{text-align:center;margin:0 0 .2em}
.discovery .sub{text-align:center;color:var(--muted);max-width:60ch;margin:0 auto 1.6em}
.hawt-wrap{display:flex;justify-content:center;align-items:center;width:100%}

/* ===================== Content ===================== */
.section{padding:54px 0}
.section.tint{background:var(--cream);border-block:1px solid var(--line)}
.prose{font-size:1.05rem}
.prose h2{position:relative;padding-top:.2em}
.prose h2::after{content:"";display:block;width:54px;height:3px;background:var(--gold);border-radius:2px;margin-top:.45em}
.prose img{border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:1.6em 0}
.lead{font-size:1.22rem;line-height:1.6;color:#33433f}

figure{margin:1.8em 0}
figure img{margin:0}
figcaption{font-size:.85rem;color:var(--muted);margin-top:.6em;text-align:center;font-style:italic}

/* pull quote */
.pullquote{font-family:var(--font-display);font-size:1.5rem;line-height:1.4;color:var(--teal);
  border-left:4px solid var(--gold);padding:.2em 0 .2em 1em;margin:1.6em 0;font-weight:500}

/* callout box */
.callout{background:var(--teal-soft);border:1px solid #cfe2e0;border-left:5px solid var(--teal);
  border-radius:12px;padding:18px 22px;margin:1.8em 0}
.callout.gold{background:#faf3e2;border-color:#ecdcb4;border-left-color:var(--gold)}
.callout.tip{background:#eef6ee;border-color:#cfe6cf;border-left-color:#4e9d5b}
.callout h3,.callout h4{margin-top:0}
.callout p:last-child{margin-bottom:0}

/* expert note */
.expert{display:flex;gap:16px;align-items:flex-start;background:var(--cream);border:1px solid var(--line);
  border-radius:14px;padding:18px 20px;margin:1.8em 0;box-shadow:var(--shadow-sm)}
.expert .av{flex:0 0 48px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--gold));
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-size:1.2rem;font-weight:700}
.expert .who{font-size:.82rem;color:var(--muted);margin:0 0 .3em;font-weight:600}
.expert p:last-child{margin-bottom:0}

/* ===================== Tables ===================== */
.table-wrap{overflow-x:auto;margin:1.6em 0;border-radius:12px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;background:var(--cream);font-size:.96rem;min-width:480px}
caption{caption-side:top;text-align:left;font-weight:700;padding:14px 16px 0;color:var(--ink);font-family:var(--font-display);font-size:1.1rem}
th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line)}
thead th{background:var(--teal-deep);color:#fff;font-weight:600;font-size:.9rem}
tbody tr:nth-child(even){background:#fbf8f1}
tbody tr:last-child td{border-bottom:0}
td .yes{color:#2f8a43;font-weight:700}
td .no{color:var(--terracotta);font-weight:700}

/* ===================== Cards / grids ===================== */
.grid{display:grid;gap:24px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .card-img{aspect-ratio:16/10;overflow:hidden}
.card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.05)}
.card .card-body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.card h3{margin:0 0 .4em;font-size:1.2rem}
.card p{color:var(--muted);font-size:.96rem;margin-bottom:1em}
.card .card-link{margin-top:auto;font-weight:700;color:var(--gold-deep);display:inline-flex;align-items:center;gap:6px}
.card .card-link::after{content:"→";transition:transform .15s}
.card:hover .card-link::after{transform:translateX(4px)}

/* feature list with icons */
.features{list-style:none;padding:0;margin:1.4em 0;display:grid;gap:14px}
.features li{display:flex;gap:13px;align-items:flex-start;margin:0}
.features .ic{flex:0 0 34px;width:34px;height:34px;border-radius:9px;background:var(--teal-soft);
  display:flex;align-items:center;justify-content:center;color:var(--teal)}
.features .ic svg{width:18px;height:18px}
.features b{display:block}

/* number stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:1.8em 0;text-align:center}
.stats .stat{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:20px 12px}
.stats .num{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--teal);display:block;line-height:1}
.stats .lbl{font-size:.82rem;color:var(--muted);margin-top:.4em;display:block}

/* ===================== CTA band ===================== */
.cta-band{background:linear-gradient(120deg,var(--teal-deep),var(--teal));color:#fff;border-radius:var(--radius);
  padding:38px 34px;margin:2em 0;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
  box-shadow:var(--shadow)}
.cta-band h2,.cta-band h3{color:#fff;margin:0 0 .25em}
.cta-band p{color:#d7e6e4;margin:0;max-width:60ch}
.cta-band .cta-band-text{flex:1;min-width:260px}

/* ===================== FAQ ===================== */
.faq{margin:1.4em 0}
.faq details{background:var(--cream);border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:600;font-family:var(--font-display);font-size:1.1rem;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--gold-deep);flex:0 0 auto;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-a{padding:0 20px 18px;color:#384743}
.faq .faq-a p:last-child{margin-bottom:0}

/* breadcrumb */
.breadcrumb{font-size:.85rem;color:var(--muted);padding:14px 0}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.breadcrumb li::after{content:"/";margin-left:8px;color:var(--line)}
.breadcrumb li:last-child::after{content:""}
.breadcrumb a{color:var(--muted)}

/* table of contents */
.toc{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin:0 0 2em}
.toc strong{display:block;font-family:var(--font-display);font-size:1.05rem;margin-bottom:.5em}
.toc ol{margin:0;padding-left:1.2em;columns:2;column-gap:30px}
.toc a{color:var(--teal)}
@media(max-width:640px){.toc ol{columns:1}}

/* ===================== Footer ===================== */
.site-footer{background:var(--teal-deep);color:#cfe0de;margin-top:60px;font-size:.92rem}
.footer-top{max-width:var(--maxw);margin:0 auto;padding:50px 22px 30px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.footer-top h4{color:#fff;font-family:var(--font-body);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin:0 0 1em}
.footer-top ul{list-style:none;padding:0;margin:0}
.footer-top li{margin-bottom:.6em}
.footer-top a{color:#cfe0de}
.footer-top a:hover{color:#fff}
.footer-brand img{height:48px;margin-bottom:14px}
.footer-brand p{color:#a8c2bf;font-size:.9rem;max-width:34ch}
.footer-disclaimer{border-top:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.18)}
.footer-disclaimer .container{padding-top:22px;padding-bottom:22px}
.footer-disclaimer p{font-size:.8rem;color:#9fb8b5;margin:0 0 .7em;line-height:1.6}
.footer-disclaimer b{color:#e7c87a}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.8rem;color:#8eaaa7;
  border-top:1px solid rgba(255,255,255,.1);padding-top:16px;margin-top:6px}
.footer-bottom a{color:#9fb8b5}

/* ===================== Misc ===================== */
.text-center{text-align:center}
.mt-0{margin-top:0}
.sponsored-note{font-size:.78rem;color:var(--muted);font-style:italic}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:#000;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

/* ===================== Responsive ===================== */
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:30px;padding:48px 22px 56px}
  .booking-card{max-width:520px}
  .footer-top{grid-template-columns:1fr 1fr}
  .grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body{font-size:16px}
  .hdr-nav{position:fixed;top:0;right:0;height:100vh;width:min(82vw,330px);background:var(--teal-deep);
    flex-direction:column;align-items:stretch;gap:0;padding:78px 26px 26px;transform:translateX(100%);
    transition:transform .25s;box-shadow:-8px 0 30px rgba(0,0,0,.3);overflow-y:auto}
  .hdr-nav.open{transform:translateX(0)}
  .hdr-nav ul{flex-direction:column;gap:0;width:100%}
  .hdr-nav li{border-bottom:1px solid rgba(255,255,255,.1)}
  .hdr-nav a{display:block;padding:14px 0;font-size:1.05rem;border-bottom:0}
  .hdr-nav .cta-btn{margin-top:18px}
  .menu-toggle{display:block;margin-left:auto}
  .lang-switch{margin-top:18px}
  .lang-menu{position:static;max-height:none;box-shadow:none;border:0;background:transparent;padding:0;margin-top:8px}
  .lang-menu.open{display:grid}
  .lang-menu a{color:#cfe0de}
  .lang-menu a:hover{background:rgba(255,255,255,.1)}
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
  .nav-overlay.show{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55}
}
@media(max-width:440px){
  .grid.cols-4,.stats{grid-template-columns:1fr}
  .hero-actions .cta-btn{width:100%}
}
