/*
Theme Name: Turra
Description: Tema custom per Turra Srl - parapetti, scale, ringhiere, cancelli e chiusure in vetro. Costruito per velocità (niente page builder, niente jQuery, niente cache plugin necessario) e per mettere in risalto la qualità del lavoro artigianale.
Author: Turra Srl
Version: 1.0
Text Domain: turra
*/

:root{
  --turra-red:#c9153a;
  --turra-dark:#1a1a1a;
  --turra-ink:#2b2b2b;
  --turra-body:#4a4a4a;
  --turra-bg-alt:#f7f7f8;
  --turra-radius:10px;
  --turra-max:1180px;
}

*{box-sizing:border-box}
html{font-size:17px;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Montserrat',Arial,Helvetica,sans-serif;color:var(--turra-ink);line-height:1.6;background:#fff}
img{max-width:100%;height:auto;display:block}
a{color:var(--turra-red)}
.turra-container{max-width:var(--turra-max);margin:0 auto;padding:0 20px}

/* Eyebrow / section labels */
.turra-eyebrow{display:block;text-align:center;text-transform:uppercase;letter-spacing:.18em;font-size:.78em;font-weight:700;color:var(--turra-red);margin-bottom:10px}
.turra-eyebrow--light{color:#fff;opacity:.85}

h1,h2,h3,h4{font-family:'Montserrat',Arial,sans-serif;font-weight:800;line-height:1.25;margin:0 0 .5em;color:var(--turra-ink)}
.turra-section-title{font-size:2.1em;text-align:center;position:relative;padding-bottom:18px;margin-bottom:34px}
.turra-section-title:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--turra-red);border-radius:3px}

