/* ===================================================================
   Consorzio IN.TE.SE. — Homepage DARK + LIME (mobile-first)
   Adattamento stile "agency" dark con accento verde brand.
   Brand: verde #70C931 · grigio #838383
   =================================================================== */

:root{
  --bg:#101210;
  --bg-soft:#16191500;
  --card:#181c17;
  --card-2:#1f241d;
  --line:#2b302a;
  --line-2:#363c34;
  --green:#7bd23c;
  --green-bri:#9aec4d;
  --green-d:#4f8a1f;
  --ink:#10130e;          /* text on green */
  --text:#f2f5ef;
  --muted:#9aa295;
  --muted-2:#727a6e;
  --white:#ffffff;
  --on-white:#14171a;
  --on-white-mut:#5f6660;
  --blue:#4a93cf;
  --r:24px;
  --r-lg:32px;
  --pad:20px;            /* mobile gutter */
  /* typography — corporate/institutional pairing */
  --font-head:"Libre Franklin",system-ui,sans-serif;
  --font-body:"Source Sans 3",system-ui,sans-serif;
  --font-label:"Libre Franklin",system-ui,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-head);margin:0;line-height:1.08;
  letter-spacing:-.02em;font-weight:700;}
p{margin:0;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
ul{margin:0;padding:0;list-style:none;}
.wrap{max-width:1240px;margin:0 auto;padding:0 var(--pad);}

.eyebrow{font-family:var(--font-label);font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:500;color:var(--green);}
.spark{color:var(--green);font-size:.8em;vertical-align:.08em;}
.hl{background:var(--green);color:var(--ink);padding:.04em .28em;border-radius:7px;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;}

/* placeholder */
.ph{background:repeating-linear-gradient(45deg,#23271f,#23271f 12px,#282d24 12px,#282d24 24px);
  display:flex;align-items:center;justify-content:center;text-align:center;color:#79806f;
  font-family:var(--font-label);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;padding:16px;}
.ph.light{background:repeating-linear-gradient(45deg,#e7eae2,#e7eae2 12px,#eef1ea 12px,#eef1ea 24px);
  color:#9aa39a;}
.imgwrap{overflow:hidden;padding:0;}
.imgwrap img{width:100%;height:100%;object-fit:cover;display:block;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-head);
  font-weight:600;font-size:15px;padding:14px 22px;border-radius:40px;cursor:pointer;
  border:none;transition:transform .15s,background .15s,color .15s;white-space:nowrap;}
.btn svg{width:15px;height:15px;flex:none;}
.btn-green{background:var(--green);color:var(--ink);}
.btn-green:hover{background:var(--green-bri);}
.btn-dark{background:#14171266;color:var(--text);border:1px solid var(--line-2);}
.btn-dark:hover{border-color:var(--green);color:var(--green);}
.btn-ondark{background:#1c211a;color:var(--text);border:1px solid var(--line-2);}
.btn-light{background:var(--on-white);color:#fff;}
.btn-ghost{background:transparent;color:var(--on-white);border:1px solid #d7ddd2;}

/* =================== NAV =================== */
.nav-outer{position:sticky;top:0;z-index:50;padding:14px var(--pad);}
.nav{background:#15181496;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:44px;
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 9px 9px 18px;max-width:1240px;margin:0 auto;}
.nav .brand{display:flex;align-items:center;gap:12px;}
.nav .brand-mark{height:46px;width:auto;transform-origin:center;
  transition:transform .7s cubic-bezier(.34,1.4,.4,1),filter .3s;}
.nav .brand-text{height:19px;width:auto;transition:opacity .3s;display:none;}
.nav .brand:hover .brand-mark{transform:rotate(360deg) scale(1.07);
  filter:drop-shadow(0 0 10px rgba(123,210,60,.55));}
.nav .brand:active .brand-mark{transform:rotate(360deg) scale(.96);}
/* entrance (added by JS on load, removed on animationend) */
.brand-mark.spin-in{animation:logoMarkIn 1s cubic-bezier(.2,.8,.25,1) both;}
.brand-text.fade-in{animation:logoTextIn .6s ease .42s both;}
@keyframes logoMarkIn{
  0%{opacity:0;transform:rotate(-160deg) scale(.35);}
  55%{opacity:1;}
  100%{opacity:1;transform:rotate(0) scale(1);}}
@keyframes logoTextIn{
  0%{opacity:0;transform:translateX(-12px);}
  100%{opacity:1;transform:translateX(0);}}
@media (prefers-reduced-motion: reduce){
  .brand-mark.spin-in,.brand-text.fade-in{animation:none;}
  .nav .brand:hover .brand-mark{transform:scale(1.05);}
}
.nav-links{display:none;}
.nav-cta{display:flex;align-items:center;gap:8px;}
.nav-cta .btn{padding:11px 18px;font-size:14px;}
.burger{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);
  background:transparent;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);}
.burger svg{width:18px;height:18px;}

/* mobile menu sheet */
.sheet{position:fixed;inset:0;z-index:60;background:#0d0f0ce6;backdrop-filter:blur(8px);
  display:none;flex-direction:column;padding:90px 24px 30px;}
.sheet.open{display:flex;}
.sheet a{font-family:var(--font-head);font-size:26px;font-weight:600;
  padding:14px 0;border-bottom:1px solid var(--line);}
.sheet a:last-of-type{border-bottom:none;}
.sheet .close{position:absolute;top:26px;right:24px;width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line-2);background:transparent;color:var(--text);font-size:20px;cursor:pointer;}

/* =================== HERO =================== */
.hero{padding:8px var(--pad) 0;display:flex;justify-content:center;}
.hero-card{background:var(--white);color:var(--on-white);border-radius:var(--r-lg);
  padding:34px 24px 30px;position:relative;overflow:hidden;width:100%;max-width:1240px;}
.hero-card .eyebrow{color:var(--green-d);}
.hero h1{font-size:clamp(32px,8.5vw,40px);color:var(--on-white);margin:16px 0 0;
  font-weight:700;letter-spacing:-.03em;}
.hero .lead{color:var(--on-white-mut);font-size:16px;margin:16px 0 22px;}
.hero .cta{display:flex;flex-wrap:wrap;gap:10px;}
.hero-photo{margin:26px -4px 0;position:relative;}
.hero-photo .circle{aspect-ratio:1/1;border-radius:50%;overflow:hidden;
  background:var(--green);}
.hero-photo .circle .ph{height:100%;width:100%;}
.hero-photo .circle img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-rating{position:absolute;right:6px;top:14px;background:#fff;border-radius:16px;
  padding:10px 14px;box-shadow:0 8px 24px rgba(0,0,0,.14);text-align:center;}
.hero-rating .stars{color:var(--green-d);font-size:13px;letter-spacing:2px;}
.hero-rating b{font-family:var(--font-head);font-size:18px;display:block;color:var(--on-white);line-height:1.1;}
.hero-rating span{font-size:11px;color:var(--on-white-mut);}
.hero-deco{position:absolute;font-size:26px;color:var(--green);}

/* =================== STATS =================== */
.stats{margin:14px var(--pad) 0;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:8px 6px;display:grid;grid-template-columns:1fr 1fr;}
.stats .it{padding:18px 16px;}
.stats .n{font-family:var(--font-head);font-weight:700;font-size:30px;letter-spacing:-.03em;}
.stats .n em{color:var(--green);font-style:normal;}
.stats .l{font-size:13px;color:var(--muted);margin-top:2px;}

/* =================== SECTION base =================== */
.section{padding:56px 0;}
.section .head{margin-bottom:28px;}
.section .head h2{font-size:clamp(28px,7vw,34px);}
.section .head .sub{color:var(--muted);margin-top:14px;font-size:16px;}

/* intro / network blurb */
.intro h2 .hl{font-size:.95em;}
.intro .copy{color:var(--muted);font-size:16px;margin-top:18px;}
.intro-imgs{display:grid;grid-template-columns:1fr;gap:14px;margin-top:26px;}
.intro-imgs .ph{border-radius:var(--r);height:200px;}
.intro-imgs .tag{position:relative;}
.intro-imgs .tag .lab{position:absolute;left:14px;bottom:14px;background:var(--green);
  color:var(--ink);font-family:var(--font-label);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;padding:7px 12px;border-radius:8px;}

/* =================== SERVIZI dark card =================== */
.serv{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px 22px;}
.serv .eyebrow{margin-bottom:16px;}
.serv h2{font-size:clamp(26px,6.5vw,32px);}
.serv .copy{color:var(--muted);margin:16px 0 24px;font-size:15px;}
.serv-list{display:flex;flex-direction:column;gap:12px;}
.serv-item{display:flex;flex-direction:column;}
.serv-row{display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  font-family:inherit;color:var(--text);background:var(--card-2);
  border:1px solid var(--line);border-radius:40px;padding:14px 16px;cursor:pointer;
  transition:border-color .15s,background .15s;}
.serv-row:hover{border-color:var(--green);}
.serv-row[aria-expanded="true"]{border-color:var(--green);}
.serv-row .ix{font-family:var(--font-label);font-size:13px;color:var(--green);
  width:30px;flex:none;}
.serv-row .t{flex:1;font-family:var(--font-head);font-weight:600;font-size:16px;}
.serv-row .go{width:34px;height:34px;border-radius:50%;background:var(--green);
  color:var(--ink);display:flex;align-items:center;justify-content:center;flex:none;
  transition:transform .3s cubic-bezier(.2,.8,.25,1);}
.serv-row .go svg{width:15px;height:15px;}
.serv-row[aria-expanded="true"] .go{transform:rotate(180deg);}
.serv-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s ease;}
.serv-panel.open{grid-template-rows:1fr;}
.serv-panel-in{overflow:hidden;}
.serv-panel p{color:var(--muted);font-size:14.5px;line-height:1.6;padding:14px 22px 6px 60px;}
.serv-extra{margin-top:18px;display:grid;gap:14px;}
.serv-photo{border-radius:var(--r);overflow:hidden;height:200px;}
.expert{background:var(--green);color:var(--ink);border-radius:var(--r);padding:22px;}
.expert h3{font-size:20px;font-family:var(--font-head);}
.expert p{font-size:14px;margin:8px 0 16px;color:#1c3010;}
.expert .btn-light{background:var(--ink);}

/* =================== FORMAZIONE FINANZIATA band =================== */
.ff{background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 22px;}
.badge-fi{display:inline-flex;align-items:center;gap:10px;background:#0e120c;
  border:1px solid var(--line-2);border-radius:40px;padding:8px 8px 8px 16px;
  font-family:var(--font-label);font-size:12px;letter-spacing:.04em;color:var(--muted);
  margin-bottom:20px;}
.badge-fi b{background:var(--green);color:var(--ink);padding:5px 10px;border-radius:30px;
  font-family:var(--font-head);font-weight:700;}
.ff h2{font-size:clamp(26px,6.5vw,32px);}
.ff p{color:var(--muted);margin:16px 0 22px;}
.ff-points{display:flex;flex-direction:column;gap:10px;margin-bottom:22px;}
.ff-points li{display:flex;gap:12px;align-items:flex-start;font-size:15px;}
.ff-points .dot{color:var(--green);flex:none;margin-top:3px;}

/* plans chips */
.plans{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.plan{font-family:var(--font-label);font-size:12px;border:1px solid var(--line-2);
  border-radius:30px;padding:8px 14px;color:var(--muted);}
.plan b{color:var(--text);font-family:var(--font-head);}

/* =================== RETE / partner =================== */
.net-grid{display:grid;grid-template-columns:1fr;gap:14px;}
.net-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:24px;transition:border-color .15s;}
.net-card:hover{border-color:var(--green);}
.net-card .logo{width:54px;height:54px;border-radius:14px;background:var(--card-2);
  border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-weight:700;color:var(--green);margin-bottom:16px;}
.net-card .logo.logo-img{padding:9px;}
.net-card .logo.logo-img img{width:100%;height:100%;object-fit:contain;display:block;opacity:.92;}
.net-card h3{font-size:19px;}
.net-card p{color:var(--muted);font-size:14px;margin-top:10px;}
.net-card.iul{background:var(--card-2);border-color:var(--blue);}
.net-card.iul .logo{color:var(--blue);border-color:var(--blue);}
.net-card .logo.logo-iul{width:auto;min-width:104px;height:64px;padding:0;background:transparent;border:none;border-radius:0;}
.net-card .logo.logo-iul img{height:100%;width:auto;object-fit:contain;display:block;}
.net-card .tag-iul{display:inline-block;font-family:var(--font-label);font-size:11px;
  letter-spacing:.08em;color:#cfe6f5;background:var(--blue);padding:5px 11px;
  border-radius:30px;margin-bottom:14px;}

/* =================== BLOG / APPROFONDIMENTI =================== */
.blog .head{display:flex;flex-direction:column;gap:18px;margin-bottom:28px;}
.blog .head .head-top{display:flex;flex-direction:column;gap:14px;}
.blog .head .btn{align-self:flex-start;}

/* featured post */
.post-feat{display:grid;grid-template-columns:1fr;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  transition:border-color .15s;margin-bottom:14px;}
.post-feat:hover{border-color:var(--green);}
.post-feat .media{position:relative;height:220px;}
.post-feat .media .ph,.post-feat .media img{height:100%;width:100%;object-fit:cover;}
.post-feat .pill-cat{position:absolute;left:16px;top:16px;}
.post-feat .body{padding:26px 22px 28px;}
.post-feat h3{font-size:clamp(22px,5.6vw,28px);font-family:var(--font-head);letter-spacing:-.02em;
  margin-top:14px;line-height:1.18;}
.post-feat .excerpt{color:var(--muted);font-size:15px;margin-top:14px;}

/* card grid */
.blog-grid{display:grid;grid-template-columns:1fr;gap:14px;}
.post-card{display:flex;flex-direction:column;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:border-color .15s,transform .15s;}
.post-card:hover{border-color:var(--green);}
.post-card .media{height:170px;position:relative;}
.post-card .media .ph,.post-card .media img{height:100%;width:100%;object-fit:cover;}
.post-card .pill-cat{position:absolute;left:14px;top:14px;}
.post-card .body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1;}
.post-card h3{font-size:18px;font-family:var(--font-head);letter-spacing:-.01em;
  margin-top:10px;line-height:1.25;}
.post-card .excerpt{color:var(--muted);font-size:14px;margin-top:10px;flex:1;}

/* shared post bits */
.pill-cat{display:inline-block;font-family:var(--font-label);font-size:11px;
  letter-spacing:.07em;text-transform:uppercase;background:var(--green);color:var(--ink);
  padding:6px 11px;border-radius:30px;font-weight:500;}
.post-meta{display:flex;align-items:center;gap:10px;font-family:var(--font-label);
  font-size:12px;color:var(--muted-2);letter-spacing:.03em;}
.post-meta .dot-sep{width:3px;height:3px;border-radius:50%;background:var(--muted-2);}
.post-more{display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-family:var(--font-head);font-weight:600;font-size:14px;color:var(--green);}
.post-more svg{width:14px;height:14px;transition:transform .15s;}
.post-feat:hover .post-more svg,.post-card:hover .post-more svg{transform:translateX(4px);}

/* =================== BIG TYPE band =================== */
.bigtype{padding:50px 0;text-align:center;}
.bigtype h2{font-family:var(--font-head);font-weight:700;font-size:clamp(34px,11vw,58px);
  letter-spacing:-.03em;line-height:1.05;}
.bigtype h2 .spark{font-size:.55em;vertical-align:.22em;margin:0 .05em;}
.bigtype .rule{display:flex;align-items:center;gap:14px;justify-content:center;
  margin-top:24px;color:var(--muted-2);font-family:var(--font-label);font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;}
.bigtype .rule .ln{height:1px;width:40px;background:var(--line-2);}

/* =================== CONTATTI green block =================== */
.contact{background:var(--green);color:var(--ink);border-radius:var(--r-lg);
  padding:34px 22px;margin:0 var(--pad);}
.contact .eyebrow{color:#234012;}
.contact h2{font-size:clamp(28px,7.5vw,38px);color:var(--ink);margin-top:12px;}
.contact p{color:#1f3a10;margin:14px 0 24px;font-size:15px;}
.form{display:grid;gap:12px;}
.form .field{display:flex;flex-direction:column;gap:6px;}
.form label{font-family:var(--font-label);font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:#234012;}
.form input,.form select,.form textarea{background:#0f120e;border:1px solid #1c2a12;
  border-radius:14px;padding:14px 16px;color:var(--text);font-family:inherit;font-size:15px;}
.form input::placeholder,.form textarea::placeholder{color:#6c7464;}
.form textarea{min-height:96px;resize:vertical;}
.form .row2{display:grid;grid-template-columns:1fr;gap:12px;}
.form .check{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:#1f3a10;}
.form .check input{width:18px;height:18px;flex:none;margin-top:2px;}
.form .btn-submit{background:var(--ink);color:#fff;justify-content:center;padding:16px;
  font-size:16px;margin-top:4px;}

/* =================== FOOTER =================== */
.footer{padding:50px var(--pad) 30px;}
.footer .top{display:grid;gap:30px;}
.footer .brand-lock{display:inline-flex;align-items:center;gap:13px;margin-bottom:18px;}
.footer .brand-mark{height:54px;width:auto;transform-origin:center;
  transition:transform .7s cubic-bezier(.34,1.4,.4,1),filter .3s;}
.footer .brand-text{height:22px;width:auto;}
.footer .brand-lock:hover .brand-mark{transform:rotate(360deg) scale(1.06);
  filter:drop-shadow(0 0 11px rgba(123,210,60,.5));}
@media (prefers-reduced-motion: reduce){
  .footer .brand-lock:hover .brand-mark{transform:scale(1.05);}
}
.footer .brand p{color:var(--muted);font-size:14px;max-width:34ch;}
.footer .socials{display:flex;gap:10px;margin-top:18px;}
.footer .soc{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);
  background:var(--card);display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:color .15s,border-color .15s,transform .15s;}
.footer .soc svg{width:18px;height:18px;}
.footer .soc:hover{color:var(--green);border-color:var(--green);transform:translateY(-2px);}
.footer .col h4{font-family:var(--font-label);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted-2);font-weight:500;margin-bottom:14px;}
.footer .col a,.footer .col p{display:block;color:var(--muted);font-size:14px;padding:5px 0;}
.footer .col a:hover{color:var(--green);}
.footer .legal{border-top:1px solid var(--line);margin-top:36px;padding-top:22px;
  display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between;
  font-family:var(--font-label);font-size:11px;color:var(--muted-2);letter-spacing:.03em;}
.footer .legal-links a{color:var(--muted);}
.footer .legal-links a:hover{color:var(--green);}

/* ===================================================================
   DESKTOP  ≥ 920px
   =================================================================== */
@media (min-width:920px){
  :root{--pad:40px;}
  .nav-links{display:flex;gap:30px;font-size:15px;font-weight:500;}
  .nav-links a:hover{color:var(--green);}
  .nav .brand-text{display:block;}
  .burger{display:none;}
  .nav{padding:10px 10px 10px 24px;}

  .hero{padding:18px 40px 0;}
  .hero-card{padding:54px 56px 50px;display:grid;
    grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;}
  .hero-card .txt{align-self:center;}
  .hero h1{font-size:clamp(44px,4.6vw,64px);margin-top:18px;}
  .hero .lead{font-size:18px;max-width:42ch;}
  .hero-photo{margin:0;}
  .hero-photo .circle{max-width:420px;margin-left:auto;}

  .stats{margin:18px 40px 0;grid-template-columns:repeat(4,1fr);padding:10px;}
  .stats .it{padding:24px;border-right:1px solid var(--line);}
  .stats .it:last-child{border-right:none;}
  .stats .n{font-size:38px;}

  .section{padding:90px 0;}
  .section .head{max-width:60ch;}

  .intro-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;}
  .intro-imgs{grid-template-columns:1fr 1fr;margin-top:0;}
  .intro-imgs .ph{height:300px;}

  .serv{padding:54px;display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start;}
  .serv-head{grid-column:1/-1;}
  .serv-extra{margin-top:0;}
  .serv-photo{height:260px;}

  .ff{padding:54px;}
  .ff-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:start;}

  .net-grid{grid-template-columns:repeat(2,1fr);}
  .net-card.iul{grid-column:1/-1;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;}

  .blog .head{flex-direction:row;align-items:flex-end;justify-content:space-between;}
  .blog .head .head-top{flex:1;}
  .blog .head .btn{margin-bottom:4px;}
  .post-feat{grid-template-columns:1.05fr .95fr;align-items:stretch;margin-bottom:18px;}
  .post-feat .media{height:auto;min-height:320px;}
  .post-feat .body{padding:42px 44px;display:flex;flex-direction:column;justify-content:center;}
  .post-feat .excerpt{font-size:16px;max-width:46ch;}
  .blog-grid{grid-template-columns:repeat(3,1fr);gap:20px;}
  .post-card .media{height:190px;}

  .contact{margin:0 40px;padding:60px;}
  .contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
  .form .row2{grid-template-columns:1fr 1fr;}

  .footer{padding:70px 40px 36px;}
  .footer .top{grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;}
}

@media (min-width:920px){
  .bigtype h2{font-size:clamp(58px,8vw,108px);}
}
