/* =========================================================
   Il Segreto del Minatore — THEME CSS (WordPress, no builder)
   Palette: antracite • giallo lampada
   Font: DM Sans (body), Unbounded (headings)
   v1.6 — hero con WEBP + fallback PNG
          (resto: menu hover fix, slider, forms, footer nav |, ecc.)
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;700;800&family=Unbounded:wght@700;800&display=swap');

/* ---------- Tokens ---------- */
:root{
  --bg:#0b0c0e; 
  --bg2:#121417; 
  --card:#15181c; 
  --text:#e9eef3;
  --muted:#a9b3bf; 
  --accent:#ffd166; 
  --accent2:#ff9f1c;
  --border:rgba(255,255,255,.08); 
  --soft:rgba(255,255,255,.06); 
  --link:#e9eef3;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;background:#0b0c0e;color:var(--text);
  font:400 16px/1.55 "DM Sans",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue","Noto Sans",Arial,sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;border:0;vertical-align:middle}
a{color:var(--link);text-decoration:none}
a:hover{opacity:.9;text-decoration:underline}
b,strong{font-weight:800}
small{opacity:.9}
#content,.site-main,.entry-content,.hentry{margin:0;padding:0;border:0}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  margin:.4em 0 .3em; line-height:1.15;
  font-family:"Unbounded",system-ui,sans-serif; font-weight:800
}
h1{font-size:clamp(32px,5vw,56px)}
h2{font-size:clamp(22px,3.2vw,32px)}
h3{font-size:clamp(18px,2.4vw,22px)}
h4{font-size:clamp(16px,2vw,20px)}
.subtitle{color:var(--muted);font-size:1.05rem}
.lead{font-size:1.08rem;color:var(--muted)}
.muted{color:var(--muted)}
.badge{
  display:inline-block;padding:6px 12px;border:1px solid rgba(255,255,255,.2);
  border-radius:999px;font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)
}
.notice{
  display:block;background:rgba(255,255,255,.04);
  border-left:4px solid var(--accent);padding:12px;border-radius:10px;color:var(--text)
}

/* ---------- Layout ---------- */
.container{width:min(1100px,92%);margin:0 auto}
.skip{position:absolute;left:-9999px;top:auto}

/* ---------- Header & Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(14,17,20,.92);border-bottom:1px solid var(--soft);
  backdrop-filter:blur(6px) saturate(110%);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{font-family:"Unbounded",system-ui,sans-serif;font-weight:800;color:var(--text);text-decoration:none}

/* Burger */
.nav-toggle{
  display:none;background:transparent;border:1px solid rgba(255,255,255,.2);
  padding:6px 10px;border-radius:8px;color:var(--text)
}

/* Menu base */
.menu{list-style:none;margin:0;padding:0;display:flex;gap:16px;position:relative}
.menu li{position:relative}
.menu a{display:block;color:var(--text);padding:8px 12px;border-radius:10px;white-space:nowrap}
.menu a:hover{background:var(--soft);text-decoration:none}
.menu .current-menu-item > a{outline:2px solid var(--soft)}

/* Caret desktop */
.menu > li.menu-item-has-children > a::after{content:"▾";font-size:.8em;margin-left:.4em;opacity:.8}

/* Submenu desktop */
.menu .sub-menu{
  position:absolute;left:0;top:calc(100% + 10px);min-width:220px;
  background:#0e1114;border:1px solid var(--border);border-radius:12px;
  padding:8px;display:none;flex-direction:column;gap:2px;
  box-shadow:0 20px 40px rgba(0,0,0,.35);opacity:0;transform:translateY(-6px);
  transition:opacity .18s ease, transform .18s ease;
}

/* FIX: no bullets + spacing reset */
.menu .sub-menu,
.menu .sub-menu li{list-style:none !important;margin:0 !important;padding:0 !important}

/* FIX: attacca + z-index */
.menu .sub-menu{z-index:9999;top:100% !important}

/* FIX: hover bridge */
.menu > li{position:relative}
.menu > li > .sub-menu::before{
  content:"";position:absolute;left:0;right:0;top:-10px;height:10px;background:transparent;display:block
}

