/*
Theme Name: LB Supporto Enti Pubblici
Theme URI: https://lbsupportoentipubblici.com
Author: Luca Biondi
Description: Tema professionale per LB Supporto Enti Pubblici
Version: 4.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: Proprietary
Text Domain: lb-supporto
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0c1f3a;
  --navy-mid:#1a3456;
  --gold:#b8962e;
  --black:#0a0a0a;
  --white:#ffffff;
  --off:#f5f3ef;
  --light:#eeebe4;
  --mid:#7a7a7a;
  --border:#d8d4cc;
  --text:#1a1a1a;
}
html{scroll-behavior:smooth}
body{
  font-family:'Barlow',sans-serif;
  font-weight:400;line-height:1.6;
  color:var(--text);background:var(--white);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

.wrap{max-width:1280px;margin:0 auto;padding:0 3rem}
@media(max-width:768px){.wrap{padding:0 1.4rem}}

/* ─── HEADER ──────────────────────────────────────────────── */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--white);
  border-bottom:1px solid var(--border);
}
.nav-wrap{
  display:flex;justify-content:space-between;align-items:center;
  height:80px;max-width:1280px;margin:0 auto;padding:0 3rem;
}
.site-logo img{height:60px;width:auto}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mid);font-weight:400;transition:color .2s;
}
.nav-links a:hover{color:var(--navy)}
.nav-contact{
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy);font-weight:600;
  border-bottom:1px solid var(--navy);padding-bottom:1px;
  transition:color .2s,border-color .2s;
}
.nav-contact:hover{color:var(--gold);border-color:var(--gold)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--navy)}

/* ─── HERO — editoriale, testo protagonista ───────────────── */
.hero{
  padding-top:80px;
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:var(--white);
  position:relative;overflow:hidden;
}

/* Linea oro verticale sinistra */
.hero::before{
  content:'';
  position:absolute;left:3rem;top:0;bottom:0;
  width:1px;background:var(--gold);opacity:.35;
}

.hero-top{
  flex:1;display:flex;align-items:flex-end;
  padding:5rem 3rem 3rem 6rem;
  max-width:1280px;margin:0 auto;width:100%;
}

/* Titolo enorme che occupa tutta la larghezza */
.hero-headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(3.5rem,7vw,7rem);
  line-height:.95;
  color:var(--navy);
  font-weight:700;
  letter-spacing:-.02em;
  max-width:900px;
}
.hero-headline em{
  font-style:italic;font-weight:400;
  color:var(--navy-mid);
}

.hero-bottom{
  border-top:1px solid var(--border);
  padding:2rem 3rem 2rem 6rem;
  max-width:1280px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr 1fr auto;
  gap:3rem;align-items:center;
}
.hero-claim{
  font-size:.9rem;line-height:1.85;
  color:var(--mid);font-weight:300;
  grid-column:1/3;
  max-width:520px;
}
.hero-claim strong{color:var(--navy);font-weight:500}
.hero-ref{
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mid);font-weight:400;
  border-left:1px solid var(--border);
  padding-left:2rem;
}
.hero-ref span{display:block;color:var(--navy);font-weight:600;font-size:.8rem;letter-spacing:0;text-transform:none;margin-top:.2rem}
.hero-cta{
  background:var(--navy);color:var(--white);
  padding:1rem 2.5rem;
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  font-family:'Barlow',sans-serif;transition:background .2s;
  white-space:nowrap;
}
.hero-cta:hover{background:var(--navy-mid)}

/* ─── STRIP KEYWORDS ──────────────────────────────────────── */
.keywords{
  background:var(--off);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:.95rem 3rem;
  display:flex;gap:0;overflow:hidden;
}
.kw{
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--mid);white-space:nowrap;padding:0 1.8rem;
  border-right:1px solid var(--border);
}
.kw:first-child{padding-left:0}
.kw:last-child{border-right:none}

/* ─── INTRO — testo editoriale largo ─────────────────────── */
.intro{
  padding:7rem 3rem 7rem 6rem;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:200px 1fr;
  gap:6rem;align-items:start;
  border-bottom:1px solid var(--border);
}
.intro-label{
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  padding-top:.5rem;
  position:sticky;top:100px;
}
.intro-text{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.3rem,2vw,1.75rem);
  line-height:1.7;color:var(--navy);font-weight:400;
}
.intro-text strong{font-weight:700}
.intro-text em{font-style:italic}

