/* Fonts are enqueued via wp_enqueue_style('gi-fonts') in functions.php (no render-blocking @import). */

:root{
  --green:#238707;
  --green-d:#166100;
  --green-2:#238707;
  --mint:#BFE3A8;
  --mint-soft:#EDF6FA;
  --bg:#F9FAF7;
  --card:#FFFFFF;
  --ink:#17202A;
  --muted:#5D6670;
  --line:rgba(23,32,42,0.12);
  --line-soft:rgba(23,32,42,0.07);
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Manrope", system-ui, sans-serif;
  --r-s:12px;
  --r-m:18px;
  --r-l:26px;
  --maxw:1280px;
  --gap:28px;
  --shadow-1:0 1px 2px rgba(23,32,42,0.04);
  --shadow-2:0 18px 40px -22px rgba(23,32,42,0.28);
  --shadow-3:0 30px 60px -28px rgba(35,135,7,0.28);
  --thermal:linear-gradient(90deg,#238707 0%,#BFE3A8 55%,#238707 100%);
  --isotherms-dark:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 192' fill='none' stroke='%23B9D9EA' stroke-width='1'%3E%3Cpath stroke-opacity='.30' d='M210,96 C210,84 230,78 250,82 C272,86 280,100 268,110 C256,120 228,120 216,110 C208,104 210,100 210,96 Z'/%3E%3Cpath stroke-opacity='.24' d='M190,96 C190,76 222,64 254,70 C290,77 304,100 284,118 C264,134 218,134 198,116 C190,109 190,102 190,96 Z'/%3E%3Cpath stroke-opacity='.18' d='M168,96 C168,68 216,50 260,58 C310,67 330,100 302,126 C274,150 210,148 182,122 C170,111 168,103 168,96 Z'/%3E%3Cpath stroke-opacity='.12' d='M144,96 C144,58 210,36 266,46 C330,57 356,100 320,134 C284,166 196,164 162,128 C148,114 144,104 144,96 Z'/%3E%3Cpath stroke-opacity='.07' d='M118,96 C118,48 202,22 272,34 C350,47 382,100 338,142 C294,182 184,180 142,134 C124,116 118,106 118,96 Z'/%3E%3C/svg%3E");
}

*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.greenitaly-site{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.6}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px}

.media{position:relative;overflow:hidden;border-radius:var(--r-m);background:var(--mint-soft)}
.media img,.gi-placeholder{width:100%;height:100%;display:block;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.gi-placeholder{background:linear-gradient(135deg,#edf6fa,#dcecf5 58%,#ffe4d8);position:relative}
.gi-placeholder::before{content:"";position:absolute;inset:18px;border:1.5px dashed rgba(27,27,27,.18);border-radius:inherit}
.gi-placeholder span{position:absolute;inset:0;display:grid;place-items:center;color:rgba(27,27,27,.42);font-size:13px;font-weight:600}

.site-header{position:sticky;top:0;z-index:60;background:rgba(249,250,247,0.86);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--line-soft)}
.header-inner{display:flex;align-items:center;gap:32px;height:78px}
.site-header .header-inner{max-width:none;padding:0 40px}
.brand{display:flex;align-items:center;font-family:var(--sans);font-weight:800;font-size:25px;letter-spacing:0;white-space:nowrap}
.brand-text{display:inline-flex;align-items:baseline;line-height:1}
.brand-cold{color:var(--green-d);letter-spacing:0}
.brand-hot{color:#238707;letter-spacing:0} /* darker than --green-2: 3:1+ on light header bg (WCAG large text) */
.brand-deg{color:#238707;font-weight:800;font-size:.6em;position:relative;top:-.5em;margin:0 2px}
.footer-brand .brand-cold{color:#fff}
.footer-brand .brand-hot{color:var(--green-2)}
.footer-brand .brand-deg{color:var(--green-2)}
.nav{display:flex;align-items:center;justify-content:center;gap:clamp(18px,2vw,34px);margin-left:8px;flex:1}
.nav .nav-list{display:contents;margin:0;padding:0;list-style:none}
.nav li{list-style:none;margin:0;padding:0}
.nav a{font-size:15px;font-weight:600;color:var(--ink);padding:6px 0;position:relative;white-space:nowrap;transition:color .2s}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--green);transition:width .28s cubic-bezier(.2,.7,.2,1)}
.nav a:hover,.nav .current-menu-item>a,.nav .current-cat>a{color:var(--green)}
.nav a:hover::after,.nav .current-menu-item>a::after,.nav .current-cat>a::after{width:100%}
.header-tools{margin-left:auto;display:flex;align-items:center;gap:14px}
.icon-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--card);display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:.2s}
.icon-btn:hover{border-color:var(--green);color:var(--green)}
.icon-btn svg{width:19px;height:19px}
.menu-btn{display:none}
.mobile-nav{display:none;position:fixed;inset:0;z-index:80;background:rgba(27,27,27,.4);opacity:0;pointer-events:none;transition:opacity .25s}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav .sheet{position:absolute;top:0;right:0;height:100%;width:min(82vw,360px);background:var(--bg);padding:28px 26px;transform:translateX(100%);transition:transform .32s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;gap:6px}
.mobile-nav.open .sheet{transform:none}
.mobile-nav .sheet a{font-family:var(--serif);font-size:24px;font-weight:600;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.mobile-nav .sheet .close{align-self:flex-end;margin-bottom:14px}

.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--green)}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:transparent;border:2px solid var(--green)} /* il "grado" del brand */
.card{display:flex;flex-direction:column;gap:16px;cursor:pointer;--img-h:240px}
.card .media{height:var(--img-h)}
.card .card-body{display:flex;flex-direction:column;gap:11px}
.card .cat,.latest-item .cat{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.card h3{font-family:var(--serif);font-weight:700;color:var(--ink);margin:0;line-height:1.14;letter-spacing:0;font-size:var(--title,23px);text-wrap:pretty}
.card .byline{font-size:13px;color:var(--muted)}
.card:hover h3,.latest-item:hover h3{color:var(--green-d)}
.card:hover .media img,.card:hover .gi-placeholder,.latest-item:hover .media img,.latest-item:hover .gi-placeholder{transform:scale(1.055)}
.card .media{transition:box-shadow .35s,transform .35s}
.card:hover .media{box-shadow:var(--shadow-2)}
.card .media::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--thermal);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.2,.7,.2,1);z-index:1}
.card:hover .media::after{transform:scaleX(1)}
.card.feature{--img-h:460px;--title:40px}
.card.feature h3{font-weight:800;line-height:1.08}
.card.medium{--img-h:280px;--title:23px}
.card.small{--img-h:200px;--title:19px}

.hero{padding:46px 0 30px}
.hero-grid{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.7fr);gap:46px;align-items:stretch}
.hero-content{display:flex;flex-direction:column;justify-content:center;gap:24px;padding:14px 0}
.hero-content .eyebrow{font-size:13px}
.hero-content h1{font-family:var(--serif);font-weight:800;margin:0;font-size:clamp(40px,4.4vw,68px);line-height:1.02;letter-spacing:0;text-wrap:balance}
.hero-meta{display:flex;align-items:center;gap:14px;font-size:14px;font-weight:600;color:var(--muted);flex-wrap:wrap}
.hero-meta .author{color:var(--ink)}
.dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.6;display:inline-block}
.hero-media{height:560px;border-radius:var(--r-l)}
.hero-media .media{height:100%;border-radius:var(--r-l)}
.hero-cta{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--green);font-size:15px;margin-top:2px}
.hero-cta svg{width:18px;height:18px;transition:transform .3s}
.hero-content:hover .hero-cta svg{transform:translateX(5px)}