.menu .sub-menu a{padding:10px 12px;border-radius:8px}
.menu .sub-menu a:hover{background:rgba(255,255,255,.06);text-decoration:none}
.menu > li:hover > .sub-menu,
.menu > li:focus-within > .sub-menu{display:flex;opacity:1;transform:translateY(0)}

/* CTA header */
.cta-header{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#111 !important;box-shadow:0 8px 24px rgba(255,209,102,.18);
  border-radius:14px;padding:10px 14px;font-weight:800;
}

/* Mobile */
@media (max-width:860px){
  .nav-toggle{display:block}
  .menu{
    position:absolute;right:4%;top:60px;background:#0e1114;border:1px solid var(--border);
    padding:12px;border-radius:12px;min-width:260px;display:none;flex-direction:column;gap:4px;
  }
  .menu.show{display:flex}
  .menu .sub-menu{
    position:static;min-width:unset;margin:6px 0 4px 0;
    display:none;opacity:1;transform:none;box-shadow:none;border:1px solid var(--border);
  }
  .menu li.open > .sub-menu{display:flex}
  .menu > li.menu-item-has-children > a::after{content:"";}
  .cta-header{display:none}
}
.submenu-toggle{
  margin-left:6px;background:transparent;border:1px solid rgba(255,255,255,.2);
  color:#e9eef3;border-radius:6px;padding:0 8px;line-height:22px;cursor:pointer;display:none;
}
@media (max-width:860px){ .submenu-toggle{display:inline-block} }

/* ---------- Buttons ---------- */
.btn{appearance:none;border:none;display:inline-block;cursor:pointer;padding:12px 18px;border-radius:14px;font-weight:800}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#111;box-shadow:0 10px 30px rgba(255,209,102,.25)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.14);color:var(--text)}

/* ---------- Cards & Grids ---------- */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:40px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* ---------- Media blocks ---------- */
.media{display:grid;grid-template-columns:1.2fr 1fr;gap:18px;margin:22px 0}
.media .media-img{overflow:hidden;border-radius:14px;border:1px solid var(--border)}
.media .media-img img{display:block;width:100%;height:auto;object-fit:cover}
.media .media-body .badge{margin-bottom:8px}
@media (max-width:960px){ .media{grid-template-columns:1fr} }

/* ---------- Hero ---------- */
.hero{
  border-bottom:none;position:relative;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.75)),
    image-set(
      url("../img/hero-minatore-1920.webp") type("image/webp") 1x,
      url("../img/hero-minatore-1920.png") type("image/png") 1x
    )
    center/cover no-repeat;
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:72px;
  background:linear-gradient(to bottom, rgba(0,0,0,0), var(--bg));pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;padding:76px 0}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px}
.kpi{background:rgba(255,255,255,.05);border:1px solid var(--border);padding:12px;border-radius:12px;text-align:center}
.kpi b{display:block;font-size:1.1rem}

/* ---------- Tri-cards home ---------- */
.container.grid-3.info{max-width:980px;margin-left:auto;margin-right:auto;margin-bottom:56px}
.info .card{text-align:left}

/* ---------- Subhead ---------- */
.subhead{background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,.7));padding:40px 0;border-bottom:1px solid var(--soft)}

/* ---------- Prose ---------- */
.prose{padding:30px 0}
.prose p{margin:.6em 0}
.prose ul,.prose ol{padding-left:1.2em}
.prose .callout{background:rgba(255,255,255,.04);border-left:4px solid var(--accent);padding:14px;border-radius:10px;margin:12px 0}
.steps{counter-reset:step;list-style:none;padding:0;margin:0}
.steps>li{background:rgba(255,255,255,.04);padding:16px 16px 10px;border-radius:12px;border:1px solid var(--border);margin:0 0 12px}
.steps>li h3:before{counter-increment:step;content:counter(step) ". ";color:var(--accent);margin-right:.25em}