/* Buttons */
.turra-btn{display:inline-block;padding:15px 30px;border-radius:50px;text-decoration:none;font-weight:700;font-size:1em;transition:transform .18s ease,box-shadow .18s ease;border:none;cursor:pointer}
.turra-btn:hover{transform:translateY(-2px)}
.turra-btn--primary{background:var(--turra-red);color:#fff;box-shadow:0 8px 24px rgba(201,21,58,.4)}
.turra-btn--primary:hover{color:#fff;box-shadow:0 12px 30px rgba(201,21,58,.6)}
.turra-btn--ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.turra-btn--ghost:hover{background:#fff;color:var(--turra-red)}
.turra-btn--dark{background:var(--turra-dark);color:#fff}
.turra-btn--dark:hover{color:#fff;background:var(--turra-red)}

/* Header — barra superiore stile bandiera italiana (3 bande uguali).
   Il bianco è #fff puro (bandiera), con una riga di separazione per non fonderlo
   con l'header sottostante. */
.turra-topbar__row{display:flex;border-bottom:1px solid #ececec}
.turra-topbar__col{flex:1;display:flex;align-items:center;min-height:44px;padding:0 20px;font-size:.8em;min-width:0}
.turra-topbar__col--green{background:#00753a;color:#fff;justify-content:flex-start}
.turra-topbar__col--white{background:#fff;color:var(--turra-ink);justify-content:center;font-weight:700}
.turra-topbar__col--red{background:var(--turra-red);color:#fff;justify-content:flex-end;gap:24px}
.turra-topbar__col--red a{display:inline-flex;align-items:center;gap:6px;color:#fff;text-decoration:none;padding:12px 4px}
.turra-topbar__col--red a:hover{opacity:.85}

@media (max-width:900px){
  .turra-topbar__col--white{display:none}
}
.turra-header{border-bottom:1px solid #eee;position:sticky;top:0;background:#fff;z-index:100}
.turra-header__row{max-width:1440px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:nowrap}
.turra-logo{flex-shrink:0}
.turra-logo img{height:52px;width:auto}
.turra-nav{display:flex;gap:16px;flex-wrap:nowrap;list-style:none;margin:0;padding:0;min-width:0}
.turra-nav>li{position:relative}
.turra-nav>li>a{display:flex;align-items:center;gap:7px;padding:8px 0;text-decoration:none;color:var(--turra-ink);font-weight:700;font-size:.82em;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}
.turra-nav>li>a:hover{color:var(--turra-red)}
/* Icona SVG di sezione: eredita il colore del testo (rossa in hover) e si alza appena
   al passaggio del mouse per un tocco di vivacità */
.turra-nav__ico{width:18px;height:18px;flex:0 0 auto;stroke:currentColor;transition:transform .18s ease}
.turra-nav>li>a:hover .turra-nav__ico{transform:translateY(-2px)}
.turra-nav .sub-menu{display:none;position:absolute;top:100%;left:0;background:#fff;box-shadow:0 12px 30px rgba(0,0,0,.12);border-radius:10px;padding:10px;min-width:300px;max-width:340px;list-style:none;margin:0;z-index:10;max-height:80vh;overflow-y:auto}
.turra-nav li:hover>.sub-menu{display:block}
.turra-nav .sub-menu a{display:flex;align-items:center;gap:14px;padding:7px;border-radius:8px;font-size:.9em;text-transform:none;font-weight:600;white-space:normal;color:var(--turra-ink);text-decoration:none}
.turra-nav .sub-menu a:hover{color:var(--turra-red);background:var(--turra-bg-alt)}
.turra-nav-icon{width:40px;height:40px;min-width:40px;border-radius:8px;object-fit:cover;background:var(--turra-bg-alt)}
.turra-header__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.turra-burger{display:none;background:none;border:none;font-size:1.6em;cursor:pointer}

@media (max-width:640px){
  .turra-topbar{display:none}
  /* A ~390px logo + "Preventivo" + burger non stanno nella riga e il burger
     finirebbe FUORI dallo schermo: si compattano logo e bottone. */
  .turra-header__row{padding:10px 14px;gap:10px}
  .turra-logo img{height:38px}
  .turra-header__actions{gap:8px}
  .turra-header__actions .turra-btn{padding:9px 14px;font-size:.85em}
}

@media (max-width:1050px){
  .turra-nav{display:none}
  .turra-burger{display:block}
  .turra-nav.is-open{display:flex;flex-direction:column;flex-wrap:nowrap;position:absolute;top:100%;left:0;right:0;background:#fff;box-shadow:0 16px 30px rgba(0,0,0,.12);padding:8px 20px 20px;gap:0;max-height:80vh;overflow-y:auto}
  .turra-nav.is-open>li{width:100%}
  .turra-nav.is-open>li>a{padding:12px 0;border-bottom:1px solid #f0f0f0;font-size:.9em}
  .turra-nav.is-open .sub-menu{display:block;position:static;box-shadow:none;padding:0 0 8px 16px;min-width:0;max-width:none;max-height:none;overflow:visible}
}

/* Breadcrumb */
.turra-breadcrumb{font-size:.85em;color:#888;padding:16px 0}
.turra-breadcrumb a{color:#888;text-decoration:none}
.turra-breadcrumb a:hover{color:var(--turra-red)}

/* Hero homepage: sfondo responsive + WebP (URL relative alla posizione di style.css,
   cioè alla cartella del tema). Base JPG per tutti; @supports serve il WebP (più leggero)
   ai browser che lo gestiscono. Desktop 1600px, mobile 900px/37KB WebP per un LCP rapido. */
.turra-hero--home{background-size:cover;background-position:center;padding:40px 20px;color:#fff;text-align:center;position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;background-image:linear-gradient(180deg,rgba(10,10,10,.35),rgba(10,10,10,.65)),url('assets/hero-desktop.jpg')}
@supports (background-image:image-set(url("x") type("image/webp"))){
  .turra-hero--home{background-image:linear-gradient(180deg,rgba(10,10,10,.35),rgba(10,10,10,.65)),image-set(url('assets/hero-desktop.webp') type("image/webp"),url('assets/hero-desktop.jpg') type("image/jpeg"))}
}
@media (max-width:768px){
  .turra-hero--home{background-image:linear-gradient(180deg,rgba(10,10,10,.35),rgba(10,10,10,.65)),url('assets/hero-mobile.jpg')}
  @supports (background-image:image-set(url("x") type("image/webp"))){
    .turra-hero--home{background-image:linear-gradient(180deg,rgba(10,10,10,.35),rgba(10,10,10,.65)),image-set(url('assets/hero-mobile.webp') type("image/webp"),url('assets/hero-mobile.jpg') type("image/jpeg"))}
  }
}

/* Hero (product/category pages) */
.turra-page-hero{background-size:cover;background-position:center;padding:70px 20px;color:#fff;position:relative}
.turra-page-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.35),rgba(10,10,10,.7))}
.turra-page-hero__inner{position:relative;z-index:1;max-width:var(--turra-max);margin:0 auto}
.turra-page-hero h1{color:#fff;font-size:2.4em;margin:0}

/* Gallery (custom lightbox, no external plugin dependency) */
.turra-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:30px 0}
.turra-gallery__item{position:relative;aspect-ratio:4/3;border-radius:8px;overflow:hidden;cursor:zoom-in;background:#eee}
.turra-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.turra-gallery__item:hover img{transform:scale(1.06)}
.turra-gallery__code{position:absolute;left:0;right:0;bottom:0;z-index:1;background:linear-gradient(180deg,transparent,rgba(0,0,0,.78));color:#fff;font-size:.74em;font-weight:600;line-height:1.35;padding:20px 10px 8px;pointer-events:none}
.turra-lightbox{position:fixed;inset:0;background:rgba(10,10,10,.92);display:none;align-items:center;justify-content:center;z-index:1000;padding:30px}
.turra-lightbox.is-open{display:flex}
.turra-lightbox img{max-width:92vw;max-height:80vh;border-radius:6px}
.turra-lightbox__caption{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);max-width:88vw;color:#fff;background:rgba(0,0,0,.55);padding:8px 18px;border-radius:50px;font-size:.95em;font-weight:600;text-align:center;margin:0}
.turra-lightbox__close,.turra-lightbox__prev,.turra-lightbox__next{position:absolute;background:rgba(255,255,255,.15);color:#fff;border:none;width:46px;height:46px;border-radius:50%;font-size:1.4em;cursor:pointer;display:flex;align-items:center;justify-content:center}
.turra-lightbox__close{top:24px;right:24px}
.turra-lightbox__prev{left:24px;top:50%;transform:translateY(-50%)}
.turra-lightbox__next{right:24px;top:50%;transform:translateY(-50%)}
.turra-lightbox__close:hover,.turra-lightbox__prev:hover,.turra-lightbox__next:hover{background:var(--turra-red)}

/* Content */
.turra-content{max-width:820px;margin:0 auto;padding:50px 20px}
.turra-content p{font-size:1.05em;line-height:1.8;color:var(--turra-body)}
.turra-content h2{font-size:1.5em;margin-top:1.4em}

/* Product page layout: testo + sidebar con il form preventivo.
   NIENTE position:sticky sulla sidebar: col form allungato (Comune+Provincia) il box
   supera l'altezza dello schermo e sticky+overflow interno lo farebbe "scorrere dentro
   sé stesso" mentre l'utente compila — instabile proprio dove si raccolgono i lead. */
.turra-product-layout{max-width:var(--turra-max);margin:0 auto;padding:0 20px;display:grid;grid-template-columns:1fr 340px;gap:50px;align-items:start}
.turra-product-layout .turra-content{max-width:none;margin:0;padding:50px 0}
.turra-sidebar{padding:50px 0}
.turra-sidebar .turra-cta{margin:0}

@media (max-width:900px){
  .turra-product-layout{grid-template-columns:1fr;gap:0}
  .turra-sidebar{padding:0 0 40px}
}

/* Cards / mosaic / showcase (shared with homepage) */
.turra-mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.turra-mosaic__item{position:relative;display:flex;align-items:flex-end;aspect-ratio:1/1;border-radius:var(--turra-radius);overflow:hidden;text-decoration:none;transition:transform .35s ease,box-shadow .35s ease}
.turra-mosaic__item:hover{transform:scale(1.015);box-shadow:0 18px 40px rgba(0,0,0,.25)}
.turra-mosaic__item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.turra-mosaic__item:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.75));z-index:1}
.turra-mosaic__item span{position:relative;z-index:2;color:#fff;font-weight:700;padding:16px}

.turra-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px}
.turra-card{display:block;background:#fff;border-radius:var(--turra-radius);overflow:hidden;text-decoration:none;color:var(--turra-ink);box-shadow:0 4px 16px rgba(0,0,0,.08);transition:transform .2s ease,box-shadow .2s ease}
.turra-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.15)}
.turra-card__img{aspect-ratio:4/3;overflow:hidden;background:#eee}
.turra-card__img img{width:100%;height:100%;object-fit:cover}
.turra-card__body{padding:16px}
.turra-card__title{font-weight:700;font-size:1em;margin:0}

/* CTA box */
.turra-cta{margin:40px 0;padding:34px;background:var(--turra-bg-alt);border-left:4px solid var(--turra-red);border-radius:6px}
.turra-cta h3{margin-top:0}
.turra-cta__phone{font-size:1.3em;font-weight:700;text-decoration:none}

/* Form nella CTA: campi comodi da compilare (Gravity Forms li renderebbe stretti,
   soprattutto telefono/email affiancati nella sidebar) */
.turra-cta .gform_wrapper input[type=text],
.turra-cta .gform_wrapper input[type=email],
.turra-cta .gform_wrapper input[type=tel],
.turra-cta .gform_wrapper input[type=number],
.turra-cta .gform_wrapper select,
.turra-cta .gform_wrapper textarea{width:100%;box-sizing:border-box;padding:11px 12px;font-size:1em;border:1px solid #d5d5d8;border-radius:6px;background:#fff}
.turra-cta .gform_wrapper input:focus,
.turra-cta .gform_wrapper select:focus,
.turra-cta .gform_wrapper textarea:focus{outline:none;border-color:var(--turra-red)}
/* Il CSS gravity-theme fissa larghezze ridotte sugli input .small/.medium/.large e
   carica DOPO il nostro foglio: serve l'important per vincere a pari specificità */
.turra-cta .gform_wrapper input.small,
.turra-cta .gform_wrapper input.medium,
.turra-cta .gform_wrapper input.large,
.turra-cta .gform_wrapper select.small,
.turra-cta .gform_wrapper select.medium,
.turra-cta .gform_wrapper select.large,
.turra-cta .gform_wrapper textarea.small,
.turra-cta .gform_wrapper textarea.medium,
.turra-cta .gform_wrapper textarea.large{width:100% !important}
/* In sidebar ogni campo occupa tutta la riga: niente colonne strette */
.turra-sidebar .turra-cta .gform_wrapper .gform_fields .gfield{grid-column:1/-1 !important}
/* Sidebar: box e spaziature più compatti, così si vedono più campi a colpo d'occhio */
.turra-sidebar .turra-cta{padding:24px 20px}
.turra-sidebar .turra-cta .gform_wrapper .gform_fields{grid-row-gap:12px !important}
.turra-sidebar .turra-cta .gform_wrapper input[type=text],
.turra-sidebar .turra-cta .gform_wrapper input[type=email],
.turra-sidebar .turra-cta .gform_wrapper input[type=tel]{padding:9px 11px}
.turra-sidebar .turra-cta .gform_wrapper textarea{height:110px !important;padding:9px 11px}
/* Il testo informativa privacy del consenso occupa mezzo schermo: compresso e scorrevole
   (important: il CSS gravity-theme carica dopo il nostro e vincerebbe a pari specificità) */
.turra-cta .gform_wrapper .gfield_consent_description{max-height:64px !important;overflow-y:auto !important;font-size:.72em !important;line-height:1.5;padding:8px 10px !important}
/* Contatore caratteri ("2 di 30...") sotto il campo Provincia: rumore, via */
.turra-cta .gform_wrapper .ginput_counter{display:none !important}
/* Bottone invio del form: stile bottone primario del tema, non il grigio del browser */
.turra-cta .gform_wrapper input[type=submit]{display:inline-block;width:100%;padding:14px 30px;border:none;border-radius:50px;background:var(--turra-red);color:#fff;font-weight:700;font-size:1em;font-family:inherit;cursor:pointer;box-shadow:0 8px 24px rgba(201,21,58,.35);transition:transform .18s ease,box-shadow .18s ease}
.turra-cta .gform_wrapper input[type=submit]:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(201,21,58,.5)}

/* Box informazioni locali (dati reali del comune, sulle pagine dottrina prodotto+città) */
.turra-local-info{margin:24px 0 0;padding:26px;background:#fff;border:1px solid #eee;border-radius:6px}
.turra-local-info h2{font-size:1.05em;margin:0 0 14px}
.turra-local-info ul{list-style:none;margin:0;padding:0}
.turra-local-info li{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-top:1px solid #f0f0f0;font-size:.92em}
.turra-local-info li:first-child{border-top:none}
.turra-local-info li span{color:#888}
.turra-local-info li strong{color:var(--turra-ink);text-align:right}

.turra-cta-final{background:var(--turra-dark);color:#fff;text-align:center;padding:70px 20px}
.turra-cta-final h2{color:#fff}
.turra-cta-final p{color:#ccc}
.turra-cta-final .gform_wrapper{max-width:820px;margin:30px auto 0;background:#fff;border-radius:12px;padding:38px 40px;color:#222;text-align:left}
.turra-cta-final__phone a{color:#fff;font-size:1.4em;font-weight:700;text-decoration:none}
/* Form home: tutti i campi impilati a piena larghezza, stessa dimensione e allineati.
   Il gravity-theme dispone i campi su una griglia a 12 colonne con larghezze diverse
   (nome intero, telefono/email/comune/provincia a metà): qui forziamo una sola colonna
   così ogni campo — inclusi Nome e Cognome — occupa la stessa larghezza. */
.turra-cta-final .gform_wrapper .gform_fields{display:grid !important;grid-template-columns:1fr !important;grid-gap:18px !important;gap:18px !important}
.turra-cta-final .gform_wrapper .gfield{grid-column:1 / -1 !important;max-width:none !important}
.turra-cta-final .gform_wrapper .ginput_complex{display:grid !important;grid-template-columns:1fr !important;gap:18px !important}
.turra-cta-final .gform_wrapper .ginput_complex > span{width:100% !important;padding:0 !important;margin:0 !important}
.turra-cta-final .gform_wrapper input[type=text],
.turra-cta-final .gform_wrapper input[type=email],
.turra-cta-final .gform_wrapper input[type=tel],
.turra-cta-final .gform_wrapper input.small,
.turra-cta-final .gform_wrapper input.medium,
.turra-cta-final .gform_wrapper input.large,
.turra-cta-final .gform_wrapper select,
.turra-cta-final .gform_wrapper textarea{width:100% !important;box-sizing:border-box;padding:12px 14px;border:1px solid #d5d5d8;border-radius:8px;font-size:1em;background:#fff}
.turra-cta-final .gform_wrapper input:focus,
.turra-cta-final .gform_wrapper select:focus,
.turra-cta-final .gform_wrapper textarea:focus{outline:none;border-color:var(--turra-red)}
.turra-cta-final .gform_wrapper textarea{min-height:120px}
.turra-cta-final .gform_wrapper .ginput_counter{display:none !important}
.turra-cta-final .gform_wrapper .gfield_consent_description{max-height:70px;overflow-y:auto;font-size:.8em;line-height:1.5;padding:8px 10px}
.turra-cta-final .gform_wrapper input[type=submit]{width:100%;padding:15px 30px;border:none;border-radius:50px;background:var(--turra-red);color:#fff;font-weight:700;font-size:1.05em;font-family:inherit;cursor:pointer;box-shadow:0 8px 24px rgba(201,21,58,.35);transition:transform .18s ease,box-shadow .18s ease}
.turra-cta-final .gform_wrapper input[type=submit]:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(201,21,58,.5)}

/* FAQ */
.turra-faq{max-width:800px;margin:0 auto 14px;background:#fff;border-radius:var(--turra-radius);box-shadow:0 4px 14px rgba(0,0,0,.06);padding:6px 22px}
.turra-faq summary{font-weight:700;cursor:pointer;padding:16px 28px 16px 0;position:relative;list-style:none}
.turra-faq summary::-webkit-details-marker{display:none}
.turra-faq summary:after{content:"+";position:absolute;right:0;top:14px;font-size:1.4em;color:var(--turra-red);transition:transform .2s ease}
.turra-faq[open] summary:after{transform:rotate(45deg)}
.turra-faq p{padding-bottom:18px;margin:0}

/* Footer */
.turra-footer{background:#151515;color:#c4c4c4;padding:60px 0 30px;font-size:.92em}
.turra-footer a{color:#e2e2e2;text-decoration:none}
.turra-footer a:hover{color:var(--turra-red)}
/* Touch target adeguati (min ~24px) e spaziatura sui link del footer */
.turra-footer__cols a,.turra-footer__products a{display:inline-block;padding:5px 0}
.turra-footer__cols p a{padding:6px 0}
.turra-footer__cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:30px;margin-bottom:40px}
.turra-footer__cols h3{color:#fff;font-size:.95em;text-transform:uppercase;letter-spacing:.05em}
.turra-footer__cols ul{list-style:none;padding:0;margin:0}
.turra-footer__cols li{margin-bottom:8px}
.turra-footer__products{grid-column:span 2}
.turra-footer__products ul{column-count:2;column-gap:30px}
.turra-footer__products li{break-inside:avoid}

@media (max-width:640px){
  .turra-footer__products{grid-column:span 1}
  .turra-footer__products ul{column-count:1}
}
.turra-footer__bottom{border-top:1px solid #2a2a2a;padding-top:24px;text-align:center;font-size:.85em;color:#999}
.turra-footer__credit{display:block;margin-top:8px;font-size:.95em;color:#b0b0b0}
.turra-footer__credit a{color:#dcdcdc;text-decoration:underline;text-underline-offset:2px;display:inline-block;padding:6px 3px}
.turra-footer__credit a:hover{color:var(--turra-red)}

/* Sezione "Chi siamo" in home: sotto i paragrafi, lista punti di forza a sinistra e
   foto a destra ALTA QUANTO LA LISTA: l'immagine riempie la cella (object-fit:cover,
   ritaglio centrato sulla spirale della scala), niente spazi morti sopra/sotto. */
.turra-about{display:grid;grid-template-columns:1fr 340px;gap:56px;align-items:stretch;margin-top:34px}
.turra-about figure{position:relative;margin:0;min-height:230px}
.turra-about figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;border-radius:14px;box-shadow:0 18px 45px rgba(0,0,0,.18)}
@media (max-width:900px){
  .turra-about{grid-template-columns:1fr;gap:32px}
  .turra-about figure{position:static;min-height:0;max-width:420px;margin:0 auto}
  .turra-about figure img{position:static;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
}

/* ===== Pagina Contatti (layout dedicato) ===== */
.turra-contact-hero{max-width:var(--turra-max);margin:0 auto;padding:20px 20px 10px;text-align:center}
.turra-contact-hero h1{font-size:2.4em;margin:0 0 12px}
.turra-contact-hero p{max-width:640px;margin:0 auto;color:var(--turra-body);line-height:1.7;font-size:1.05em}

.turra-contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:30px 20px}
.turra-contact-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:26px 18px;background:#fff;border:1px solid #eee;border-radius:var(--turra-radius);box-shadow:0 6px 20px rgba(0,0,0,.06);text-decoration:none;color:var(--turra-ink);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.turra-contact-card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(0,0,0,.12);border-color:var(--turra-red)}
.turra-contact-card__ico{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--turra-bg-alt);color:var(--turra-red)}
.turra-contact-card__ico svg{width:24px;height:24px}
.turra-contact-card strong{font-size:1.02em}
.turra-contact-card span{color:var(--turra-body);font-size:.92em;line-height:1.5}

.turra-contact-main{display:grid;grid-template-columns:1.35fr 1fr;gap:40px;padding:20px 20px 70px;align-items:start}
.turra-contact-form{background:#fff;border:1px solid #eee;border-radius:var(--turra-radius);box-shadow:0 8px 26px rgba(0,0,0,.07);padding:34px}
.turra-contact-form h2{font-size:1.5em;margin:0 0 6px}
.turra-contact-form__lead{color:var(--turra-body);line-height:1.6;margin:0 0 20px}
/* Form Contatti: campi puliti a piena larghezza, coerenti col resto */
.turra-contact-form .gform_wrapper input[type=text],
.turra-contact-form .gform_wrapper input[type=email],
.turra-contact-form .gform_wrapper input[type=tel],
.turra-contact-form .gform_wrapper input[type=number],
.turra-contact-form .gform_wrapper input.small,
.turra-contact-form .gform_wrapper input.medium,
.turra-contact-form .gform_wrapper input.large,
.turra-contact-form .gform_wrapper select,
.turra-contact-form .gform_wrapper textarea{width:100% !important;box-sizing:border-box;padding:12px 14px;border:1px solid #d5d5d8;border-radius:8px;font-size:1em;background:#fff}
.turra-contact-form .gform_wrapper input:focus,
.turra-contact-form .gform_wrapper select:focus,
.turra-contact-form .gform_wrapper textarea:focus{outline:none;border-color:var(--turra-red)}
.turra-contact-form .gform_wrapper textarea{min-height:130px}
.turra-contact-form .gform_wrapper .gfield_consent_description{max-height:74px;overflow-y:auto;font-size:.82em;line-height:1.5;padding:8px 10px}
.turra-contact-form .gform_wrapper input[type=submit]{width:100%;padding:15px 30px;border:none;border-radius:50px;background:var(--turra-red);color:#fff;font-weight:700;font-size:1.05em;font-family:inherit;cursor:pointer;box-shadow:0 8px 24px rgba(201,21,58,.35);transition:transform .18s ease,box-shadow .18s ease}
.turra-contact-form .gform_wrapper input[type=submit]:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(201,21,58,.5)}

.turra-contact-side{position:sticky;top:120px;display:flex;flex-direction:column;gap:20px}
.turra-contact-map{border-radius:var(--turra-radius);overflow:hidden;box-shadow:0 8px 26px rgba(0,0,0,.1);line-height:0}
.turra-contact-map iframe{width:100%;height:300px;border:0;display:block}
.turra-contact-note{background:var(--turra-dark);color:#ddd;border-radius:var(--turra-radius);padding:26px}
.turra-contact-note strong{display:block;color:#fff;font-size:1.05em;margin-bottom:8px}
.turra-contact-note p{margin:0 0 14px;line-height:1.6;font-size:.92em;color:#c9c9c9}
.turra-contact-note__dir{color:#fff;font-weight:700;text-decoration:none}
.turra-contact-note__dir:hover{color:var(--turra-red)}

@media (max-width:900px){
  .turra-contact-cards{grid-template-columns:repeat(2,1fr)}
  .turra-contact-main{grid-template-columns:1fr;gap:28px}
  .turra-contact-side{position:static}
}
@media (max-width:520px){
  .turra-contact-cards{grid-template-columns:1fr}
}

/* Pagina Credit (crediti Evo Sistemi) */
.turra-credit{max-width:900px;margin:0 auto;display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:center;background:#fff;border:1px solid #eee;border-radius:var(--turra-radius);box-shadow:0 10px 30px rgba(0,0,0,.08);padding:40px}
.turra-credit__brand{text-align:center}
.turra-credit__brand img{width:100%;max-width:260px;height:auto;margin:0 auto}
.turra-credit__body h2{font-size:1.5em;margin:0 0 6px}
.turra-credit__body h2 span{color:var(--turra-red);font-weight:700;font-size:.62em;display:block;text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.turra-credit__body p{color:var(--turra-body);line-height:1.7;margin:0 0 16px}
.turra-credit__services{list-style:none;padding:0;margin:0 0 22px}
.turra-credit__services li{padding:6px 0 6px 26px;position:relative;line-height:1.5;color:var(--turra-body)}
.turra-credit__services li:before{content:"\2713";position:absolute;left:0;top:6px;color:var(--turra-red);font-weight:800}
.turra-credit__services li strong{color:var(--turra-ink)}
.turra-credit__services a{color:var(--turra-red);text-decoration:underline}
.turra-credit__foot{margin:22px 0 0;font-size:.92em;color:#888}
.turra-credit__foot a{color:var(--turra-red);text-decoration:underline;font-weight:600}
@media (max-width:720px){
  .turra-credit{grid-template-columns:1fr;gap:26px;padding:28px;text-align:center}
  .turra-credit__actions{justify-content:center}
}

/* Reveal on scroll */
.turra-reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.turra-reveal.turra-in{opacity:1;transform:none}

/* ===== Pagine geo: striscia dati comune, box E-E-A-T, città vicine ===== */
.turra-geo-strip{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:0 0 6px;padding:14px 18px;background:var(--turra-bg-alt);border-left:4px solid var(--turra-red);border-radius:6px;font-size:.88em}
.turra-geo-strip__place{font-weight:700;color:var(--turra-ink)}
.turra-geo-strip__place:before{content:"\1F4CD";margin-right:6px}
.turra-geo-strip__chip{background:#fff;border:1px solid #e5e5e7;border-radius:50px;padding:4px 13px;color:var(--turra-body);font-weight:600;white-space:nowrap}
.turra-geo-strip__chip--full{border-color:var(--turra-red);color:var(--turra-red)}

.turra-eeat{margin:10px 0 34px;padding:36px;background:var(--turra-dark);border-radius:var(--turra-radius);color:#ddd}
.turra-eeat h2{color:#fff;font-size:1.4em;margin:0 0 22px;padding-bottom:14px;position:relative}
.turra-eeat h2:after{content:"";position:absolute;bottom:0;left:0;width:56px;height:3px;background:var(--turra-red);border-radius:3px}
.turra-eeat__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}
.turra-eeat__item strong{display:block;color:#fff;font-size:1.02em;margin-bottom:6px;padding-left:24px;position:relative}
.turra-eeat__item strong:before{content:"\2713";position:absolute;left:0;top:0;color:var(--turra-red);font-weight:800}
.turra-eeat__item p{margin:0;font-size:.9em;line-height:1.65;color:#c9c9c9}
.turra-eeat__item a{color:#fff;text-decoration:underline}
.turra-eeat__firm{margin:24px 0 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.14);font-size:.85em;color:#aaa}
.turra-eeat__firm a{color:#fff;text-decoration:none}
.turra-eeat__firm a:hover{color:var(--turra-red)}

.turra-nearby{margin:0 0 40px}
.turra-nearby h2{font-size:1.15em;margin:0 0 14px}
.turra-nearby__links{display:flex;flex-wrap:wrap;gap:10px}
.turra-nearby__links a{display:inline-block;padding:9px 18px;background:var(--turra-bg-alt);border:1px solid #e5e5e7;border-radius:50px;color:var(--turra-ink);text-decoration:none;font-size:.88em;font-weight:600;transition:all .18s ease}
.turra-nearby__links a:hover{background:var(--turra-red);border-color:var(--turra-red);color:#fff}

/* ===== Blog ===== */
.turra-blog-hero{position:relative;padding:90px 20px 160px;color:#fff;background:var(--turra-dark);overflow:hidden}
.turra-blog-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.4;transform:scale(1.04)}
.turra-blog-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.25) 0%,rgba(10,10,10,.6) 70%,rgba(10,10,10,.85) 100%)}
.turra-blog-hero__inner{position:relative;z-index:2;max-width:var(--turra-max);margin:0 auto;text-align:center}
.turra-blog-hero h1{color:#fff;font-size:3.4em;margin:0 0 14px;letter-spacing:-.01em}
.turra-blog-hero p{max-width:660px;margin:0 auto;color:rgba(255,255,255,.88);font-size:1.08em;line-height:1.7}

/* Chip categoria / meta articolo */
.turra-chip{display:inline-block;background:var(--turra-red);color:#fff;font-size:.72em;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:6px 14px;border-radius:50px;line-height:1.4}
.turra-post-meta{display:flex;flex-wrap:wrap;gap:6px 12px;align-items:center;font-size:.83em;color:#999;font-weight:600}
.turra-readmore{font-weight:700;color:var(--turra-red);display:inline-flex;align-items:center;gap:8px}
.turra-readmore:after{content:"\2192";transition:transform .25s ease}

/* Articolo in evidenza, sovrapposto all'hero */
.turra-featured-wrap{max-width:var(--turra-max);margin:-100px auto 0;padding:0 20px;position:relative;z-index:3}
.turra-featured{display:grid;grid-template-columns:1.25fr 1fr;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.3);text-decoration:none;color:var(--turra-ink)}
.turra-featured__img{position:relative;min-height:380px;overflow:hidden;background:#eee}
.turra-featured__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.turra-featured:hover .turra-featured__img img{transform:scale(1.05)}
.turra-featured__img .turra-chip{position:absolute;top:18px;left:18px;z-index:2}
.turra-featured__body{padding:44px 46px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.turra-featured__body h2{font-size:1.65em;margin:0;transition:color .2s ease}
.turra-featured:hover .turra-featured__body h2{color:var(--turra-red)}
.turra-featured__body p{margin:0;color:var(--turra-body);line-height:1.7}
.turra-featured:hover .turra-readmore:after{transform:translateX(6px)}

/* Griglia articoli */
.turra-blog-grid{max-width:var(--turra-max);margin:0 auto;padding:60px 20px 10px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.turra-post-card{display:flex;flex-direction:column;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 6px 22px rgba(0,0,0,.08);text-decoration:none;color:var(--turra-ink);transition:transform .3s ease,box-shadow .3s ease}
.turra-post-card:hover{transform:translateY(-8px);box-shadow:0 22px 48px rgba(0,0,0,.16)}
.turra-post-card__img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#eee}
.turra-post-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.turra-post-card:hover .turra-post-card__img img{transform:scale(1.08)}
.turra-post-card__img .turra-chip{position:absolute;top:14px;left:14px;z-index:2}
.turra-post-card__body{display:flex;flex-direction:column;gap:10px;padding:22px 22px 24px;flex:1}
.turra-post-card__body h3{font-size:1.06em;line-height:1.45;margin:0;transition:color .2s ease}
.turra-post-card:hover .turra-post-card__body h3{color:var(--turra-red)}
.turra-post-card__body p{margin:0;font-size:.92em;color:var(--turra-body);line-height:1.65;flex:1}
.turra-post-card:hover .turra-readmore:after{transform:translateX(6px)}

/* Ingresso scaglionato delle card (le colonne 2 e 3 arrivano con un filo di ritardo) */
.turra-blog-grid .turra-reveal:nth-child(3n+2){transition-delay:.12s}
.turra-blog-grid .turra-reveal:nth-child(3n){transition-delay:.24s}

@media (max-width:980px){
  .turra-blog-hero{padding:70px 20px 140px}
  .turra-blog-hero h1{font-size:2.6em}
  .turra-featured{grid-template-columns:1fr}
  .turra-featured__img{min-height:260px}
  .turra-featured__body{padding:30px}
  .turra-blog-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .turra-blog-grid .turra-reveal:nth-child(3n+2),.turra-blog-grid .turra-reveal:nth-child(3n){transition-delay:0s}
}
@media (max-width:600px){
  .turra-blog-hero h1{font-size:2.1em}
  .turra-blog-grid{grid-template-columns:1fr}
}

/* Pagination */
.turra-pagination{display:flex;justify-content:center;gap:8px;margin:40px 0}
.turra-pagination a,.turra-pagination span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;text-decoration:none;color:var(--turra-ink);font-weight:700}
.turra-pagination .current{background:var(--turra-red);color:#fff}
.turra-pagination a:hover{background:var(--turra-bg-alt)}

@media (max-width:900px){
  html{font-size:16px}
  .turra-mosaic{grid-template-columns:repeat(2,1fr)}
  .turra-page-hero h1{font-size:1.8em}
}