/* ─── SERVIZI — lista pulita, niente card ─────────────────── */
.servizi{
  padding:6rem 3rem 6rem 6rem;
  max-width:1280px;margin:0 auto;
  border-bottom:1px solid var(--border);
}
.sec-label{
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:3rem;display:block;
}
.svc-list-wrap{display:flex;flex-direction:column}
.svc-item{
  display:grid;grid-template-columns:60px 1fr 1fr 40px;
  gap:3rem;align-items:start;
  padding:2.5rem 0;
  border-top:1px solid var(--border);
  transition:background .15s;
  cursor:default;
}
.svc-item:hover{background:var(--off);padding-left:1rem;padding-right:1rem;margin:0 -1rem}
.svc-item:hover .svc-n{color:var(--gold)}
.svc-item:hover .svc-arr{color:var(--navy);transform:translateX(4px)}
.svc-n{
  font-size:.72rem;letter-spacing:.1em;color:var(--border);
  font-weight:600;padding-top:.2rem;transition:color .2s;
}
.svc-name{
  font-family:'Playfair Display',serif;
  font-size:1.15rem;color:var(--navy);font-weight:700;
  margin-bottom:.6rem;line-height:1.2;
}
.svc-badge{
  display:inline-block;font-size:.52rem;letter-spacing:.1em;
  text-transform:uppercase;background:var(--gold);color:var(--white);
  padding:.15rem .6rem;margin-left:.7rem;vertical-align:middle;
}
.svc-desc{
  font-size:.85rem;line-height:1.85;color:var(--mid);font-weight:300;
}
.svc-points{
  display:flex;flex-direction:column;gap:.4rem;
}
.svc-points li{
  font-size:.78rem;color:var(--mid);font-weight:300;
  padding-left:1rem;position:relative;line-height:1.55;
}
.svc-points li::before{
  content:'—';position:absolute;left:0;
  color:var(--gold);font-size:.65rem;
}
.svc-arr{
  font-size:1rem;color:var(--border);
  padding-top:.3rem;transition:all .2s;
  text-align:right;
}

/* ─── APPROCCIO — 5 passi orizzontali minimali ────────────── */
.approccio{
  padding:6rem 3rem 6rem 6rem;
  max-width:1280px;margin:0 auto;
  border-bottom:1px solid var(--border);
  background:var(--white);
}
.steps-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:0;margin-top:3rem;
}
.step-item{
  padding-right:2.5rem;
  border-right:1px solid var(--border);
}
.step-item:last-child{border-right:none;padding-right:0}
.step-item:not(:first-child){padding-left:2.5rem}
.step-n{
  font-size:.62rem;letter-spacing:.16em;color:var(--gold);
  font-weight:500;margin-bottom:1.2rem;display:block;
}
.step-title{
  font-family:'Playfair Display',serif;
  font-size:1.05rem;color:var(--navy);font-weight:700;
  margin-bottom:.7rem;line-height:1.2;
}
.step-desc{
  font-size:.78rem;line-height:1.75;color:var(--mid);font-weight:300;
}

/* ─── PIATTAFORME ─────────────────────────────────────────── */
.platforms{
  padding:2.5rem 3rem 2.5rem 6rem;
  max-width:1280px;margin:0 auto;
  border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:180px 1fr;gap:4rem;align-items:center;
}
.platforms-label{
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mid);
}
.platforms-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.ptag{
  font-size:.68rem;letter-spacing:.06em;
  border:1px solid var(--border);color:var(--navy);
  padding:.28rem .9rem;font-weight:400;
  transition:all .2s;
}
.ptag:hover{border-color:var(--navy);background:var(--navy);color:var(--white)}

/* ─── CHI SONO — foto discreta + testo ───────────────────── */
.chi-sono{
  padding:7rem 3rem 7rem 6rem;
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 340px;
  gap:6rem;align-items:start;
  border-bottom:1px solid var(--border);
}
.chi-left{}
.chi-label{
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:2rem;display:block;
}
.chi-headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.8rem,3vw,2.6rem);
  color:var(--navy);font-weight:700;
  line-height:1.1;margin-bottom:2rem;
}
.chi-body{
  font-size:.92rem;line-height:1.95;
  color:var(--mid);font-weight:300;margin-bottom:2.5rem;
  max-width:600px;
}
.chi-items{display:flex;flex-direction:column;gap:.9rem;margin-bottom:2.5rem}
.chi-item{
  display:flex;gap:1.2rem;align-items:flex-start;
  padding:.9rem 0;border-top:1px solid var(--border);
}
.chi-item-key{
  font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mid);font-weight:400;min-width:140px;flex-shrink:0;
  padding-top:.15rem;
}
.chi-item-val{
  font-size:.84rem;color:var(--navy);font-weight:400;line-height:1.6;
}
.chi-enti-title{
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.2rem;display:block;
}
.chi-ente{padding:.75rem 0;border-top:1px solid var(--border)}
.chi-ente:first-of-type{border-top:none;padding-top:0}
.chi-ente-n{font-size:.82rem;color:var(--navy);font-weight:600}
.chi-ente-d{font-size:.74rem;color:var(--mid);font-weight:300;margin-top:.15rem;line-height:1.5}