/* ---------- Mappa placeholder ---------- */
.map-placeholder{
  aspect-ratio:16/9;display:grid;place-items:center;
  background:linear-gradient(135deg,#0f1114,#0b0c0e);
  border:1px dashed rgba(255,255,255,.25);border-radius:12px;color:var(--muted)
}

/* ---------- Forms ---------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .full{grid-column:1 / -1}
.form input,.form select,.form textarea{
  width:100%;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f1114;color:var(--text)
}
.form .actions{display:flex;align-items:center;gap:14px}
.checkbox{display:flex;gap:8px;align-items:center}

/* WPForms skin */
.wpforms-container .wpforms-field input,
.wpforms-container .wpforms-field select,
.wpforms-container .wpforms-field textarea{
  width:100%;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0f1114;color:var(--text)
}
.wpforms-submit{
  background:linear-gradient(135deg,var(--accent),var(--accent2)) !important;
  color:#111 !important;border:none !important;border-radius:14px !important;
  padding:12px 18px !important;font-weight:800 !important
}

/* ---------- FAQ ---------- */
.faq details{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin:0 0 12px}
.faq summary{cursor:pointer;font-weight:700;list-style:none}
.faq summary::-webkit-details-marker{display:none}

/* ---------- Slider ---------- */
.min-slider{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--border);background:#0f1114}
.min-slider .track{display:flex;transition:transform .35s ease;will-change:transform}
.min-slide{flex:0 0 100%;position:relative}
.min-slide img{display:block;width:100%;height:460px;object-fit:cover}
.min-caption{
  position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.65));
  padding:16px;color:#f5f7fa
}
.min-arrow{
  position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);
  border:1px solid var(--border);backdrop-filter:blur(4px);width:40px;height:40px;border-radius:999px;display:grid;place-items:center;cursor:pointer
}
.min-prev{left:10px} .min-next{right:10px}
.min-dots{position:absolute;left:0;right:0;bottom:10px;display:flex;justify-content:center;gap:8px}
.min-dot{width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.4);border:1px solid var(--border);cursor:pointer}
.min-dot.active{background:var(--accent)}

/* ---------- Footer + Widget Columns ---------- */
.site-footer{border-top:1px solid var(--soft);padding:32px 0;background:#0f1114;margin-top:24px}
.footer-widgets{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:14px
}
.footer-col{min-width:0}
.widget{
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
}
.widget-title{
  margin:.2em 0 .4em;
  font-size:1rem;
  font-family:"Unbounded",system-ui,sans-serif;
  font-weight:800
}
.widget ul{list-style:none;margin:0;padding:0}
.widget ul li{margin:.45em 0}
.widget a{color:var(--text);text-decoration:none}
.widget a:hover{text-decoration:underline}
.footer-grid{
  display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap
}

/* ---------- Footer Nav — horizontal with separators ---------- */
.footer-nav ul{
  margin:0; padding:0;
  list-style:none;
  display:flex; align-items:center; flex-wrap:wrap;
  gap:10px;
}
.footer-nav li{margin:0; padding:0; list-style:none}
.footer-nav li + li{
  position:relative; padding-left:16px;
}
.footer-nav li + li::before{
  content:"|";
  position:absolute; left:0; top:50%; transform:translateY(-50%);
  color:var(--muted); opacity:.8;
}
.footer-nav a{
  color:var(--text); text-decoration:none; 
}
.footer-nav a:hover{
  text-decoration:underline;
}

/* Responsive footer */
@media (max-width:960px){
  .footer-widgets{grid-template-columns:1fr}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;padding:56px 0}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .min-slide img{height:280px}
}

/* ---------- CTA ---------- */
.cta{padding:40px 0}
.cta .cta-box{
  display:flex;gap:20px;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg, rgba(255,209,102,.08), rgba(255,255,255,.02));
  border:1px solid var(--border);padding:18px 20px;border-radius:16px
}

/* ---------- Utilities ---------- */
.inline{color:var(--accent);text-decoration:none}
.inline:hover{text-decoration:underline}
.card a.inline:hover{text-decoration:underline}
.min-section{border-top:1px solid rgba(255,255,255,.06)}

/* Page title helper
.page-id-XX .entry-title{display:none;}
*/
