/* =========================================================
   traslochi.news — design system
   Palette: notte inchiostro + turchese/idro-gradienti
   Display: Space Grotesk | Body: Inter | Dati: IBM Plex Mono
   ========================================================= */

:root{
  --ink:#0A2540;
  --ink-soft:#123B52;
  --ink-700:#1B4459;
  --turq:#14B8A6;
  --turq-light:#5EEAD4;
  --turq-pale:#E3FBF6;
  --teal-deep:#0E7490;
  --violet-tech:#6D5BD0;
  --amber-data:#F5A623;
  --coral-alert:#FF6B4A;
  --bg:#F5FAF9;
  --paper:#FFFFFF;
  --line:#DCEDEA;
  --ink-muted:#5B7A85;
  --radius-lg:24px;
  --radius-md:16px;
  --radius-sm:10px;
  --shadow-soft:0 20px 45px -25px rgba(10,37,64,.35);
  --shadow-card:0 12px 30px -18px rgba(10,37,64,.28);
  --grad-hero:linear-gradient(135deg,#0A2540 0%,#0E7490 46%,#14B8A6 100%);
  --grad-turq:linear-gradient(120deg,#14B8A6 0%,#5EEAD4 100%);
  --grad-tech:linear-gradient(120deg,#6D5BD0 0%,#14B8A6 100%);
  --font-display:"Space Grotesk",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-mono:"IBM Plex Mono",monospace;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--teal-deep);text-decoration:none;}
a.inline-link{
  color:var(--teal-deep);
  text-decoration:underline;
  text-decoration-color:var(--turq-light);
  text-underline-offset:3px;
  font-weight:600;
}
a.inline-link:hover{color:var(--ink);}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);margin:0 0 .5em;letter-spacing:-.01em;}
.mono{font-family:var(--font-mono);}
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:12.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--teal-deep);
  background:var(--turq-pale);border:1px solid var(--turq-light);
  padding:6px 14px;border-radius:999px;
}
section{padding:72px 0;}
@media(max-width:720px){section{padding:48px 0;}}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,250,249,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:1180px;margin:0 auto;}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--ink);}
.logo-mark{width:34px;height:34px;border-radius:10px;background:var(--grad-turq);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card);flex-shrink:0;}
.logo-mark svg{width:20px;height:20px;}
nav.main-nav{display:flex;gap:26px;font-size:14.5px;font-weight:600;}
nav.main-nav a{color:var(--ink-700);}
nav.main-nav a:hover{color:var(--turq);}
.nav-toggle{display:none;}
@media(max-width:920px){
  nav.main-nav{position:fixed;inset:64px 0 0 0;background:var(--paper);flex-direction:column;padding:24px;gap:18px;transform:translateY(-110%);transition:transform .3s ease;overflow:auto;}
  nav.main-nav.open{transform:translateY(0);}
  .nav-toggle{display:block;background:none;border:none;font-size:26px;color:var(--ink);cursor:pointer;}
}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(135deg,#0A2540 0%,#3B2E7A 35%,#0E7490 68%,#14B8A6 100%);
  background-size:220% 220%;
  animation:hero-bg-move 22s ease infinite;
  color:#EAF7F5;
  position:relative;
  overflow:hidden;
  padding:88px 0 64px;
}
@keyframes hero-bg-move{
  0%{background-position:0% 30%;}
  50%{background-position:100% 70%;}
  100%{background-position:0% 30%;}
}
@media (prefers-reduced-motion: reduce){.hero{animation:none;}}
.hero::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 82% 18%,rgba(94,234,212,.25),transparent 55%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative;}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;}}
.hero h1{color:#fff;font-size:clamp(32px,4.4vw,54px);line-height:1.05;margin-bottom:20px;}
.hero p.lead{font-size:18px;color:#CFEDE8;max-width:52ch;margin-bottom:28px;}
.hero-stats{display:flex;gap:28px;margin-top:36px;flex-wrap:wrap;}
.hero-stat b{display:block;font-family:var(--font-mono);font-size:26px;color:var(--turq-light);}
.hero-stat span{font-size:12.5px;color:#AFD8D2;text-transform:uppercase;letter-spacing:.08em;}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 24px;border-radius:999px;font-weight:700;font-size:14.5px;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;
}
.btn-primary{background:var(--turq-light);color:var(--ink);box-shadow:0 14px 30px -14px rgba(94,234,212,.7);}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{background:transparent;color:#EAF7F5;border-color:rgba(234,247,245,.4);}
.btn-ghost:hover{border-color:#EAF7F5;}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{transform:translateY(-2px);}

/* ---------- Italy route map (signature element) ---------- */
.italy-map-wrap{position:relative;}
.italy-map{width:100%;height:auto;filter:drop-shadow(0 25px 40px rgba(0,0,0,.35));}
.route-dot{fill:var(--turq-light);}
.route-pulse{animation:pulse 2.6s ease-in-out infinite;}
@keyframes pulse{
  0%,100%{opacity:.35;r:9;}
  50%{opacity:.9;r:14;}
}
.route-line{
  stroke:var(--turq-light);stroke-width:2;fill:none;stroke-dasharray:6 8;
  animation:dash 18s linear infinite;
}
@keyframes dash{to{stroke-dashoffset:-400;}}
.route-label{font-family:var(--font-mono);font-size:11px;fill:#CFEDE8;}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr;}}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:28px;box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.card .icon-tile{
  width:48px;height:48px;border-radius:14px;background:var(--grad-turq);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
  box-shadow:0 10px 20px -10px rgba(20,184,166,.6);
}
.card .icon-tile.tech{background:var(--grad-tech);}
.card .icon-tile svg{width:24px;height:24px;color:#fff;}
.card h3{font-size:19px;margin-bottom:8px;}
.card p{color:var(--ink-muted);font-size:15px;margin:0;}

.section-head{max-width:640px;margin:0 auto 44px;text-align:center;}
.section-head h2{font-size:clamp(26px,3.2vw,38px);}
.section-head p{color:var(--ink-muted);font-size:16.5px;}

.section-alt{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.section-dark{background:var(--ink);color:#DDEFEC;}
.section-dark h2,.section-dark h3{color:#fff;}
.section-dark .card{background:var(--ink-soft);border-color:rgba(255,255,255,.08);}
.section-dark .card p{color:#A9C9C3;}

/* Stat block */
.stat-block{
  border-radius:var(--radius-md);padding:26px;background:var(--turq-pale);
  border:1px solid var(--turq-light);
}
.stat-block b{display:block;font-family:var(--font-mono);font-size:34px;color:var(--teal-deep);}
.stat-block span{font-size:13.5px;color:var(--ink-muted);}

/* Timeline (real chronological data → numbering justified) */
.timeline{position:relative;padding-left:28px;border-left:2px solid var(--turq-light);}
.timeline-item{position:relative;padding-bottom:32px;}
.timeline-item::before{
  content:"";position:absolute;left:-35px;top:4px;width:14px;height:14px;border-radius:50%;
  background:var(--turq);border:3px solid var(--turq-pale);
}
.timeline-item b{font-family:var(--font-mono);color:var(--teal-deep);font-size:13px;}

/* Table */
table.data-table{width:100%;border-collapse:collapse;font-size:14.5px;background:var(--paper);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);}
table.data-table th{background:var(--ink);color:#fff;text-align:left;padding:14px 16px;font-family:var(--font-mono);font-weight:500;font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;}
table.data-table td{padding:13px 16px;border-bottom:1px solid var(--line);}
table.data-table tr:last-child td{border-bottom:none;}
table.data-table tr:hover td{background:var(--turq-pale);}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--ink-muted);padding:18px 0;}
.breadcrumb a{color:var(--ink-muted);}
.breadcrumb a:hover{color:var(--turq);}

/* Region chips */
.chip-row{display:flex;flex-wrap:wrap;gap:10px;}
.chip{
  padding:9px 16px;border-radius:999px;background:var(--paper);border:1px solid var(--line);
  font-size:13.5px;font-weight:600;color:var(--ink-700);
}
.chip:hover{border-color:var(--turq);color:var(--teal-deep);}

/* CTA banner */
.cta-banner{
  background:var(--grad-tech);border-radius:var(--radius-lg);padding:48px;color:#fff;
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
}
.cta-banner h3{color:#fff;font-size:26px;margin-bottom:6px;}
.cta-banner p{margin:0;color:rgba(255,255,255,.85);}

/* Disclaimer box */
.disclaimer{
  background:#FFF7EC;border:1px solid #F3D9A6;border-radius:var(--radius-sm);
  padding:16px 20px;font-size:13.5px;color:#7A5B1E;display:flex;gap:10px;align-items:flex-start;
}
.disclaimer svg{flex-shrink:0;width:18px;height:18px;margin-top:2px;color:#B8860B;}

/* Article card (news) */
.article-card{display:flex;flex-direction:column;gap:10px;}
.article-thumb{
  height:150px;border-radius:var(--radius-md);background:var(--grad-hero);position:relative;overflow:hidden;
}
.article-thumb.alt{background:var(--grad-tech);}
.article-thumb.amber{background:linear-gradient(120deg,#F5A623,#FF6B4A);}
.article-meta{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;}

/* Footer */
footer.site-footer{background:var(--ink);color:#B9D6D1;padding:56px 0 28px;margin-top:80px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;}}
footer.site-footer h4{color:#fff;font-size:14px;margin-bottom:14px;}
footer.site-footer a{color:#9FC4BE;font-size:14px;display:block;margin-bottom:9px;}
footer.site-footer a:hover{color:var(--turq-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:36px;padding-top:22px;font-size:12.5px;color:#7FA39C;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.brand-credit{font-size:12px;color:#7FA39C;}
.brand-credit a{color:#9FC4BE;}

/* Cookie banner */
#cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--ink);color:#EAF7F5;
  padding:18px 24px;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  box-shadow:0 -10px 30px rgba(0,0,0,.25);transform:translateY(120%);transition:transform .4s ease;
}
#cookie-banner.show{transform:translateY(0);}
#cookie-banner p{margin:0;font-size:13.5px;max-width:60ch;color:#CFEDE8;}
#cookie-banner .cookie-actions{display:flex;gap:10px;flex-shrink:0;}
.btn-small{padding:9px 16px;font-size:13px;border-radius:999px;font-weight:700;cursor:pointer;border:1px solid transparent;}
.btn-small.accept{background:var(--turq-light);color:var(--ink);}
.btn-small.decline{background:transparent;border-color:rgba(234,247,245,.35);color:#EAF7F5;}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;}
}

/* ---------- Scroll reveal (progressive enhancement, safe without JS) ---------- */
.reveal-init{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease;}
.reveal-in{opacity:1 !important;transform:none !important;}

/* ---------- Marquee ticker ---------- */
.ticker{
  overflow:hidden;white-space:nowrap;border-top:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14);
  padding:14px 0;position:relative;
  background:linear-gradient(120deg,#1B1450,#0E7490,#6D5BD0,#0A2540);
  background-size:300% 300%;
  animation:ticker-bg-move 14s ease infinite;
}
@keyframes ticker-bg-move{
  0%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
  100%{background-position:0% 50%;}
}
.ticker-track{display:inline-flex;align-items:center;padding-left:100%;animation:ticker-scroll 95s linear infinite;}
.ticker-track a{
  font-family:var(--font-mono);font-size:13px;letter-spacing:.06em;color:#E7DCFF;text-transform:uppercase;
  padding:0 20px;white-space:nowrap;text-decoration:none;transition:color .15s ease;border-right:1px solid rgba(231,220,255,.25);
}
.ticker-track a:hover{color:var(--turq-light);}
.ticker-track a:last-child{border-right:none;}
@keyframes ticker-scroll{0%{transform:translateX(0);}100%{transform:translateX(-100%);}}
@media (prefers-reduced-motion: reduce){.ticker{animation:none;}.ticker-track{animation-duration:220s;}}

/* ---------- Footer credit emphasis ---------- */
.brand-credit-strong{font-weight:700;color:var(--turq-light) !important;}

/* ---------- Floating decorative blobs ---------- */
.blob{position:absolute;border-radius:50%;filter:blur(50px);opacity:.35;pointer-events:none;animation:float-blob 12s ease-in-out infinite;}
@keyframes float-blob{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(14px,-18px) scale(1.06);}}

/* ---------- Region card grid on homepage ---------- */
.region-pill{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 18px;border-radius:var(--radius-sm);background:var(--paper);border:1px solid var(--line);
  font-size:14px;font-weight:600;color:var(--ink-700);transition:border-color .2s ease,transform .2s ease;
}
.region-pill:hover{border-color:var(--turq);transform:translateY(-2px);color:var(--teal-deep);}
.region-pill .macro-tag{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-muted);text-transform:uppercase;}

/* ---------- News cover (no external photos: brand-consistent illustrated covers) ---------- */
.news-cover{
  height:170px;border-radius:var(--radius-md);position:relative;overflow:hidden;
  display:flex;align-items:flex-end;padding:16px;
}
.news-cover svg{position:absolute;opacity:.5;}
.news-cover .cat-badge{
  position:relative;z-index:1;background:rgba(10,37,64,.55);backdrop-filter:blur(4px);
  color:#fff;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
}
.news-cover.c-mercato{background:var(--grad-turq);}
.news-cover.c-innovazione{background:var(--grad-tech);}
.news-cover.c-normativa{background:linear-gradient(120deg,#F5A623,#FF6B4A);}
.news-cover.c-web3{background:linear-gradient(120deg,#6D5BD0,#0A2540);}
.news-cover.g0{background:linear-gradient(120deg,#14B8A6,#5EEAD4);}
.news-cover.g1{background:linear-gradient(120deg,#6D5BD0,#14B8A6);}
.news-cover.g2{background:linear-gradient(120deg,#F5A623,#FF6B4A);}
.news-cover.g3{background:linear-gradient(120deg,#6D5BD0,#0A2540);}
.news-cover.g4{background:linear-gradient(120deg,#0EA5A5,#0A2540);}
.news-cover.g5{background:linear-gradient(120deg,#FF6B4A,#6D5BD0);}
.news-cover.g6{background:linear-gradient(120deg,#0A2540,#14B8A6);}
.news-cover.g7{background:linear-gradient(120deg,#F5A623,#0EA5A5);}
.news-cover.g8{background:linear-gradient(120deg,#5EEAD4,#6D5BD0);}
.news-cover.g9{background:linear-gradient(120deg,#FF6B4A,#0A2540);}
.news-cover.island{background:linear-gradient(120deg,#0891B2,#0EA5A5);}
.news-cover.enclave{background:linear-gradient(120deg,#334155,#6D5BD0);}

/* Utility */
.mt-0{margin-top:0;}
.text-muted{color:var(--ink-muted);}
.prose p{margin:0 0 18px;font-size:16px;color:var(--ink-700);}
.prose h2{margin-top:44px;}
.prose ul{color:var(--ink-700);line-height:1.8;}