.chi-right{display:flex;flex-direction:column;gap:1.5rem;padding-top:.5rem}
/* Foto piccola e discreta */
.chi-photo{
  width:100%;
  border:1px solid var(--border);
  overflow:hidden;
}
.chi-photo img{
  width:100%;
  object-fit:cover;object-position:top center;
  filter:grayscale(20%);
  transition:filter .3s;
  max-height:360px;
}
.chi-photo:hover img{filter:grayscale(0%)}
.chi-photo-cap{
  padding:.75rem 1rem;
  border-top:1px solid var(--border);
  background:var(--off);
}
.chi-photo-cap-name{
  font-size:.78rem;color:var(--navy);font-weight:600;
}
.chi-photo-cap-role{
  font-size:.65rem;color:var(--mid);font-weight:300;margin-top:.1rem;
}
/* Info laterali */
.chi-info-block{
  border:1px solid var(--border);
  padding:1.4rem;background:var(--off);
}
.chi-info-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:.6rem 0;border-bottom:1px solid var(--border);
}
.chi-info-row:last-child{border-bottom:none;padding-bottom:0}
.chi-info-k{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mid)}
.chi-info-v{font-size:.82rem;color:var(--navy);font-weight:600}

/* ─── CONTATTI ────────────────────────────────────────────── */
.contatti{
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--navy);
}
.cont-left{
  padding:7rem 4rem 7rem 6rem;
  position:relative;overflow:hidden;
  border-right:1px solid rgba(255,255,255,.08);
}
.cont-left::before{
  content:'';position:absolute;left:3rem;top:0;bottom:0;
  width:1px;background:var(--gold);opacity:.2;
}
.cont-eyebrow{
  font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(201,168,76,.7);font-weight:400;
  display:block;margin-bottom:2rem;
}
.cont-headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.8rem,3vw,2.6rem);
  color:var(--white);font-weight:700;
  line-height:1.1;margin-bottom:1.5rem;
}
.cont-sub{
  font-size:.9rem;line-height:1.9;
  color:rgba(255,255,255,.35);font-weight:300;
  max-width:380px;margin-bottom:3.5rem;
}
.cont-data{display:flex;flex-direction:column;gap:1.5rem}
.cont-row{display:flex;flex-direction:column;gap:.2rem}
.cont-k{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,168,76,.7)}
.cont-v{font-size:.88rem;color:rgba(255,255,255,.55);font-weight:300}
.cont-v a{color:rgba(255,255,255,.55);transition:color .2s}
.cont-v a:hover{color:var(--white)}

.cont-right{padding:7rem 4rem}
.cont-form-title{
  font-family:'Playfair Display',serif;
  font-size:1.3rem;color:var(--white);font-weight:700;
  margin-bottom:2.5rem;
}
.f{margin-bottom:1.4rem}
.f label{
  font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.35);display:block;margin-bottom:.5rem;
}
.f input,.f textarea,.f select{
  width:100%;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  color:var(--white);padding:.82rem 1rem;
  font-size:.86rem;font-family:'Barlow',sans-serif;
  font-weight:300;outline:none;-webkit-appearance:none;
  transition:border-color .2s;
}
.f input::placeholder,.f textarea::placeholder{color:rgba(255,255,255,.2)}
.f input:focus,.f textarea:focus,.f select:focus{border-color:rgba(255,255,255,.35)}
.f textarea{height:90px;resize:none}
.f select option{background:var(--navy);color:var(--white)}
.f-btn{
  width:100%;background:var(--white);color:var(--navy);
  padding:1rem;font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:700;
  font-family:'Barlow',sans-serif;transition:background .2s,color .2s;
}
.f-btn:hover{background:var(--off)}
.f-gdpr{font-size:.6rem;color:rgba(255,255,255,.2);margin-top:.8rem;line-height:1.6}
.f-ok{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);padding:1rem;font-size:.84rem;color:rgba(255,255,255,.7);margin-bottom:1.5rem}