.section{padding:52px 0}
.section.tight{padding:34px 0}
.section-head{position:relative;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:34px;padding-bottom:18px;border-bottom:0}
.section-head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;border-radius:2px;background:var(--thermal)}
.section-head h2{font-family:var(--serif);font-weight:700;margin:0;font-size:clamp(26px,2.7vw,38px);letter-spacing:0;line-height:1}
.section-head .count{font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.04em}
.see-all{font-size:14px;font-weight:700;color:var(--green);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.see-all svg{width:16px;height:16px;transition:transform .25s}
.see-all:hover svg{transform:translateX(4px)}

.editorial-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gap);align-items:start}
.editorial-grid .feature{grid-column:span 7}
.editorial-grid .side-stack{grid-column:span 5;display:flex;flex-direction:column;gap:30px}
.editorial-grid .side-stack .card{flex-direction:row;gap:20px;--img-h:150px}
.editorial-grid .side-stack .media{width:200px;flex:0 0 200px}
.editorial-grid .side-stack .card-body{justify-content:center}
.editorial-grid .row4{grid-column:span 12;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.cluster-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.category-sections{padding-top:68px}
.category-sections,.category-band{scroll-margin-top:104px}
.category-section-stack .category-band:first-child{border-top:0;padding-top:0}
.category-index{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 34px}
.category-section-stack{display:flex;flex-direction:column;gap:54px}
.category-band{padding-top:34px;border-top:1px solid var(--line)}
.category-band-head{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:28px;align-items:end;margin-bottom:28px}
.band-glyph{width:84px;height:84px;color:var(--mint);opacity:.55;justify-self:end;align-self:center;margin-right:6px;pointer-events:none}
.band-glyph svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
@media (max-width:900px){.band-glyph{display:none}}
.category-band-head h3{font-family:var(--serif);font-size:clamp(30px,3.6vw,48px);line-height:1;margin:12px 0 0;letter-spacing:0}
.category-band-head p{max-width:58ch;margin:14px 0 0;color:var(--muted);font-size:15.5px;line-height:1.55}
.category-article-grid{display:grid;grid-template-columns:1.15fr repeat(2,minmax(0,.85fr));gap:var(--gap);align-items:start}
.category-article-grid .category-lead{--img-h:330px;--title:30px}
.category-article-grid .card.small{--img-h:210px}
/* ── Rotating band layouts (movement) ── */
/* lead: big lead + 2 small in a row, mirrored on alternate bands */
.category-article-grid.layout-lead.reverse{direction:rtl}
.category-article-grid.layout-lead.reverse>*{direction:ltr}
/* trio: three equal cards */
.category-article-grid.layout-trio{grid-template-columns:repeat(3,1fr);align-items:start}
.category-article-grid.layout-trio .card{--img-h:248px;--title:23px}
/* mosaic: tall lead on one side + two stacked cards on the other */
.category-article-grid.layout-mosaic{grid-template-columns:1.6fr 1fr;align-items:stretch}
.category-article-grid.layout-mosaic .category-lead{grid-column:1;grid-row:1 / span 2;--img-h:436px;--title:32px}
.category-article-grid.layout-mosaic.reverse{grid-template-columns:1fr 1.6fr}
.category-article-grid.layout-mosaic.reverse .category-lead{grid-column:2}
.category-article-grid.layout-mosaic .card.small{--img-h:190px}
.featured-dossier-section{padding:64px 0}
.featured-dossier{position:relative;min-height:660px;display:grid;overflow:hidden;background:var(--ink);color:#fff}
.featured-dossier__bg{position:absolute;inset:0;border-radius:0;background:var(--ink)}
.featured-dossier__bg img,.featured-dossier__bg .gi-placeholder{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.featured-dossier__shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,63,99,.9) 0%,rgba(23,32,42,.72) 42%,rgba(23,32,42,.34) 100%),linear-gradient(180deg,rgba(23,32,42,.2) 0%,rgba(23,32,42,.72) 100%);z-index:1}
.featured-dossier__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:72px 40px;display:grid;grid-template-columns:minmax(0,.92fr) minmax(520px,1.08fr);gap:60px;align-items:center}
.featured-dossier__lead{display:flex;flex-direction:column;align-items:flex-start;gap:18px;max-width:570px}
.featured-dossier__label{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:7px 15px;color:rgba(255,255,255,.86);font-size:11.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;background:rgba(255,255,255,.08)}
.featured-dossier__label::before{content:"";width:8px;height:8px;border-radius:50%;background:transparent;border:2px solid var(--green-2)}
.featured-dossier__cat,.featured-dossier__card-cat{color:var(--green-2);font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}
.featured-dossier__lead h2{font-family:var(--serif);font-size:clamp(42px,5vw,70px);font-weight:800;line-height:1.02;letter-spacing:0;margin:0;text-wrap:balance}
.featured-dossier__lead p{max-width:54ch;margin:0;color:rgba(255,255,255,.78);font-size:17px;line-height:1.7}
.featured-dossier__cta{display:inline-flex;align-items:center;gap:10px;margin-top:8px;min-height:50px;padding:0 22px;border-radius:999px;background:var(--green-2);color:var(--ink);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 22px 36px -24px rgba(35,135,7,.8);transition:transform .22s,background .22s}
.featured-dossier__cta svg{width:17px;height:17px;transition:transform .22s}
.featured-dossier__lead:hover .featured-dossier__cta{background:#2FA008;transform:translateY(-1px)}
.featured-dossier__lead:hover .featured-dossier__cta svg{transform:translateX(4px)}
/* 2x2: con 4 colonne le card scendevano sotto i 150px e i titoli andavano a capo dentro le parole */
.featured-dossier__cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:stretch}
.featured-dossier__card{display:flex;flex-direction:column;gap:12px;padding:14px;border:1px solid rgba(255,255,255,.22);border-radius:var(--r-m);background:rgba(255,255,255,.12);backdrop-filter:blur(12px);box-shadow:0 24px 42px -34px rgba(0,0,0,.72);transition:transform .25s,border-color .25s,background .25s}
.featured-dossier__card:hover{transform:translateY(-4px);border-color:rgba(35,135,7,.8);background:rgba(255,255,255,.17)}
.featured-dossier__thumb{height:140px;border-radius:12px;background:rgba(255,255,255,.12)}
.featured-dossier__thumb img,.featured-dossier__thumb .gi-placeholder{height:100%;object-fit:cover}
.featured-dossier__card h3{font-family:var(--serif);font-size:19px;line-height:1.18;letter-spacing:0;margin:0;color:#fff;text-wrap:pretty}
.newsletter-cta-section{padding:62px 0}
.newsletter-cta{display:grid;grid-template-columns:minmax(0,.95fr) minmax(360px,.78fr);gap:44px;align-items:center;padding:38px;border-radius:var(--r-l);background-image:var(--isotherms-dark),linear-gradient(135deg,var(--green-d),var(--ink) 68%);background-repeat:no-repeat,no-repeat;background-position:right -80px center,0 0;background-size:560px auto,auto;color:#fff;box-shadow:var(--shadow-2)}
.newsletter-cta__content h2{font-family:var(--serif);font-size:clamp(34px,4vw,54px);line-height:1.02;margin:18px 0 0;letter-spacing:0;text-wrap:balance}
.newsletter-cta__content p{max-width:58ch;margin:20px 0 0;color:rgba(255,255,255,.74);font-size:17px;line-height:1.65}
.newsletter-cta .eyebrow{color:var(--green-2)}
.newsletter-cta .eyebrow::before{border-color:var(--green-2)}
.newsletter-cta__form{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-m);padding:26px;backdrop-filter:blur(10px)}
.cgb-ft-newsletter__title{font-family:var(--serif);font-size:28px;line-height:1.05;margin:0;color:#fff}
.cgb-ft-newsletter__sub{margin:10px 0 18px;color:rgba(255,255,255,.7);font-size:14.5px;line-height:1.55}
.cgb-ft-newsletter__fields{display:flex;gap:10px;align-items:stretch}
.cgb-ft-newsletter__input{width:100%;min-width:0;height:48px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#fff;color:var(--ink);font:600 14px var(--sans);padding:0 18px;outline:none}
.cgb-ft-newsletter__input:focus{border-color:var(--green-2);box-shadow:0 0 0 3px rgba(35,135,7,.18)}
.cgb-ft-newsletter__btn{height:48px;border:0;border-radius:999px;background:var(--green-2);color:var(--ink);font:800 14px var(--sans);padding:0 20px;white-space:nowrap;cursor:pointer;transition:background .2s,transform .2s}
.cgb-ft-newsletter__btn:hover{background:#2FA008;transform:translateY(-1px)}
.cgb-ft-newsletter__btn:disabled{opacity:.58;cursor:not-allowed;transform:none}
.cgb-ft-newsletter__consent{display:flex;gap:10px;align-items:flex-start;margin-top:14px;color:rgba(255,255,255,.72);font-size:12.5px;line-height:1.45}
.cgb-ft-newsletter__consent input{margin-top:3px;flex:0 0 auto;accent-color:var(--green-2)}
.cgb-ft-newsletter__consent a{color:#fff;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.cgb-ft-newsletter__feedback{display:none;margin-top:12px;font-size:13px;font-weight:700}
.cgb-ft-newsletter__feedback--success{color:#a7f3d0}
.cgb-ft-newsletter__feedback--error{color:#fecaca}
.cgb-ft-newsletter__success{display:none}
.strip-wrap{position:relative}
.strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(420px,46%);gap:var(--gap);overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 40px 26px;margin:0 -40px;scrollbar-width:none}
.strip::-webkit-scrollbar{display:none}
.strip .card{scroll-snap-align:start;--img-h:340px;--title:30px}
.strip-arrows{display:flex;gap:10px}
.latest-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 48px}
.latest-item{display:grid;grid-template-columns:120px 1fr;gap:22px;align-items:start;padding:22px 0;border-top:1px solid var(--line);cursor:pointer}
.latest-item .media{height:104px;border-radius:var(--r-s)}
.latest-item h3{font-family:var(--serif);font-size:21px;font-weight:600;line-height:1.16;margin:0 0 9px;letter-spacing:0;text-wrap:pretty}
.latest-item .meta-row{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:600;color:var(--muted);flex-wrap:wrap}
.latest-item .cat{font-size:11px}

.site-footer{position:relative;background-image:var(--isotherms-dark),linear-gradient(135deg,var(--green-d),var(--ink) 64%);background-repeat:no-repeat,no-repeat;background-position:right -60px top -40px,0 0;background-size:640px auto,auto;color:#fff;margin-top:60px}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--thermal)}
.footer-inner{padding:64px 40px 40px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand .brand{color:#fff;font-size:30px}
.footer-brand .brand b{color:var(--green-2)}
.footer-brand p{color:rgba(255,255,255,.6);font-size:15px;max-width:34ch;margin:18px 0 0;line-height:1.6}
.footer-col h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45);margin:0 0 18px;font-weight:700}
.footer-col a{display:block;color:rgba(255,255,255,.82);font-size:15px;padding:7px 0;transition:color .2s}
.footer-col a:hover{color:var(--green-2)}
.footer-bottom{padding-top:28px;display:flex;justify-content:space-between;gap:20px;font-size:13px;color:rgba(255,255,255,.5)}
.footer-legal{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:flex-end}
.footer-legal a{color:rgba(255,255,255,.66);transition:color .2s}
.footer-legal a:hover{color:var(--green-2)}

.cat-hero{padding:56px 0 14px}
.cat-hero .container{position:relative}
.cat-hero__glyph{position:absolute;right:48px;bottom:6px;width:110px;height:110px;color:var(--mint);opacity:.45;pointer-events:none}
.cat-hero__glyph svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:.9;stroke-linecap:round;stroke-linejoin:round}
.cat-hero h1{font-family:var(--serif);font-weight:800;font-size:clamp(44px,6vw,84px);margin:14px 0 0;letter-spacing:0;line-height:.98;position:relative}
.cat-hero .count{color:var(--muted);font-weight:600;font-size:15px;margin-top:16px}
.cat-hero .desc,.cat-hero .eyebrow{position:relative}
@media (max-width:900px){.cat-hero__glyph{display:none}}
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;padding:26px 0 8px;position:sticky;top:78px;z-index:40;background:var(--bg)}
.chip{border:1px solid var(--line);background:var(--card);color:var(--ink);padding:9px 18px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;transition:.2s;white-space:nowrap}
.chip:hover{border-color:var(--green-2);color:var(--green-d)}
.chip.active{background:var(--green);border-color:var(--green);color:#fff}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:42px var(--gap);padding:30px 0 10px}
.archive-shell{padding-top:54px}

.article-wrap{padding:50px 0 20px}
.article-head{max-width:820px;margin:0 auto;text-align:center}
.article-head .eyebrow{font-size:13px;justify-content:center}
.article-head h1{font-family:var(--serif);font-weight:800;font-size:clamp(38px,4.6vw,62px);line-height:1.04;letter-spacing:0;margin:20px 0 0;text-wrap:balance}
.article-head .dek{font-size:21px;line-height:1.5;color:var(--muted);margin:24px auto 0;max-width:62ch;font-weight:400}
.article-byline{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin:30px 0 0;font-size:14px;font-weight:600;color:var(--muted)}
.article-byline .author{color:var(--ink)}
.article-byline .avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--green-2),var(--green));display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;object-fit:cover}
.article-hero{height:min(58vw,620px);border-radius:var(--r-l);margin:46px 0 0}
.article-hero .media{height:100%;border-radius:var(--r-l)}
.article-body{max-width:720px;margin:48px auto 0}
.article-body p{font-size:19px;line-height:1.78;margin:0 0 26px;color:#2a2a2a}
.article-body p:first-of-type::first-letter{font-family:var(--serif);font-weight:700;float:left;font-size:74px;line-height:.78;padding:6px 14px 0 0;color:var(--green)}
.article-body blockquote{margin:38px 0;padding:6px 0 6px 28px;border-left:3px solid var(--green);font-family:var(--serif);font-style:italic;font-size:26px;line-height:1.35;color:var(--ink)}
.article-author-box{max-width:720px;margin:54px auto 0;padding:26px;border:1px solid var(--line);border-radius:var(--r-m);background:var(--card);display:grid;grid-template-columns:88px minmax(0,1fr);gap:22px;align-items:start;box-shadow:var(--shadow-1)}
.article-author-avatar{width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--mint-soft)}
.article-author-avatar .author-avatar{width:100%;height:100%;object-fit:cover;border-radius:50%}
.article-author-content h2{font-family:var(--serif);font-size:30px;line-height:1;margin:10px 0 0}
.article-author-content p{margin:12px 0 16px;color:var(--muted);font-size:15.5px;line-height:1.6}
.related{border-top:1px solid var(--line);margin-top:64px;padding-top:48px}
.related .cluster-grid{grid-template-columns:repeat(3,1fr)}
.page-shell{padding:70px 40px}
.page-content{max-width:760px;margin:0 auto}
.page-content h1{font-family:var(--serif);font-size:clamp(38px,5vw,64px);line-height:1.05;margin:0 0 28px}
.not-found-shell{min-height:calc(100vh - 78px - 320px);display:grid;place-items:center;padding-top:92px;padding-bottom:92px}
.not-found-content{text-align:center}
.not-found-content .eyebrow{justify-content:center}
.not-found-content h1{margin-top:18px;margin-bottom:18px}
.not-found-content p{max-width:54ch;margin:0 auto 28px;color:var(--muted);font-size:19px;line-height:1.65}
.not-found-cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:46px;padding:0 22px;border-radius:999px;background:var(--green);color:#fff;font-size:15px;font-weight:800;box-shadow:var(--shadow-3);transition:transform .2s,background .2s}
.not-found-cta:hover{background:var(--green-d);transform:translateY(-1px)}
.not-found-cta svg{width:18px;height:18px;flex:0 0 auto}
.author-hero{padding:66px 0 18px}
.author-hero-inner{display:grid;grid-template-columns:132px minmax(0,760px);gap:30px;align-items:center}
.author-avatar-wrap{width:132px;height:132px;border-radius:50%;overflow:hidden;background:var(--mint-soft);box-shadow:var(--shadow-2)}
.author-avatar{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}
.author-hero h1{font-family:var(--serif);font-size:clamp(42px,5vw,76px);line-height:1;margin:12px 0 0;letter-spacing:0}
.author-hero p{max-width:62ch;margin:18px 0 0;color:var(--muted);font-size:18px;line-height:1.55}

@media (max-width:1080px){
  .editorial-grid .feature{grid-column:span 12}
  .editorial-grid .side-stack{grid-column:span 12;flex-direction:row}
  .editorial-grid .side-stack .card{flex:1;flex-direction:column;--img-h:200px}
  .editorial-grid .side-stack .media{width:auto;flex:auto}
  .editorial-grid .row4{grid-template-columns:repeat(2,1fr)}
  .cluster-grid{grid-template-columns:repeat(2,1fr)}
  .category-article-grid{grid-template-columns:repeat(2,1fr)}
  .category-article-grid .category-lead{grid-column:span 2}
  .category-article-grid.layout-trio{grid-template-columns:repeat(2,1fr)}
  .category-article-grid.layout-mosaic,.category-article-grid.layout-mosaic.reverse{grid-template-columns:repeat(2,1fr)}
  .category-article-grid.layout-mosaic .category-lead{grid-column:1 / -1;grid-row:auto;--img-h:300px}
  .featured-dossier__inner{grid-template-columns:1fr;gap:34px}
  .featured-dossier__thumb{height:170px}
  .newsletter-cta{grid-template-columns:1fr;gap:28px}
  .latest-grid{grid-template-columns:1fr}
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .container{padding:0 22px}
  .site-header .header-inner{padding:0 22px}
  .nav{display:none}
  .menu-btn{display:grid}
  .mobile-nav{display:block}
  .hero-grid{grid-template-columns:1fr;gap:26px}
  .hero-media{height:300px;order:-1}
  .hero-content h1{font-size:clamp(34px,9vw,46px)}
  .editorial-grid .row4{grid-template-columns:1fr}
  .editorial-grid .side-stack{flex-direction:column}
  .editorial-grid .side-stack .card{flex-direction:row;--img-h:110px}
  .editorial-grid .side-stack .media{width:130px;flex:0 0 130px}
  .cluster-grid,.archive-grid{grid-template-columns:1fr}
  .category-index{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;margin-right:-22px}
  .category-band-head{grid-template-columns:1fr;gap:16px}
  .category-article-grid{grid-template-columns:1fr}
  .category-article-grid .category-lead{grid-column:auto;--title:25px}
  .category-article-grid .card.small{--img-h:170px}
  .category-article-grid.layout-trio,.category-article-grid.layout-mosaic,.category-article-grid.layout-mosaic.reverse{grid-template-columns:1fr}
  .category-article-grid.layout-mosaic .category-lead{grid-column:auto;grid-row:auto;--img-h:230px;--title:25px}
  .category-article-grid.layout-trio .card,.category-article-grid.layout-mosaic .card.small{--img-h:200px}
  .featured-dossier-section{padding:42px 0}
  .featured-dossier{min-height:auto}
  .featured-dossier__shade{background:linear-gradient(180deg,rgba(8,63,99,.92) 0%,rgba(23,32,42,.78) 58%,rgba(23,32,42,.92) 100%)}
  .featured-dossier__inner{padding:46px 22px;gap:28px}
  .featured-dossier__lead h2{font-size:36px}
  .featured-dossier__lead p{font-size:15.5px}
  .featured-dossier__cards{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(230px,76%);grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;margin-right:-22px;scrollbar-width:none}
  .featured-dossier__cards::-webkit-scrollbar{display:none}
  .featured-dossier__card{scroll-snap-align:start}
  .featured-dossier__thumb{height:154px}
  .newsletter-cta-section{padding:42px 0}
  .newsletter-cta{padding:24px;border-radius:var(--r-m)}
  .newsletter-cta__content h2{font-size:32px}
  .newsletter-cta__form{padding:20px}
  .cgb-ft-newsletter__fields{display:grid;grid-template-columns:1fr}
  .cgb-ft-newsletter__btn{width:100%}
  .article-author-box{grid-template-columns:1fr;padding:22px}
  .article-author-avatar{width:76px;height:76px}
  .strip{grid-auto-columns:minmax(300px,86%);padding-left:22px;padding-right:22px;margin:0 -22px}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-inner{padding-left:22px;padding-right:22px}
  .card.feature{--title:30px}
  .author-hero-inner{grid-template-columns:1fr;gap:18px}
  .author-avatar-wrap{width:104px;height:104px}
  .section{padding:38px 0}
}

/* ── Accessibility ── */
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100px;left:16px;z-index:100;background:var(--green-d);color:#fff;font-weight:700;font-size:14px;padding:12px 20px;border-radius:0 0 12px 12px;transition:top .2s}
.skip-link:focus{top:0}
:focus-visible{outline:2.5px solid var(--green);outline-offset:3px;border-radius:4px}
.icon-btn:focus-visible,.chip:focus-visible,.not-found-cta:focus-visible,.cgb-ft-newsletter__btn:focus-visible{outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}

/* ── Search overlay ── */
.search-overlay{display:block;position:fixed;inset:0;z-index:90;background:rgba(8,63,99,.55);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .25s}
.search-overlay.open{opacity:1;pointer-events:auto}
.search-overlay__panel{position:relative;max-width:680px;margin:18vh auto 0;background:var(--bg);border-radius:var(--r-l);padding:38px;box-shadow:var(--shadow-2);transform:translateY(-14px);transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.search-overlay.open .search-overlay__panel{transform:none}
.search-overlay__panel .close{position:absolute;top:16px;right:16px}
.search-overlay__form{display:flex;gap:10px;margin-top:8px}
.search-overlay__form input[type="search"]{flex:1;min-width:0;height:54px;border:1.5px solid var(--line);border-radius:999px;background:var(--card);color:var(--ink);font:600 17px var(--sans);padding:0 24px;outline:none}
.search-overlay__form input[type="search"]:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(14,107,168,.15)}
.search-overlay__form button{height:54px;border:0;border-radius:999px;background:var(--green);color:#fff;font:800 15px var(--sans);padding:0 28px;cursor:pointer;transition:background .2s}
.search-overlay__form button:hover{background:var(--green-d)}
.search-overlay__hints{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:22px;font-size:13px;font-weight:700;color:var(--muted)}
.search-overlay__results{display:none;margin-top:6px;max-height:46vh;overflow-y:auto;overscroll-behavior:contain}
.search-overlay__results.has-results{display:block}
.search-result{display:block;padding:13px 6px;border-bottom:1px solid var(--line-soft)}
.search-result:last-of-type{border-bottom:0}
.search-result__date{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.search-result__title{display:block;font-family:var(--serif);font-size:18px;font-weight:600;line-height:1.25;color:var(--ink);margin-top:3px;transition:color .2s;text-wrap:pretty}
.search-result:hover .search-result__title{color:var(--green)}
.search-overlay__all{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:6px;font-size:14px;font-weight:800;color:var(--green)}
.search-overlay__all:hover{color:var(--green-d)}
.search-overlay__empty{margin:0;padding:14px 6px;color:var(--muted);font-size:15px}
@media (max-width:760px){
  .search-overlay__panel{margin:0;border-radius:0 0 var(--r-l) var(--r-l);padding:64px 22px 28px}
  .search-overlay__form{flex-direction:column}
  .search-overlay__form button{width:100%}
}

/* ── Pagination ── */
.pagination{margin:14px 0 30px}
.pagination .nav-links{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border:1px solid var(--line);border-radius:999px;background:var(--card);color:var(--ink);font-size:14.5px;font-weight:700;transition:.2s}
.pagination .page-numbers:hover{border-color:var(--green);color:var(--green)}
.pagination .page-numbers.current{background:var(--green);border-color:var(--green);color:#fff}
.pagination .page-numbers.dots{border:0;background:none}
.pagination .screen-reader-text{display:none}

/* ── Empty states ── */
.empty-state{padding:48px 0 70px;max-width:560px}
.empty-state h2{font-family:var(--serif);font-size:clamp(26px,3vw,36px);line-height:1.1;margin:0 0 14px}
.empty-state p{color:var(--muted);font-size:17px;line-height:1.65;margin:0 0 24px}
.empty-state .chips{display:flex;gap:10px;flex-wrap:wrap}

/* ── Category hero description ── */
.cat-hero .desc{max-width:62ch;color:var(--muted);font-size:17px;line-height:1.6;margin:16px 0 0}

/* ── Home sidebar (clusters shell) ── */
.clusters-shell{display:grid;grid-template-columns:minmax(0,1fr) 312px;gap:56px;align-items:start}
.clusters-shell.no-sidebar{grid-template-columns:1fr}
.clusters-shell .category-band-head h3{font-size:clamp(28px,3vw,40px)}
.clusters-shell .category-article-grid .category-lead{--img-h:280px;--title:26px}
.clusters-shell .category-article-grid.layout-trio .card{--img-h:200px;--title:20px}
.clusters-shell .category-article-grid.layout-mosaic .category-lead{--img-h:380px;--title:28px}
.clusters-shell .category-article-grid.layout-mosaic .card.small{--img-h:160px}
.home-sidebar{align-self:stretch} /* stretch the grid item, or the sticky inner has no travel room */
.home-sidebar__inner{position:sticky;top:96px;display:flex;flex-direction:column;gap:16px}
.sidebar-module{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-m);padding:18px 20px;box-shadow:var(--shadow-1)}
.sidebar-module__title{font-family:var(--serif);font-size:19px;line-height:1.1;margin:0 0 6px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.sidebar-ranking{list-style:none;margin:0;padding:0;counter-reset:rank;display:flex;flex-direction:column}
.sidebar-ranking li{counter-increment:rank;border-bottom:1px solid var(--line-soft)}
.sidebar-ranking li:last-child{border-bottom:0}
.sidebar-ranking li:last-child a{padding-bottom:2px}
.sidebar-ranking a{display:grid;grid-template-columns:28px minmax(0,1fr);grid-template-rows:auto auto;column-gap:12px;row-gap:2px;padding:11px 0;align-items:start}
.sidebar-ranking a::before{content:counter(rank,decimal-leading-zero);grid-column:1;grid-row:1 / span 2;align-self:start;font-family:var(--serif);font-size:19px;font-weight:700;font-style:italic;color:var(--mint);line-height:1;padding-top:2px;transition:color .2s}
.sidebar-ranking a:hover::before{color:var(--green-2)}
.sidebar-ranking__cat{grid-column:2;grid-row:1;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sidebar-ranking__title{grid-column:2;grid-row:2;font-family:var(--serif);font-size:14.5px;font-weight:600;line-height:1.32;color:var(--ink);transition:color .2s;text-wrap:pretty;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.sidebar-ranking a:hover .sidebar-ranking__title{color:var(--green-d)}
.sidebar-newsletter{background:linear-gradient(135deg,var(--green-d),var(--ink) 75%);border:0;color:#fff}
.sidebar-newsletter .eyebrow{color:var(--green-2)}
.sidebar-newsletter .eyebrow::before{border-color:var(--green-2)}
.sidebar-newsletter h3{font-family:var(--serif);font-size:19px;line-height:1.15;margin:10px 0 0;color:#fff}
.sidebar-newsletter p{margin:8px 0 14px;color:rgba(255,255,255,.74);font-size:13px;line-height:1.5}
.sidebar-newsletter__btn{display:inline-flex;align-items:center;gap:9px;min-height:44px;padding:0 20px;border-radius:999px;background:var(--green-2);color:var(--ink);font-size:13px;font-weight:800;letter-spacing:.04em;transition:background .2s,transform .2s}
.sidebar-newsletter__btn:hover{background:#2FA008;transform:translateY(-1px)}
.sidebar-newsletter__btn svg{width:15px;height:15px}
@media (max-width:1080px){
  .clusters-shell{grid-template-columns:1fr;gap:40px}
  .home-sidebar__inner{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:18px;align-items:start}
  .sidebar-newsletter{grid-column:1 / -1}
}
@media (max-width:760px){
  .home-sidebar__inner{grid-template-columns:1fr}
}

/* ── Single article: body + sidebar shell ── */
.article-shell{display:grid;grid-template-columns:minmax(0,720px) 312px;gap:56px;justify-content:center;margin-top:48px}
.article-shell .article-body{max-width:none;margin:0}
.article-shell .article-author-box{max-width:none;margin:54px 0 0}
@media (max-width:1080px){
  .article-shell{grid-template-columns:1fr;gap:40px;margin-top:40px}
}

/* ════ greentechtoday · NEWS MOOD (layer di override sul tema base) ════ */
:root{
  --bg:#FFFFFF;
  --r-s:8px;
  --r-m:12px;
  --r-l:16px;
  --gap:22px;
}

/* — Header scuro da testata — */
.site-header{background:rgba(8,33,53,.97);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{height:62px}
.brand{font-size:22px}
.brand-cold{color:#fff}
.brand-hot{color:var(--green-2)}
.brand-deg{color:var(--green-2)}
.nav a{color:rgba(255,255,255,.82)}
.nav a:hover,.nav .current-menu-item>a,.nav .current-cat>a{color:#fff}
.nav a::after{background:var(--green-2)}
.site-header .icon-btn{background:transparent;border-color:rgba(255,255,255,.28);color:#fff;width:38px;height:38px}
.site-header .icon-btn:hover{border-color:var(--green-2);color:var(--green-2)}
.skip-link{top:-120px}
.filter-bar{top:62px}
.category-sections,.category-band{scroll-margin-top:88px}

/* — Ticker Ultim'ora — */
.news-ticker{background:var(--ink);color:#fff;border-bottom:2px solid var(--green-2);overflow:hidden}
.news-ticker__inner{display:flex;align-items:center;gap:18px;height:44px}
.news-ticker__label{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--green-2)}
.news-ticker__dot{width:8px;height:8px;border-radius:50%;border:2px solid var(--green-2);animation:eo-pulse 1.6s ease-in-out infinite}
@keyframes eo-pulse{0%,100%{opacity:1}50%{opacity:.35}}
.news-ticker__viewport{flex:1;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.news-ticker__track{display:flex;gap:44px;list-style:none;margin:0;padding:0;width:max-content;animation:eo-ticker 60s linear infinite}
.news-ticker:hover .news-ticker__track{animation-play-state:paused}
@keyframes eo-ticker{to{transform:translateX(-50%)}}
.news-ticker__track a{display:inline-flex;align-items:baseline;gap:10px;font-size:14px;font-weight:600;color:rgba(255,255,255,.92);white-space:nowrap}
.news-ticker__track a:hover{color:var(--green-2)}
.news-ticker__track time{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--mint)}
@media (prefers-reduced-motion:reduce){
  .news-ticker__track{animation:none}
  .news-ticker__viewport{overflow-x:auto;mask-image:none}
}

/* — Apertura news: lead + Le ultime — */
.news-lead{padding:34px 0 14px}
.news-lead__grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(300px,.85fr);gap:40px;align-items:start}
.news-lead__main{display:flex;flex-direction:column;gap:12px}
.news-lead__main .media{height:400px}
.news-lead__main .cat{font-size:11.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.news-lead__main h1{font-family:var(--serif);font-weight:800;font-size:clamp(26px,3.2vw,42px);line-height:1.08;margin:0;letter-spacing:0;text-wrap:balance}
.news-lead__main p{margin:0;color:var(--muted);font-size:16px;line-height:1.55;max-width:64ch}
.news-lead__main:hover h1{color:var(--green-d)}
.byline .when{color:#C2410C;font-weight:700}
.news-lead__list{border-left:1px solid var(--line);padding-left:28px;display:flex;flex-direction:column}
.news-lead__list h2{font-family:var(--sans);font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin:0 0 4px;display:flex;align-items:center;gap:8px}
.news-lead__list h2::before{content:"";width:8px;height:8px;border-radius:50%;border:2px solid var(--green-2)}
.news-lead__item{display:block;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.news-lead__item:last-child{border-bottom:0}
.news-lead__item .when{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#C2410C}
.news-lead__item .cat-inline{color:var(--green)}
.news-lead__item h3{font-family:var(--serif);font-size:17px;font-weight:600;line-height:1.28;margin:4px 0 0;letter-spacing:0;text-wrap:pretty;transition:color .2s}
.news-lead__item:hover h3{color:var(--green-d)}
.news-lead__row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-top:34px;padding-top:28px;border-top:1px solid var(--line)}

/* — Densità generale — */
.section{padding:40px 0}
.section.tight{padding:24px 0}
.category-section-stack{gap:40px}
.category-band{padding-top:26px}
.category-band-head{margin-bottom:20px}
.category-band-head h3{font-size:clamp(24px,2.6vw,34px)}
.card{gap:12px}
.card .card-body{gap:8px}
.card.medium{--img-h:240px;--title:20px}
.card.small{--img-h:175px;--title:17px}
.clusters-shell .category-article-grid .category-lead{--img-h:250px;--title:22px}
.featured-dossier{min-height:560px}
.featured-dossier__inner{padding:54px 40px}
.featured-dossier__lead h2{font-size:clamp(34px,4vw,54px)}
.newsletter-cta-section{padding:46px 0}
.site-footer{margin-top:44px}

@media (max-width:1080px){
  .news-lead__grid{grid-template-columns:1fr;gap:28px}
  .news-lead__list{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:18px}
  .news-lead__row{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .news-lead__main .media{height:230px}
  .news-lead__row{grid-template-columns:1fr}
  .news-ticker__inner{height:40px;gap:12px}
}

/* — Immagini quasi squadrate (solo i media, i pannelli restano morbidi) — */
.media,.latest-item .media,.featured-dossier__thumb{border-radius:4px}
.hero-media,.hero-media .media,.article-hero,.article-hero .media{border-radius:6px}
.featured-dossier__bg,.featured-dossier__bg .media{border-radius:0}

/* ════ EO IDENTITY v2 — radius 4px globale + grammatica grafica propria ════ */
:root{--r-s:4px;--r-m:4px;--r-l:4px}

/* — tutto squadrato a 4px (anche pillole, bottoni, cerchi UI) — */
.chip,.pagination .page-numbers,.not-found-cta,
.cgb-ft-newsletter__input,.cgb-ft-newsletter__btn,
.sidebar-newsletter__btn,.search-overlay__form input[type="search"],.search-overlay__form button,
.featured-dossier__label,.featured-dossier__cta,
.icon-btn,.site-header .icon-btn{border-radius:4px}
.media,.latest-item .media,.featured-dossier__thumb,
.hero-media,.hero-media .media,.article-hero,.article-hero .media{border-radius:4px}
.skip-link{border-radius:0 0 4px 4px}
.article-byline .avatar,.article-author-avatar,.article-author-avatar .author-avatar,
.author-avatar-wrap,.author-avatar,.gi-avatar-preview{border-radius:4px}
.mobile-nav .sheet{border-radius:0}

/* — via le firme FreddoCaldo: linea termica → regola da quotidiano — */
.section-head::after{background:var(--ink);height:2px;border-radius:0}
.section-head::before{content:"";position:absolute;left:0;bottom:0;width:52px;height:6px;background:var(--green-2);z-index:1}
.card .media::after{background:var(--green-2)}
.site-footer::before{display:none}

/* — punteggiatura: quadrato pieno al posto dell'anello — */
.eyebrow::before{border:0;background:var(--green);width:7px;height:7px;border-radius:1px}
.newsletter-cta .eyebrow::before,.sidebar-newsletter .eyebrow::before{background:var(--green-2);border:0}
.featured-dossier__label::before{border:0;background:var(--green-2);border-radius:1px}
.news-lead__list h2::before{border:0;background:var(--green-2);border-radius:1px;width:7px;height:7px}
.news-ticker__dot{border:0;background:var(--green-2);border-radius:1px}

/* — niente glifi-filigrana (linguaggio FC): sezioni con colore di testata — */
.band-glyph,.cat-hero__glyph{display:none}
#categoria-solare .category-band-head>div:first-child{border-left:4px solid #166100;padding-left:16px}
#categoria-eolico .category-band-head>div:first-child{border-left:4px solid #238707;padding-left:16px}
#categoria-circolare .category-band-head>div:first-child{border-left:4px solid #0F6E56;padding-left:16px}
#categoria-mobilita .category-band-head>div:first-child{border-left:4px solid #6D28D9;padding-left:16px}
#categoria-efficienza .category-band-head>div:first-child{border-left:4px solid #C2410C;padding-left:16px}
#categoria-innovazione .category-band-head>div:first-child{border-left:4px solid #1D4ED8;padding-left:16px}
body.category-solare .cat-hero h1{box-shadow:inset 6px 0 0 #166100;padding-left:22px}
body.category-eolico .cat-hero h1{box-shadow:inset 6px 0 0 #238707;padding-left:22px}
body.category-circolare .cat-hero h1{box-shadow:inset 6px 0 0 #0F6E56;padding-left:22px}
body.category-mobilita .cat-hero h1{box-shadow:inset 6px 0 0 #6D28D9;padding-left:22px}
body.category-efficienza .cat-hero h1{box-shadow:inset 6px 0 0 #C2410C;padding-left:22px}
body.category-innovazione .cat-hero h1{box-shadow:inset 6px 0 0 #1D4ED8;padding-left:22px}

/* — newsletter: pannello piatto, niente isoterme né gradiente — */
.newsletter-cta{background-image:none;background:#0F1B29;border-left:6px solid var(--green-2);box-shadow:none}
.sidebar-newsletter{background:#0F1B29;border-left:4px solid var(--green-2)}

/* — footer piatto da testata: niente gradiente, niente isoterme — */
.site-footer{background-image:none;background:#0B1320;border-top:3px solid var(--green-2);margin-top:44px}
.footer-top{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:28px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand p{margin-top:12px;font-size:14px;max-width:46ch}
.footer-col{display:flex;flex-wrap:wrap;gap:4px 22px;max-width:520px}
.footer-col h4{flex-basis:100%;margin:0 0 8px}
.footer-col a{display:inline-block;padding:4px 0;font-size:14px}
.footer-bottom{padding-top:20px;font-size:12.5px}

/* ════ EO · Archivi e ricerca in stile testata ════ */
.cat-hero{padding:36px 0 8px}
.cat-hero h1{font-size:clamp(32px,4vw,52px)}
.cat-hero .desc{font-size:15.5px;margin-top:10px}
.cat-hero .count{font-size:13px;margin-top:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.archive-shell{padding-top:36px}
.filter-bar{padding:18px 0 8px}

/* lista densa: thumb sinistra, contenuto destra, regole orizzontali */
.archive-list{display:flex;flex-direction:column;padding:22px 0 10px}
.archive-item{display:grid;grid-template-columns:280px minmax(0,1fr);gap:24px;padding:22px 0;border-top:1px solid var(--line);align-items:start}
.archive-item:first-child{border-top:0;padding-top:6px}
.archive-item .media{height:165px}
.archive-item__body{display:flex;flex-direction:column;gap:7px}
.archive-item__meta{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.archive-item__meta .when{color:#C2410C}
.archive-item__meta .cat{color:var(--green)}
.archive-item h2{font-family:var(--serif);font-size:clamp(19px,2vw,25px);font-weight:700;line-height:1.18;margin:0;letter-spacing:0;text-wrap:pretty;transition:color .2s}
.archive-item:hover h2{color:var(--green-d)}
.archive-item p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.55;max-width:72ch;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.archive-item__author{font-size:12.5px;font-weight:700;color:var(--ink);margin-top:2px}
.archive-item .media::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--green-2);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.archive-item:hover .media::after{transform:scaleX(1)}
.archive-item:hover .media img{transform:scale(1.04)}

/* form di affinamento nel search */
.search-hero .count{margin-top:8px}
.search-refine{display:flex;gap:10px;margin-top:18px;max-width:560px}
.search-refine input[type="search"]{flex:1;min-width:0;height:46px;border:1.5px solid var(--line);border-radius:4px;background:var(--card);color:var(--ink);font:600 15px var(--sans);padding:0 16px;outline:none}
.search-refine input[type="search"]:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(14,107,168,.12)}
.search-refine button{height:46px;border:0;border-radius:4px;background:var(--green);color:#fff;font:800 13.5px var(--sans);padding:0 22px;cursor:pointer;transition:background .2s}
.search-refine button:hover{background:var(--green-d)}

/* autore: job title */
.author-job{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#C2410C;margin-top:8px}
.author-hero{padding:44px 0 10px}
.author-hero h1{font-size:clamp(34px,4.4vw,56px)}

@media (max-width:760px){
  .archive-item{grid-template-columns:1fr;gap:12px}
  .archive-item .media{height:190px}
  .archive-item p{-webkit-line-clamp:3}
  .search-refine{flex-direction:column}
  .search-refine button{width:100%}
}

/* ════ EO PALETTE v3 — basta blu FreddoCaldo: ink + ambra elettrica ════ */
:root{
  --green:#166100;        /* primario testuale: ambra scura (link, kicker, chip attivi) */
  --green-d:#1F2937;      /* scuro neutro per hover titoli */
  --green-2:#238707;      /* accento: ambra elettrica (CTA, ticker, sweep) */
  --mint:#8FD46A;         /* numerazioni e tempi su fondo scuro */
  --mint-soft:#E6F4DA;    /* fondi placeholder */
  --shadow-3:0 30px 60px -28px rgba(35,135,7,0.28);
}

/* header: da navy FC a quasi-nero */
.site-header{background:rgba(16,21,29,.97)}
.brand-hot,.brand-deg{color:#238707}
.footer-brand .brand-hot,.footer-brand .brand-deg{color:#238707}

/* residui arancio/navy FC espliciti */
.cgb-ft-newsletter__btn:hover,.sidebar-newsletter__btn:hover,
.featured-dossier__lead:hover .featured-dossier__cta{background:#2FA008}
.cgb-ft-newsletter__input:focus{border-color:#238707;box-shadow:0 0 0 3px rgba(35,135,7,.2)}
.featured-dossier__shade{background:linear-gradient(90deg,rgba(13,17,23,.92) 0%,rgba(16,21,29,.74) 42%,rgba(16,21,29,.34) 100%),linear-gradient(180deg,rgba(16,21,29,.2) 0%,rgba(16,21,29,.74) 100%)}
.featured-dossier__card:hover{border-color:rgba(35,135,7,.85)}
.newsletter-cta,.sidebar-newsletter{background:#141B24}
.search-overlay{background:rgba(16,21,29,.55)}
.search-overlay__form input[type="search"]:focus,.search-refine input[type="search"]:focus{border-color:#166100;box-shadow:0 0 0 3px rgba(22,97,0,.14)}
.byline .when,.archive-item__meta .when,.news-lead__item .when,.author-job{color:#166100}
.news-ticker{border-bottom-color:#238707}
.site-footer{border-top-color:#238707}
.skip-link{background:#1F2937}

/* — Cookie banner SAS allineato alla linea EO (ink + ambra, 4px) — */
.sas-cookie-consent__inner{background:rgba(16,21,29,.97);border-radius:4px;border:1px solid rgba(35,135,7,.3)}
.sas-cookie-consent__desc a{color:#8FD46A}
.sas-cookie-toggle{border-radius:4px}
.sas-cookie-toggle input[type="checkbox"]{accent-color:#238707}
.sas-cookie-consent__btn{border-radius:4px}
.sas-cookie-consent__btn--accept-all{background:#238707;color:#10151D}
.sas-cookie-consent__btn--save{background:rgba(35,135,7,.12);color:#8FD46A;border:1px solid rgba(35,135,7,.35)}
.sas-cookie-settings-link{border-radius:4px;background:rgba(16,21,29,.92);border:1px solid rgba(35,135,7,.3)}
.sas-cookie-settings-link:hover{background:#10151D}

/* ════ EO · Link sempre sottolineati + hover ════ */
a{text-decoration:underline;text-decoration-color:rgba(22,97,0,.4);text-decoration-thickness:1px;text-underline-offset:3px;transition:color .2s,text-decoration-color .2s}
a:hover{text-decoration-color:currentColor}
/* link nella prosa: colore primario, ben riconoscibili */
.article-body a,.page-content a{color:#166100;font-weight:600}
.article-body a:hover,.page-content a:hover{color:#0F4A00}
/* componenti con affordance propria: niente underline (hover già presente) */
.brand,.nav a,.chip,.icon-btn,.skip-link,
.card,.latest-item,.archive-item,.search-result,
.news-lead__main,.news-lead__item,.sidebar-ranking a,
.featured-dossier__lead,.featured-dossier__card,
.pagination .page-numbers,.not-found-cta,
.cgb-ft-newsletter__btn,.sidebar-newsletter__btn,
.see-all,.hero-cta,.hero-grid,.news-ticker__track a,
.mobile-nav .sheet a,.author{text-decoration:none}
/* hover mancante: voci del menu mobile */
.mobile-nav .sheet a:hover{color:#166100}

/* ════ EO · Fix mobile: footer (padding azzerato da .container nel MQ) + stack ════ */
.container.footer-inner{padding:48px 40px 36px}
@media (max-width:760px){
  .container.footer-inner{padding:36px 22px 28px}
  .footer-top{flex-direction:column;gap:24px;padding-bottom:24px}
  .footer-col{flex-direction:column;align-items:flex-start;gap:2px;max-width:none}
  .footer-col h4{margin-bottom:8px}
  .footer-col a{padding:6px 0;font-size:15px}
  .footer-bottom{flex-direction:column;gap:10px;align-items:flex-start}
  .footer-legal{justify-content:flex-start}
  .newsletter-cta{grid-template-columns:1fr;gap:22px;padding:22px;border-left-width:4px}
  .newsletter-cta__content h2{font-size:26px}
  .newsletter-cta__form{padding:18px}
}

/* ── Fix mobile: dossier impilato (non carosello) + mosaico reverse a colonna singola ── */
@media (max-width:760px){
  .featured-dossier__cards{display:grid;grid-auto-flow:row;grid-auto-columns:unset;grid-template-columns:1fr;gap:14px;overflow-x:visible;scroll-snap-type:none;padding-bottom:0;margin-right:0}
  .featured-dossier__card{scroll-snap-align:unset}
  .featured-dossier__thumb{height:170px}
  .category-article-grid.layout-mosaic.reverse .category-lead{grid-column:auto;grid-row:auto}
}

/* greentechtoday wordmark (rebrand) */
.brand-cold{color:#3FBF6F}
.brand-mid{color:#fff;letter-spacing:0}
.brand-hot{color:#238707}
.footer-brand .brand-cold{color:#3FBF6F}
.footer-brand .brand-mid{color:#fff}
.footer-brand .brand-hot{color:#238707}

/* greentechtoday logo immagine */
.custom-logo-link{display:inline-flex;align-items:center;line-height:0}
.custom-logo{height:40px;width:auto;display:block}
.footer-brand .custom-logo{height:46px}
@media(max-width:760px){.custom-logo{height:34px}}

/* ===== HAMBURGER MENU OVERLAY (sempre attivo, card categorie con thumb) ===== */
.site-header .nav{display:none!important}
.menu-btn{display:inline-flex!important}
.mobile-nav{position:fixed;inset:0;z-index:95;background:rgba(8,18,32,.55);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .28s;overflow-y:auto;padding:24px}
.mobile-nav.open{opacity:1;pointer-events:auto}
.menu-panel{background:var(--bg,#fff);width:100%;max-width:1080px;margin:0 auto;border-radius:var(--r-m,6px);padding:26px 30px 32px;box-shadow:0 40px 90px -24px rgba(0,0,0,.55);transform:translateY(-18px);transition:transform .32s cubic-bezier(.2,.7,.2,1)}
.mobile-nav.open .menu-panel{transform:none}
.menu-panel__head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:18px;margin-bottom:22px;border-bottom:1px solid var(--line,#e5e7eb)}
.menu-panel__head .brand-logo,.menu-panel__head .custom-logo{height:34px!important;width:auto!important}
.menu-panel__head .close{position:static}
.menu-panel__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.menu-card{display:flex;flex-direction:column;border:1px solid var(--line,#e5e7eb);border-radius:var(--r-m,6px);overflow:hidden;background:var(--card,#fff);transition:border-color .2s,transform .2s,box-shadow .2s;text-decoration:none!important}
.menu-card:hover{border-color:var(--blue,#1462A8);transform:translateY(-3px);box-shadow:0 16px 32px -18px rgba(0,0,0,.4)}
.menu-card__media{aspect-ratio:16/9;overflow:hidden;border-radius:0;background:var(--mint-soft,#eef)}
.menu-card__media img,.menu-card__media .gi-placeholder{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.menu-card:hover .menu-card__media img{transform:scale(1.06)}
.menu-card__body{padding:11px 14px 13px}
.menu-card__name{display:block;font-family:var(--serif,inherit);font-weight:700;font-size:15.5px;line-height:1.25;color:var(--ink,#15324F)}
.menu-card__count{display:block;margin-top:5px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--blue,#1462A8)}
.menu-panel__foot{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line,#e5e7eb)}
.menu-panel__foot a{font-weight:600;font-size:14px;color:var(--ink,#15324F);padding:9px 18px;border:1px solid var(--line,#e5e7eb);border-radius:var(--r-s,4px);text-decoration:none!important;transition:.2s}
.menu-panel__foot a:hover{border-color:var(--blue,#1462A8);color:var(--blue,#1462A8)}
@media(max-width:820px){.menu-panel__grid{grid-template-columns:1fr 1fr}.menu-panel{padding:20px}}
@media(max-width:520px){.menu-panel__grid{grid-template-columns:1fr}.mobile-nav{padding:12px}}

/* EO: testata menu scura per logo bianco */
.menu-panel__head{background:#10151D;margin:-26px -30px 24px;padding:18px 30px;border-bottom:0;border-radius:var(--r-m,6px) var(--r-m,6px) 0 0}
.menu-panel__head .close{color:#fff;border-color:rgba(255,255,255,.35)}
.menu-panel__head .close:hover{background:rgba(255,255,255,.12)}

/* menu-fix-display: hamburger overlay sempre renderizzato (override vecchio display:none desktop) */
.mobile-nav{display:block}

/* MENU LISTA nome+desc (no thumb) */
.menu-panel{max-width:760px}
.menu-panel__grid{grid-template-columns:1fr 1fr!important;gap:0 40px!important}
.menu-item{display:block;padding:15px 2px;border-top:1px solid var(--line,#e5e7eb);text-decoration:none!important;transition:padding .15s}
.menu-item:hover{padding-left:8px}
.menu-item__name{display:block;font-family:var(--serif,inherit);font-weight:700;font-size:17.5px;line-height:1.2;color:var(--ink,#15324F);transition:color .2s}
.menu-item:hover .menu-item__name{color:var(--blue,#1462A8)}
.menu-item__desc{display:block;margin-top:4px;font-size:13px;line-height:1.45;color:var(--muted,#5A6675)}
@media(max-width:680px){.menu-panel__grid{grid-template-columns:1fr!important}}

.menu-panel__head .close{background:transparent!important}
/* ════ BRAND-GREEN-FIX-2026: hamburger centrato + filter-bar mobile compatta ════ */
.menu-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important}
@media(max-width:760px){
  .filter-bar{flex-wrap:nowrap!important;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;position:static!important;top:auto!important;padding:12px 0 6px}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-bar .chip{flex:0 0 auto}
}
/* ════ HEADER-NON-FULLWIDTH: l'inner rispetta il container come il resto del sito ════ */
.site-header .header-inner{max-width:var(--maxw);margin-left:auto;margin-right:auto}
