:root{
  --bg:#fbf7f0; --card:#fff; --ink:#2a2320; --muted:#8a7f76;
  --brand:#c0392b; --brand-dark:#8e2a20; --accent:#e1a948; --line:#ece3d7;
  --radius:14px; --shadow:0 6px 22px rgba(70,50,30,.08);
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}
h1,h2,h3,h4{font-family:Fraunces,Georgia,serif;line-height:1.15;margin:.2em 0 .5em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;height:68px}
.logo{font-family:Fraunces,serif;font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:8px;white-space:nowrap}
.logo span strong{color:var(--brand)}
.main-nav{display:flex;gap:22px;margin-left:8px;font-weight:500}
.main-nav a:hover{color:var(--brand)}
.header-search{margin-left:auto;display:flex;background:var(--card);border:1px solid var(--line);border-radius:30px;overflow:hidden}
.header-search input{border:0;padding:9px 16px;background:transparent;outline:none;min-width:220px;font-size:.92rem}
.header-search button{border:0;background:transparent;padding:0 14px;cursor:pointer;font-size:1rem}

/* Hero */
.hero{background:linear-gradient(135deg,#7a1f17,#c0392b 60%,#e1a948);color:#fff;padding:72px 0 84px;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);color:#fff;margin-bottom:.2em}
.hero p{font-size:1.15rem;opacity:.95;max-width:620px;margin:0 auto 28px}
.hero-search{display:flex;max-width:560px;margin:0 auto;background:#fff;border-radius:40px;padding:6px;box-shadow:var(--shadow)}
.hero-search input{flex:1;border:0;padding:14px 20px;font-size:1rem;border-radius:40px;outline:none;color:var(--ink)}
.hero-search button{border:0;background:var(--brand);color:#fff;padding:0 26px;border-radius:40px;font-weight:600;cursor:pointer}
.hero-search button:hover{background:var(--brand-dark)}

/* Sezioni */
section.block{padding:54px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:10px}
.section-head h2{font-size:1.9rem;margin:0}
.section-head a{color:var(--brand);font-weight:600}

/* Griglie */
.grid{display:grid;gap:22px}
.grid.cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.grid.cities{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.grid.cuisines{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}

/* Card ristorante */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(70,50,30,.14)}
.card-cover{aspect-ratio:16/10;background:linear-gradient(135deg,#e9ddc9,#d9c4a3);display:flex;align-items:center;justify-content:center;font-size:2.6rem;position:relative}
.card-cover img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;top:10px;left:10px;background:var(--accent);color:#3a2a00;font-size:.72rem;font-weight:700;padding:4px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.card-body{padding:15px 16px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.card-body h3{margin:0;font-size:1.18rem}
.card-meta{display:flex;align-items:center;gap:8px;font-size:.86rem;color:var(--muted);flex-wrap:wrap}
.tag{display:inline-block;background:#f3ece0;color:#7a6a55;font-size:.74rem;padding:3px 9px;border-radius:20px}
.rating{color:var(--accent);font-size:.95rem;letter-spacing:1px}
.card-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:8px}
.price{font-weight:700;color:var(--ink)}

/* City / cuisine tile */
.tile{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:var(--shadow);transition:transform .18s}
.tile:hover{transform:translateY(-3px);border-color:var(--accent)}
.tile .big{font-size:2rem}
.tile h3{margin:.4em 0 .1em;font-size:1.15rem}
.tile .count{color:var(--brand);font-weight:600;font-size:.85rem}

/* Page header */
.page-head{background:linear-gradient(135deg,#3a241f,#7a1f17);color:#fff;padding:46px 0}
.page-head h1{color:#fff;margin:0 0 6px;font-size:2.3rem}
.page-head .breadcrumb{font-size:.85rem;opacity:.8}
.page-head .breadcrumb a{text-decoration:underline}

/* Filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}
.chip{background:var(--card);border:1px solid var(--line);padding:7px 15px;border-radius:30px;font-size:.88rem;cursor:pointer;transition:.15s}
.chip:hover,.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* Detail */
.detail-hero{aspect-ratio:21/8;background:linear-gradient(135deg,#e9ddc9,#d9c4a3);display:flex;align-items:center;justify-content:center;font-size:4rem;border-radius:var(--radius);overflow:hidden;margin:24px 0}
.detail-hero img{width:100%;height:100%;object-fit:cover}
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:34px;align-items:start}
.menu-cat{margin-bottom:26px}
.menu-cat h3{border-bottom:2px solid var(--accent);padding-bottom:6px;display:inline-block}
.menu-item{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px dashed var(--line)}
.menu-item .mi-name{font-weight:600}
.menu-item .mi-price{font-weight:700;white-space:nowrap;color:var(--brand)}
.diet{font-size:.75rem}
.sidebar-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:sticky;top:88px}
.info-row{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.info-row:last-child{border:0}
.info-row .ico{width:22px}

/* Forms */
.form-group{margin-bottom:14px}
label{display:block;font-size:.85rem;font-weight:600;margin-bottom:5px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;outline:none}
input:focus,select,textarea:focus{border-color:var(--brand)}
.btn{display:inline-block;background:var(--brand);color:#fff;border:0;padding:12px 22px;border-radius:30px;font-weight:600;cursor:pointer;text-align:center;transition:.15s}
.btn:hover{background:var(--brand-dark)}
.btn--block{width:100%}
.btn--ghost{background:transparent;color:var(--brand);border:1px solid var(--brand)}
.btn--ghost:hover{background:var(--brand);color:#fff}
.form-row{display:flex;gap:12px}
.form-row>*{flex:1}

/* Reviews */
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:12px}
.review-head{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted)}
.review .author{font-weight:600;color:var(--ink)}

/* Misc */
.flash{background:#e6f6e9;border:1px solid #aedcb7;color:#226633;padding:12px 16px;border-radius:9px;margin:18px 0}
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.site-footer{background:#2a2320;color:#d8cfc5;margin-top:60px;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:28px}
.footer-grid h4{color:#fff;font-size:1rem;margin:0 0 10px}
.footer-grid a{display:block;color:#c9bdb1;padding:3px 0;font-size:.9rem}
.footer-grid a:hover{color:var(--accent)}
.logo--footer{color:#fff;font-size:1.15rem}
.logo--footer strong{color:var(--accent)}
.copyright{margin-top:30px;padding-top:18px;border-top:1px solid #443c35;font-size:.82rem;color:#9a8e82}

/* Badge varianti */
.badge--sponsor{background:linear-gradient(135deg,#e1a948,#c0392b);color:#fff}
.badge--open{position:absolute;top:10px;right:10px;left:auto;background:#226633;color:#fff}

/* Icone servizi nelle card */
.feature-icons{display:flex;gap:6px;font-size:.95rem;opacity:.85}
.feature-list{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.feature-pill{background:#f3ece0;color:#6a5a45;font-size:.82rem;padding:5px 12px;border-radius:20px}

/* Barra filtri */
.filterbar{margin:18px 0}
.filterbar-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.fdrop{position:relative}
.fdrop>summary{list-style:none;cursor:pointer;background:var(--card);border:1px solid var(--line);padding:8px 15px;border-radius:30px;font-size:.88rem}
.fdrop>summary::-webkit-details-marker{display:none}
.fdrop>summary::after{content:" ▾"}
.fcount{background:var(--brand);color:#fff;border-radius:20px;padding:0 7px;font-size:.72rem;margin-left:4px}
.fdrop-body{position:absolute;z-index:20;top:110%;left:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;min-width:200px;display:flex;flex-direction:column;gap:8px}
.fdrop-body label{font-weight:400;display:flex;align-items:center;gap:7px;margin:0}
.fdrop-body input{width:auto}
.ftoggle{display:flex;align-items:center;gap:6px;font-weight:500;font-size:.88rem;background:var(--card);border:1px solid var(--line);padding:8px 14px;border-radius:30px}
.ftoggle input{width:auto}
.filterbar select{width:auto;border-radius:30px;padding:8px 14px}

/* Mappa */
.rest-map{height:360px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);margin:8px 0 22px;z-index:1}

/* Preferiti (cuore) */
.card-wrap{position:relative}
.fav-btn{position:absolute;top:10px;right:10px;z-index:5;border:0;background:rgba(255,255,255,.9);width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1.1rem;line-height:1;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:transform .12s}
.fav-btn:hover{transform:scale(1.12)}
.fav-inline{position:static;box-shadow:none;background:transparent;width:auto;height:auto;vertical-align:middle}

/* Recensioni verificate / risposta */
.verified-badge{display:inline-block;background:#e6f6e9;color:#226633;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:20px}
.review-reply{margin-top:10px;padding:10px 14px;background:#f5ede1;border-radius:10px;border-left:3px solid var(--accent)}
.review-reply strong{font-size:.85rem;color:#7a6a55}

/* Eventi nella scheda */
.event-row{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px dashed var(--line)}
.event-row .event-date{flex:0 0 60px;text-align:center;font-weight:700;color:var(--brand);font-size:1.05rem}

/* Newsletter footer */
.nl-form{display:flex;gap:6px}
.nl-form input{flex:1;padding:9px 12px;border:1px solid #443c35;border-radius:8px;background:#3a322c;color:#fff;font:inherit}
.nl-form .btn{padding:9px 14px}

/* Allergeni / segnala / foto recensioni / lingua */
.allergens-line{font-size:.78rem;color:#9a7b3a;margin-top:3px}
.report-link{display:inline-block;margin-top:8px;font-size:.78rem;color:var(--muted);text-decoration:underline}
.report-link:hover{color:var(--brand)}
.review-photos{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.review-photos img{width:90px;height:70px;object-fit:cover;border-radius:8px}
.lang-switch{font-size:.82rem;font-weight:600;border:1px solid var(--line);border-radius:20px;padding:4px 10px}
.lang-switch:hover{border-color:var(--brand);color:var(--brand)}

/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;background:#2a2320;color:#eadfd3;box-shadow:0 -4px 20px rgba(0,0,0,.2)}
.cookie-inner{display:flex;align-items:center;gap:18px;padding:14px 20px;flex-wrap:wrap}
.cookie-inner p{margin:0;font-size:.9rem;flex:1;min-width:240px}
.cookie-inner a{color:var(--accent);text-decoration:underline}
.cookie-btns{display:flex;gap:10px}

/* Paginazione */
.pager{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:30px 0 0}
.pager a,.pager span{padding:8px 14px;border-radius:8px;border:1px solid var(--line);background:var(--card);font-size:.9rem}
.pager a:hover{border-color:var(--brand);color:var(--brand)}
.pager .current{background:var(--brand);color:#fff;border-color:var(--brand)}
.pager .disabled{opacity:.4}

/* Galleria foto scheda */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:18px 0}
.gallery img{width:100%;height:120px;object-fit:cover;border-radius:10px;transition:transform .15s}
.gallery a:hover img{transform:scale(1.03)}

/* Corpo articolo blog */
.article-body{font-size:1.08rem;line-height:1.8}
.article-body p{margin:0 0 1em}

/* Tabella orari (form) */
.hours-table{border-collapse:collapse}
.hours-table td,.hours-table th{padding:3px 5px}
.hours-table input[type=time]{width:120px}

@media(max-width:860px){
  .detail-grid{grid-template-columns:1fr}
  .sidebar-card{position:static}
  .main-nav,.header-search{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
