/* Terme di Diocleziano — unofficial guide site */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;color:#1f1a14;background:#fbf8f3;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:#8a3a1a;text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:Georgia,"Times New Roman",serif;line-height:1.25;color:#2a1c10;margin:1.6em 0 .6em}
h1{font-size:clamp(1.8rem,4.2vw,2.6rem)}
h2{font-size:clamp(1.4rem,3vw,1.9rem);border-bottom:2px solid #e6d9c2;padding-bottom:.3em}
h3{font-size:clamp(1.15rem,2.2vw,1.35rem)}
p,li{font-size:1.02rem}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.container-narrow{max-width:860px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{background:#fff;border-bottom:1px solid #e8e0d0;position:sticky;top:0;z-index:50;box-shadow:0 1px 6px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;max-width:1180px;margin:0 auto;gap:16px}
.logo{display:flex;align-items:center;gap:10px;font-weight:700;color:#2a1c10;font-family:Georgia,serif;font-size:1.05rem}
.logo img{width:38px;height:38px}
.logo span small{display:block;font-size:.7rem;font-weight:400;color:#7a6a55;font-family:inherit}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;padding:4px 8px;color:#2a1c10}
.main-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.main-nav a{color:#2a1c10;padding:8px 12px;border-radius:6px;font-size:.95rem;font-weight:500}
.main-nav a:hover{background:#f3ead9;text-decoration:none}
.main-nav a.active{color:#8a3a1a}
.lang-switch{position:relative}
.lang-switch summary{list-style:none;cursor:pointer;padding:6px 12px;border:1px solid #d8caa9;border-radius:6px;font-size:.88rem;background:#fbf8f3}
.lang-switch summary::-webkit-details-marker{display:none}
.lang-list{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e0d3b8;border-radius:8px;padding:8px;min-width:170px;max-height:340px;overflow-y:auto;box-shadow:0 8px 20px rgba(0,0,0,.08);display:grid;grid-template-columns:1fr 1fr;gap:2px;z-index:60}
.lang-list a{display:block;padding:6px 10px;font-size:.85rem;color:#2a1c10;border-radius:4px}
.lang-list a:hover{background:#f3ead9;text-decoration:none}
.btn{display:inline-block;background:#c0392b;color:#fff !important;padding:10px 18px;border-radius:6px;font-weight:600;text-decoration:none;font-size:.95rem;transition:background .2s;border:0;cursor:pointer}
.btn:hover{background:#a02d20;text-decoration:none}
.btn-lg{padding:14px 26px;font-size:1.05rem}
.btn-outline{background:transparent;color:#c0392b !important;border:2px solid #c0392b}
.btn-outline:hover{background:#c0392b;color:#fff !important}

/* Hero */
.hero{position:relative;color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(20,12,4,.78),rgba(60,30,12,.55)),url("/assets/images/terme-diocleziano-hero.webp") center/cover no-repeat;z-index:-1}
.hero-inner{padding:70px 20px 50px;max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero h1{color:#fff;margin-top:0}
.hero p.lead{font-size:1.12rem;max-width:560px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.hero-disclaimer{margin-top:14px;font-size:.78rem;color:#f2e2c4;opacity:.85;cursor:help;display:inline-block;border-bottom:1px dotted #f2e2c4}
.hero-disclaimer:hover{opacity:1}
.hero-widget{background:rgba(255,255,255,.97);color:#1f1a14;padding:18px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.hero-widget h3{margin:0 0 10px;color:#2a1c10;font-size:1.1rem}

/* Sections */
section{padding:50px 0}
section.alt{background:#f3ead9}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid #ebe0c8;border-radius:10px;padding:22px;box-shadow:0 2px 6px rgba(0,0,0,.03);transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
.card h3{margin-top:0}
.card .icon{font-size:1.8rem;display:block;margin-bottom:6px}

/* Quick summary table */
.summary-table{width:100%;border-collapse:collapse;margin:18px 0;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 6px rgba(0,0,0,.05)}
.summary-table th,.summary-table td{padding:12px 14px;border-bottom:1px solid #ebe0c8;text-align:left;vertical-align:top}
.summary-table th{background:#f3ead9;font-weight:600;width:38%;color:#2a1c10}
.summary-table tr:last-child td,.summary-table tr:last-child th{border-bottom:0}

/* Callout */
.callout{background:#fff5e0;border-left:4px solid #c0392b;padding:14px 18px;margin:22px 0;border-radius:6px;font-size:.97rem}
.callout strong{color:#8a3a1a}
.tip{background:#e8f4e2;border-left-color:#3b7a2a}
.tip strong{color:#3b7a2a}

/* FAQ */
.faq details{background:#fff;border:1px solid #ebe0c8;border-radius:8px;margin-bottom:10px;padding:14px 18px}
.faq summary{cursor:pointer;font-weight:600;color:#2a1c10}
.faq details[open]{box-shadow:0 4px 14px rgba(0,0,0,.05)}
.faq details p{margin:10px 0 0}

/* Breadcrumbs */
.breadcrumbs{font-size:.85rem;color:#7a6a55;padding:14px 20px;max-width:1180px;margin:0 auto}
.breadcrumbs a{color:#7a6a55}
.breadcrumbs span{color:#2a1c10}

/* Footer */
.site-footer{background:#1f1a14;color:#d8caa9;padding:50px 0 24px;margin-top:60px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;max-width:1180px;margin:0 auto;padding:0 20px}
.site-footer h4{color:#fff;margin:0 0 12px;font-size:1rem}
.site-footer a{color:#d8caa9}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:8px}
.disclaimer{margin-top:30px;padding:20px;background:#2a1c10;border-radius:8px;font-size:.82rem;color:#bfa980;max-width:1180px;margin-left:auto;margin-right:auto}
.disclaimer strong{color:#fff}
.copyright{text-align:center;margin-top:24px;padding-top:18px;border-top:1px solid #3a2e1f;font-size:.82rem;color:#a89572}

/* Image rows */
figure{margin:24px 0}
figure img{border-radius:10px;width:100%}
figcaption{font-size:.85rem;color:#7a6a55;margin-top:6px;text-align:center;font-style:italic}

/* GYG widgets */
[data-gyg-widget]{margin:20px 0;display:block}

/* Forms */
.form-group{margin-bottom:16px}
.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#2a1c10}
.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d8caa9;border-radius:6px;font-size:1rem;font-family:inherit;background:#fff}
.form-group textarea{min-height:140px;resize:vertical}

/* Comparison */
.compare{width:100%;border-collapse:collapse;margin:20px 0;background:#fff;font-size:.95rem}
.compare th,.compare td{padding:12px;border:1px solid #ebe0c8;text-align:left}
.compare th{background:#2a1c10;color:#fff}
.compare tr:nth-child(even) td{background:#fbf8f3}

/* Responsive */
@media (max-width: 880px){
  .hero-inner{grid-template-columns:1fr;padding:50px 20px 30px;gap:24px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-toggle{display:block}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:10px;border-top:1px solid #e8e0d0;box-shadow:0 6px 14px rgba(0,0,0,.08)}
  .main-nav.open{display:flex}
  .main-nav a{padding:12px 16px;border-radius:0;border-bottom:1px solid #f3ead9}
  .main-nav .btn{margin-top:6px}
  .header-inner{position:relative;flex-wrap:wrap}
  .lang-list{grid-template-columns:1fr}
}
@media (max-width: 480px){
  .footer-grid{grid-template-columns:1fr}
  .hero-inner{padding:40px 16px 24px}
  h1{font-size:1.7rem}
  .btn-lg{padding:12px 20px}
}