/* ─── FOOTER ──────────────────────────────────────────────── */
footer{
  background:var(--black);padding:2.5rem 3rem 2.5rem 6rem;
  display:flex;justify-content:space-between;align-items:center;
  gap:2rem;
}
.f-brand{
  font-family:'Playfair Display',serif;
  font-size:.88rem;color:rgba(255,255,255,.2);
}
.f-nav{display:flex;gap:2rem}
.f-nav a{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.16);transition:color .2s}
.f-nav a:hover{color:rgba(255,255,255,.45)}
.f-copy{font-size:.58rem;color:rgba(255,255,255,.1);letter-spacing:.04em}

/* ─── BLOG ────────────────────────────────────────────────── */
.blog-hero{padding:10rem 3rem 5rem 6rem;background:var(--white);border-bottom:1px solid var(--border)}
.blog-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,5rem);color:var(--navy);line-height:1;max-width:700px}
.blog-hero p{font-size:.9rem;color:var(--mid);margin-top:1.5rem;font-weight:300;max-width:500px}
.blog-body{padding:5rem 3rem 5rem 6rem;background:var(--off);max-width:1280px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1280px;margin:0 auto}
.b-card{background:var(--white);border:1px solid var(--border);padding:2rem;transition:border-color .2s}
.b-card:hover{border-color:var(--navy)}
.b-meta{display:flex;gap:1rem;margin-bottom:1.2rem;align-items:center}
.b-cat{font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;background:var(--navy);color:var(--white);padding:.16rem .6rem}
.b-date{font-size:.68rem;color:var(--mid);font-weight:300}
.b-title{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--navy);font-weight:700;margin-bottom:.8rem;line-height:1.25}
.b-ex{font-size:.8rem;color:var(--mid);font-weight:300;line-height:1.8;margin-bottom:1.2rem}
.b-link{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);border-bottom:1px solid var(--gold);padding-bottom:2px;font-weight:500}

/* ─── SINGLE ──────────────────────────────────────────────── */
.post-hero{padding:10rem 3rem 4rem 6rem;border-bottom:1px solid var(--border)}
.post-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.5rem);color:var(--navy);max-width:800px}
.post-meta{font-size:.72rem;color:var(--mid);margin-top:1.5rem}
.post-body{background:var(--white);padding:5rem 3rem 6rem 6rem;max-width:860px}
.post-body p{font-size:.95rem;line-height:1.95;color:#333;margin-bottom:1.5rem;font-weight:300}
.post-body h2{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--navy);margin:2.5rem 0 1rem}
.post-body h3{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--navy);margin:2rem 0 .8rem}
.post-body ul{margin:1rem 0 1.5rem 1.5rem;list-style:disc}
.post-body ul li{font-size:.92rem;color:#444;margin-bottom:.5rem;font-weight:300}
.post-body strong{color:var(--navy);font-weight:600}
.post-cta-box{background:var(--off);border:1px solid var(--border);padding:2.5rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;margin:0 0 5rem}

/* ─── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1100px){
  .hero-bottom{grid-template-columns:1fr 1fr;gap:2rem}
  .hero-claim{grid-column:1/3}
  .hero-ref{border-left:none;padding-left:0}
  .chi-sono{grid-template-columns:1fr;gap:3rem}
  .chi-right{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
  .steps-grid{grid-template-columns:repeat(3,1fr)}
  .step-item:nth-child(4){border-left:none;padding-left:0}
  .contatti{grid-template-columns:1fr}
  .cont-left,.cont-right{padding:4rem 2rem}
  .cont-left::before{display:none}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .hero::before{display:none}
  .hero-top{padding:4rem 1.4rem 2rem}
  .hero-bottom{grid-template-columns:1fr;padding:1.5rem 1.4rem;gap:1.5rem}
  .hero-claim{grid-column:1/2}
  .intro{grid-template-columns:1fr;padding:4rem 1.4rem;gap:2rem}
  .servizi,.approccio,.chi-sono{padding:4rem 1.4rem}
  .platforms{grid-template-columns:1fr;padding:2rem 1.4rem;gap:1.5rem}
  .svc-item{grid-template-columns:50px 1fr;gap:1.2rem}
  .svc-points,.svc-arr{display:none}
  .steps-grid{grid-template-columns:1fr 1fr}
  .step-item{border-right:none;border-bottom:1px solid var(--border);padding:1.5rem 0;padding-left:0 !important;padding-right:0 !important}
  .step-item:last-child{border-bottom:none}
  .nav-links,.nav-contact{display:none}
  .nav-burger{display:flex}
  .chi-right{display:flex;flex-direction:column}
  footer{flex-direction:column;text-align:center;padding:2rem 1.4rem;gap:1rem}
  .f-copy{text-align:center}
  .blog-grid{grid-template-columns:1fr}
  .blog-hero,.blog-body,.post-hero,.post-body{padding-left:1.4rem;padding-right:1.4rem}
}
