/* ============================================================
   GTP Enterprice — Design System "High-Contrast Tech"
   Shared stylesheet for all pages (IT / EN / ES).
   Palette: anthracite + blue + cyan. Display: Gazpacho. Body: Telegraf.
   ============================================================ */

/* ── FONTS (local files in assets/fonts/) ─────────────────── */
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-black.otf') format('opentype'); font-weight:900; font-style:normal; font-display:swap; }
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-italic-black.otf') format('opentype'); font-weight:900; font-style:italic; font-display:swap; }
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-bold.otf') format('opentype'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-heavy.otf') format('opentype'); font-weight:800; font-style:normal; font-display:swap; }
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-medium.otf') format('opentype'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Gazpacho'; src:url('../fonts/gazpacho-regular.otf') format('opentype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-UltraLight.otf') format('opentype'); font-weight:200; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-Light.otf') format('opentype'); font-weight:300; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-Regular.otf') format('opentype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-Medium.otf') format('opentype'); font-weight:500; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-SemiBold.otf') format('opentype'); font-weight:600; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-Bold.otf') format('opentype'); font-weight:700; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-UltraBold.otf') format('opentype'); font-weight:800; font-display:swap; }
@font-face { font-family:'Telegraf'; src:url('../fonts/Telegraf-Black.otf') format('opentype'); font-weight:900; font-display:swap; }

/* ── TOKENS ────────────────────────────────────────────────── */
:root {
  --paper:     #F5F6FA;
  --surface:   #FFFFFF;
  --surface-2: #EAECF4;
  --ink:       #1E272E;
  --ink-1:     #0D151A;
  --ink-2:     #3A444D;
  --ink-muted: #5A616A;
  --blue:      #0984E3;
  --blue-text: #0670C4;   /* 4.69:1 on --paper — small text on light bg */
  --blue-2:    #3AA0FF;
  --blue-deep: #0670C4;
  --blue-soft: rgba(9,132,227,0.08);
  --blue-glow: rgba(9,132,227,0.28);
  --cyan:      #00CEC9;
  --cyan-soft: rgba(0,206,201,0.10);
  --border:    #D8DBE8;
  --border-hi: #B8BDD0;

  /* On-dark text — opacities tuned to clear WCAG AA (>=4.5:1 on --ink) */
  --on-dark:        rgba(245,246,250,0.92);
  --on-dark-strong: #F5F6FA;
  --on-dark-soft:   rgba(245,246,250,0.74);
  --on-dark-faint:  rgba(245,246,250,0.60); /* large text / non-essential only */

  --f-display:'Gazpacho', 'Times New Roman', Georgia, serif;
  --f-body:   'Telegraf', system-ui, -apple-system, sans-serif;

  --r-xs:4px; --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:20px; --r-2xl:28px; --r-pill:999px;

  --shadow-card:0 1px 0 rgba(30,39,46,0.04), 0 4px 16px rgba(30,39,46,0.06);
  --shadow-glow:0 0 48px -8px var(--blue-glow);

  /* Semantic z-index scale */
  --z-base:1;
  --z-nav:200;
  --z-overlay:300;
  --z-progress:400;
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
body {
  background:var(--paper); color:var(--ink);
  font-family:var(--f-body); font-size:16px; line-height:1.6;
  overflow-x:hidden;
}
a { color:inherit; text-decoration:none; }
button { font:inherit; border:none; background:none; cursor:pointer; color:inherit; }
ul { list-style:none; }
img, svg { display:block; max-width:100%; }
h1,h2,h3,h4 { font-family:var(--f-display); }

:focus-visible {
  outline:2px solid var(--blue-deep);
  outline-offset:2px;
  border-radius:var(--r-xs);
}

@media (prefers-reduced-motion:reduce) {
  html { scroll-behavior:auto; }
  *, *::before, *::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}

/* ── ATMOSPHERE ────────────────────────────────────────────── */
body::before {
  content:''; position:fixed; inset:-10%; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 65% 40% at 50% -5%, rgba(9,132,227,.10) 0%, transparent 65%),
    radial-gradient(ellipse 40% 30% at 100% 20%, rgba(0,206,201,.06) 0%, transparent 60%);
}

/* ── SCROLL PROGRESS ───────────────────────────────────────── */
.scroll-progress {
  position:fixed; top:0; left:0; right:0; height:2px; z-index:var(--z-progress);
  background:var(--blue); transform:scaleX(0); transform-origin:left;
  transition:transform .1s linear;
}

/* ── LAYOUT ────────────────────────────────────────────────── */
.wrap { max-width:1200px; margin-inline:auto; padding-inline:32px; position:relative; z-index:var(--z-base); }

/* ── ANIMATIONS ────────────────────────────────────────────── */
@keyframes nav-in   { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:none} }
@keyframes fade-up  { from{opacity:0;transform:translateY(20px)}  to{opacity:1;transform:none} }
@keyframes marquee  { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes draw-line{ to{stroke-dashoffset:0} }
@keyframes blink    { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes pulse-blue { 0%,100%{box-shadow:0 0 0 0 rgba(9,132,227,.35)} 50%{box-shadow:0 0 0 8px rgba(9,132,227,0)} }
@keyframes pulse-cta  { 0%,100%{box-shadow:0 2px 8px rgba(9,132,227,.25),0 0 0 0 rgba(9,132,227,.5)} 60%{box-shadow:0 2px 8px rgba(9,132,227,.25),0 0 0 18px rgba(9,132,227,0)} }
@keyframes draw-route { to { stroke-dashoffset:0; } }
@keyframes pin-pulse  { 0%,100%{transform:scale(1);opacity:.5} 65%{transform:scale(2.6);opacity:0} }
.btn-primary--pulse { animation:pulse-cta 2.8s ease-in-out infinite; }
@media (prefers-reduced-motion:reduce) { .btn-primary--pulse { animation:none; } }

/* ── NAV — floating pill + mobile panel ────────────────────── */
.nav {
  position:fixed; top:14px; left:0; right:0; margin-inline:auto;
  z-index:var(--z-nav); width:min(960px, calc(100% - 24px));
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 10px 10px 22px;
  background:rgba(245,246,250,.88);
  backdrop-filter:blur(24px) saturate(160%); -webkit-backdrop-filter:blur(24px) saturate(160%);
  border:1px solid var(--border-hi); border-radius:var(--r-pill);
  animation:nav-in .5s cubic-bezier(.22,1,.36,1) both;
  box-shadow:0 2px 24px rgba(30,39,46,.08);
}
.nav-logo { font-family:var(--f-display); font-weight:700; font-size:1.0625rem; letter-spacing:-.015em; color:var(--ink); white-space:nowrap; flex-shrink:0; }
.nav-logo em { color:var(--blue-text); font-style:normal; }
.nav-center { display:flex; align-items:center; gap:2px; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-links a { padding:7px 14px; border-radius:var(--r-pill); font-size:.875rem; font-weight:600; color:var(--ink-muted); transition:background .15s, color .15s; }
.nav-links a:hover, .nav-links a[aria-current="page"] { background:var(--surface-2); color:var(--ink); }
.nav-right { display:flex; align-items:center; gap:10px; }
.nav-langs { display:flex; gap:2px; align-items:center; }
.nav-langs a { font-size:.75rem; font-weight:700; letter-spacing:.02em; color:var(--ink-muted); padding:4px 7px; border-radius:var(--r-sm); transition:color .15s, background .15s; }
.nav-langs a:hover, .nav-langs a[aria-current="page"] { color:var(--ink); background:var(--surface-2); }
.nav-cta { flex-shrink:0; background:var(--ink); color:var(--on-dark-strong); padding:9px 20px; border-radius:var(--r-pill); font-size:.875rem; font-weight:700; letter-spacing:.01em; transition:background .2s, transform .15s, box-shadow .2s; white-space:nowrap; }
.nav-cta:hover { background:var(--ink-1); transform:translateY(-1px); box-shadow:0 4px 16px rgba(30,39,46,.2); }

.nav-toggle { display:none; width:40px; height:40px; align-items:center; justify-content:center; border-radius:var(--r-pill); color:var(--ink); flex-shrink:0; }
.nav-toggle__bar, .nav-toggle__bar::before, .nav-toggle__bar::after { display:block; width:20px; height:2px; background:currentColor; border-radius:2px; position:relative; transition:transform .2s ease, opacity .2s ease; }
.nav-toggle__bar::before { content:''; position:absolute; top:-6px; left:0; }
.nav-toggle__bar::after  { content:''; position:absolute; top:6px; left:0; }
.nav.is-open .nav-toggle__bar { background:transparent; }
.nav.is-open .nav-toggle__bar::before { transform:translateY(6px) rotate(45deg); }
.nav.is-open .nav-toggle__bar::after  { transform:translateY(-6px) rotate(-45deg); }

@media (max-width:860px) {
  .nav { padding:8px 8px 8px 18px; }
  .nav-toggle { display:flex; }
  .nav-center {
    position:fixed; inset:78px 12px auto 12px; z-index:var(--z-overlay);
    flex-direction:column; align-items:stretch; gap:6px;
    background:var(--ink); color:var(--on-dark); border-radius:var(--r-xl);
    padding:18px; box-shadow:0 16px 48px rgba(13,21,26,.4);
    opacity:0; transform:translateY(-8px) scale(.98); pointer-events:none;
    transition:opacity .2s ease, transform .2s ease;
  }
  .nav.is-open .nav-center { opacity:1; transform:none; pointer-events:auto; }
  .nav-links { flex-direction:column; align-items:stretch; gap:2px; }
  .nav-links a { color:var(--on-dark-soft); font-size:1.05rem; padding:12px 14px; }
  .nav-links a:hover, .nav-links a[aria-current="page"] { background:rgba(245,246,250,.08); color:var(--on-dark-strong); }
  .lang-select { margin-top:10px; padding-top:12px; border-top:1px solid rgba(245,246,250,.1); }
  .lang-select__btn { width:100%; justify-content:space-between; background:rgba(245,246,250,.06); border-color:rgba(245,246,250,.16); color:var(--on-dark-soft); }
  .lang-select__btn:hover, .lang-select[open] .lang-select__btn { color:var(--on-dark-strong); border-color:rgba(245,246,250,.3); }
  .lang-select__menu { position:static; margin-top:6px; min-width:0; background:rgba(245,246,250,.04); border-color:rgba(245,246,250,.12); box-shadow:none; }
  .lang-select__menu a { color:var(--on-dark-soft); }
  .lang-select__menu a:hover, .lang-select__menu a[aria-current="page"] { background:rgba(245,246,250,.08); color:var(--on-dark-strong); }
}

/* ── LANGUAGE DROPDOWN (<details>) ─────────────────────────── */
.lang-select { position:relative; flex-shrink:0; }
.lang-select__btn {
  list-style:none; display:inline-flex; align-items:center; gap:6px; cursor:pointer;
  font-size:.78rem; font-weight:700; letter-spacing:.02em; color:var(--ink-muted);
  padding:7px 12px; border-radius:var(--r-pill); border:1px solid var(--border); background:var(--surface);
  transition:color .15s, border-color .15s;
}
.lang-select__btn::-webkit-details-marker { display:none; }
.lang-select__btn:hover, .lang-select[open] .lang-select__btn { color:var(--ink); border-color:var(--border-hi); }
.lang-select__btn .chev { width:11px; height:11px; transition:transform .2s; }
.lang-select[open] .lang-select__btn .chev { transform:rotate(180deg); }
.lang-select__menu {
  position:absolute; top:calc(100% + 8px); right:0; min-width:158px;
  background:var(--surface); border:1px solid var(--border-hi); border-radius:var(--r-md);
  box-shadow:0 10px 30px rgba(30,39,46,.16); padding:6px; display:grid; gap:2px; z-index:var(--z-overlay);
}
.lang-select__menu a { padding:10px 12px; border-radius:var(--r-sm); font-size:.875rem; font-weight:600; color:var(--ink-muted); white-space:nowrap; }
.lang-select__menu a:hover, .lang-select__menu a[aria-current="page"] { background:var(--surface-2); color:var(--ink); }

/* sector icons (SVG, replaces emoji) */
.sec-icon { display:flex; align-items:center; justify-content:center; width:46px; height:46px; margin-bottom:14px; border-radius:var(--r-md); background:var(--blue-soft); }
.sec-icon svg { width:24px; height:24px; color:var(--blue-text); }

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn-primary {
  background:var(--blue-deep); color:#fff;       /* #0670C4 on #fff = 4.88:1 */
  padding:13px 28px; border-radius:var(--r-pill);
  font-family:var(--f-body); font-size:.9375rem; font-weight:700;
  display:inline-flex; align-items:center; gap:8px;
  transition:background .2s, transform .15s, box-shadow .2s;
  box-shadow:0 2px 8px rgba(9,132,227,.25);
}
.btn-primary:hover { background:#055FA8; transform:translateY(-1px); box-shadow:var(--shadow-glow); }
.btn-ghost {
  color:var(--ink-2); padding:13px 28px; border-radius:var(--r-pill);
  font-family:var(--f-body); font-size:.9375rem; font-weight:600;
  border:1.5px solid var(--border-hi);
  transition:border-color .2s, color .2s, background .2s;
}
.btn-ghost:hover { border-color:var(--blue); color:var(--blue-text); background:var(--blue-soft); }
.section--dark .btn-ghost { color:var(--on-dark); border-color:rgba(245,246,250,.3); }
.section--dark .btn-ghost:hover { color:var(--on-dark-strong); border-color:var(--cyan); background:rgba(0,206,201,.08); }

/* ── HERO (home) ───────────────────────────────────────────── */
.hero {
  display:grid; grid-template-columns:1.05fr 0.95fr; align-items:center; gap:56px;
  max-width:1200px; margin-inline:auto; padding:136px 32px 96px;
  position:relative; z-index:var(--z-base);
}
.hero-text, .hero-visual { position:relative; z-index:2; }
.hero-h1 {
  font-family:var(--f-display); font-weight:900; font-style:italic;
  font-size:clamp(2.25rem, 3.4vw, 3.05rem); line-height:1.08; letter-spacing:-.026em;
  color:var(--ink); margin-bottom:24px; text-wrap:balance;
}

/* Animated connections graphic behind the hero (home) */
.hero-net { position:absolute; inset:0; width:100%; height:100%; pointer-events:none; z-index:1; opacity:.55; }
.hero-net .route { stroke:var(--blue); stroke-width:1.5; stroke-dasharray:5 9; fill:none; opacity:.4; animation:net-dash 9s linear infinite; }
.hero-net .route.r2 { stroke:var(--cyan); opacity:.32; animation-duration:13s; }
.hero-net .node { fill:var(--blue); animation:net-pulse 3.2s ease-in-out infinite; transform-box:fill-box; transform-origin:center; }
.hero-net .node.n2 { fill:var(--cyan); animation-delay:1s; }
.hero-net .node.n3 { animation-delay:.6s; }
@keyframes net-dash { to { stroke-dashoffset:-140; } }
@keyframes net-pulse { 0%,100% { opacity:.5; transform:scale(1); } 50% { opacity:1; transform:scale(1.5); } }
@media (prefers-reduced-motion:reduce) { .hero-net .route, .hero-net .node { animation:none; } }
.hero-sub { font-size:1.0625rem; line-height:1.72; color:var(--ink-2); max-width:460px; margin-bottom:40px; }
.hero-btns { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:44px; }
.hero-proof { display:flex; align-items:center; gap:12px; font-size:.875rem; color:var(--ink-muted); }
.proof-dots { display:flex; }
.proof-dot { width:28px; height:28px; border-radius:50%; border:2px solid var(--paper); margin-left:-7px; flex-shrink:0; }
.proof-dot:first-child { margin-left:0; }
.proof-dot:nth-child(1){ background:#7090B8; } .proof-dot:nth-child(2){ background:#B87060; }
.proof-dot:nth-child(3){ background:#60B870; } .proof-dot:nth-child(4){ background:#9060B8; }
.hero-proof strong { color:var(--ink); font-weight:700; }

/* ── SUPPLIER CARD ─────────────────────────────────────────── */
.hero-visual { display:flex; justify-content:flex-end; animation:fade-up .7s .2s cubic-bezier(.22,1,.36,1) both; }
.sup-bezel { width:100%; max-width:372px; padding:4px; background:rgba(255,255,255,.6); border:1px solid var(--border); border-radius:calc(var(--r-2xl) + 4px); box-shadow:var(--shadow-card); }
.sup-card { background:var(--surface); border-radius:var(--r-2xl); padding:22px; border:1px solid rgba(216,219,232,.6); overflow:hidden; }
.sc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.sc-chip { font-size:.685rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--blue-text); background:var(--blue-soft); padding:4px 10px; border-radius:var(--r-pill); }
.sc-live { display:flex; align-items:center; gap:5px; font-size:.75rem; color:var(--ink-muted); }
.sc-dot { width:6px; height:6px; border-radius:50%; background:#22C55E; animation:blink 2.2s ease infinite; }
.sc-name { font-family:var(--f-display); font-weight:700; font-size:1.125rem; color:var(--ink); margin-bottom:3px; }
.sc-loc { font-size:.8125rem; color:var(--ink-muted); margin-bottom:18px; }
.sc-score-row { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.sc-ring { width:58px; height:58px; border-radius:50%; border:2.5px solid var(--blue); flex-shrink:0; display:flex; flex-direction:column; align-items:center; justify-content:center; animation:pulse-blue 3.5s ease infinite; background:var(--blue-soft); }
.sc-num { font-family:var(--f-display); font-weight:900; font-size:1.375rem; color:var(--blue-text); line-height:1; }
.sc-sub-label { font-size:.5rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-muted); margin-top:1px; }
.sc-rmeta p { font-size:.875rem; font-weight:600; color:var(--ink); margin-bottom:3px; }
.sc-rmeta span { font-size:.8125rem; color:var(--blue-text); font-weight:600; }
.sc-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:16px; }
.sc-m label { display:block; font-size:.625rem; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-muted); margin-bottom:4px; }
.sc-m strong { font-family:var(--f-display); font-weight:700; font-size:.9375rem; color:var(--ink); }
.sc-events { display:flex; flex-direction:column; gap:10px; }
.sc-ev { display:flex; gap:10px; align-items:flex-start; }
.sc-ev-dot { width:6px; height:6px; border-radius:50%; background:var(--border); margin-top:5px; flex-shrink:0; }
.sc-ev-dot.active { background:var(--blue); }
.sc-ev-body { font-size:.8rem; color:var(--ink-2); line-height:1.45; }
.sc-ev-time { font-size:.7rem; color:var(--ink-muted); margin-top:1px; }

/* ── MARQUEE ───────────────────────────────────────────────── */
.marquee-wrap { background:var(--ink); padding:18px 0; overflow:hidden; position:relative; z-index:var(--z-base); }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 36s linear infinite; }
.mq-item { display:inline-flex; align-items:center; gap:10px; padding:0 32px; font-family:var(--f-body); font-weight:600; font-size:.875rem; color:var(--on-dark-soft); flex-shrink:0; }
.mq-sep { color:var(--blue-2); opacity:.85; font-size:.625rem; }
/* fade bordi marquee + pause hover */
.marquee-wrap::before,.marquee-wrap::after { content:''; position:absolute; top:0; bottom:0; width:80px; z-index:2; pointer-events:none; }
.marquee-wrap::before { left:0; background:linear-gradient(to right, var(--ink) 15%, transparent); }
.marquee-wrap::after  { right:0; background:linear-gradient(to left,  var(--ink) 15%, transparent); }
@media (hover:hover) { .marquee-wrap:hover .marquee-track { animation-play-state:paused; } }

/* ── STATS ─────────────────────────────────────────────────── */
.stats-section { background:var(--ink); padding:72px 0; position:relative; z-index:var(--z-base); }
.stats-section::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, rgba(9,132,227,.4), rgba(0,206,201,.4), transparent); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.stat { padding:32px 24px; text-align:center; border-right:1px solid rgba(245,246,250,.08); }
.stat:last-child { border-right:none; }
.stat-n { font-family:var(--f-display); font-weight:900; font-size:2.5rem; color:var(--blue-2); letter-spacing:-.03em; line-height:1; margin-bottom:10px; }
.stat-n em { color:var(--cyan); font-style:normal; }
.stat-l { font-size:.875rem; color:var(--on-dark-soft); }
/* stats reveal stagger (added when section enters view) */
.js .stats-grid .stat { opacity:0; transform:translateY(14px); transition:opacity .55s ease, transform .55s ease; }
.js .stats-grid.in .stat { opacity:1; transform:none; }
.js .stats-grid.in .stat:nth-child(2) { transition-delay:.08s; }
.js .stats-grid.in .stat:nth-child(3) { transition-delay:.16s; }
.js .stats-grid.in .stat:nth-child(4) { transition-delay:.24s; }
@media (prefers-reduced-motion:reduce) { .js .stats-grid .stat { opacity:1; transform:none; transition:none; } }

/* ── BACK TO TOP (injected by main.js) ─────────────────────── */
.to-top {
  position:fixed; right:22px; bottom:22px; z-index:var(--z-overlay);
  width:46px; height:46px; border-radius:var(--r-pill);
  display:flex; align-items:center; justify-content:center;
  background:var(--ink); color:var(--on-dark-strong);
  box-shadow:0 6px 20px rgba(13,21,26,.28);
  opacity:0; transform:translateY(12px); pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, background .2s ease;
}
.to-top.is-visible { opacity:1; transform:none; pointer-events:auto; }
.to-top:hover { background:var(--blue-deep); }
.to-top svg { width:18px; height:18px; }
@media (prefers-reduced-motion:reduce) { .to-top { transition:opacity .25s ease; transform:none; } }

/* ── SECTION BASE ──────────────────────────────────────────── */
.section { padding:96px 0; position:relative; z-index:var(--z-base); }
.section--dark { background:var(--ink); color:var(--on-dark); }
.section--dark .sec-h2, .section--dark .sec-name, .section--dark .why-title { color:var(--on-dark-strong); }
.section--dark .sec-sub { color:var(--on-dark-soft); }
.section--surface-2 { background:var(--surface-2); }
.sec-label { display:flex; align-items:center; gap:10px; font-size:.6875rem; font-weight:700; text-transform:uppercase; letter-spacing:.10em; color:var(--ink-2); margin-bottom:14px; }
.section--dark .sec-label { color:var(--on-dark-soft); }
.sec-label::before { content:''; width:6px; height:6px; border-radius:1px; background:var(--blue); flex-shrink:0; }
.sec-h2 { font-family:var(--f-display); font-weight:900; font-size:clamp(1.875rem, 3.5vw, 3rem); line-height:1.1; letter-spacing:-.025em; color:var(--ink); margin-bottom:14px; text-wrap:balance; }
.sec-sub { font-size:1rem; color:var(--ink-2); max-width:560px; line-height:1.72; }
.sec-head { margin-bottom:52px; }

/* ── BENTO (home services) ─────────────────────────────────── */
.bento { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.bc { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl); padding:28px; overflow:hidden; transition:border-color .2s, box-shadow .2s, transform .2s; position:relative; }
.bc:hover { border-color:var(--blue); box-shadow:0 4px 20px rgba(9,132,227,.10); transform:translateY(-2px); }
.bc-feat { grid-column:span 2; background:var(--ink); border-color:transparent; color:var(--on-dark); }
.bc-feat:hover { border-color:rgba(0,206,201,.25); box-shadow:0 4px 32px rgba(0,206,201,.08); }
.bc-icon { width:38px; height:38px; border-radius:var(--r-md); background:var(--blue-soft); color:var(--blue-text); display:flex; align-items:center; justify-content:center; margin-bottom:18px; flex-shrink:0; }
.bc-feat .bc-icon { background:rgba(0,206,201,.12); color:var(--cyan); }
.bc-title { font-family:var(--f-display); font-weight:700; font-size:1.1875rem; color:var(--ink); margin-bottom:10px; line-height:1.2; }
.bc-feat .bc-title { color:var(--on-dark-strong); }
.bc-body { font-size:.9375rem; color:var(--ink-2); line-height:1.6; }
.bc-feat .bc-body { color:var(--on-dark-soft); }
.bc-link { display:inline-flex; align-items:center; gap:5px; margin-top:18px; font-size:.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--blue-text); transition:gap .15s; }
.bc-link:hover { gap:9px; }
.bc-feat .bc-link { color:var(--cyan); }
.bc-chart { margin-top:24px; }
.bc-chart svg { width:100%; height:56px; display:block; }

/* ── WHY ───────────────────────────────────────────────────── */
.why-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:48px 80px; }
.why-mark { width:8px; height:8px; border-radius:2px; background:var(--blue); margin-bottom:18px; display:block; }
.section--dark .why-mark { background:var(--cyan); }
/* numero outline elegante — sostituisce .why-mark nella sezione Approccio */
.why-num { font-family:var(--f-display); font-weight:900; font-style:italic; font-size:2.75rem; line-height:1; color:transparent; -webkit-text-stroke:1.5px var(--blue-deep); letter-spacing:-.04em; margin-bottom:16px; display:block; opacity:.65; }
.section--surface-2 .why-num { -webkit-text-stroke-color:var(--blue-deep); }
.section--dark .why-num { -webkit-text-stroke-color:var(--cyan); opacity:.55; }
/* stagger reveal per ogni why-item — container-based (più affidabile su mobile) */
.js .why-grid .why-item { opacity:0; transform:translateY(12px); transition:opacity .55s ease, transform .55s ease; }
.js .why-grid.in .why-item { opacity:1; transform:none; }
.js .why-grid.in .why-item:nth-child(2) { transition-delay:.1s; }
.js .why-grid.in .why-item:nth-child(3) { transition-delay:.2s; }
.js .why-grid.in .why-item:nth-child(4) { transition-delay:.3s; }
@media (prefers-reduced-motion:reduce) { .js .why-grid .why-item { opacity:1; transform:none; transition:none; } }
.why-title { font-family:var(--f-display); font-weight:700; font-size:1.25rem; color:var(--ink); margin-bottom:10px; }
.why-body { font-size:.9375rem; color:var(--ink-2); line-height:1.65; }
.section--dark .why-body { color:var(--on-dark-soft); }

/* ── SECTORS ───────────────────────────────────────────────── */
.sectors-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.sector { padding:24px; border:1px solid var(--border); border-radius:var(--r-lg); background:var(--surface); transition:border-color .2s, background .2s, transform .2s, box-shadow .2s; }
.sector:hover { border-color:var(--blue); background:var(--blue-soft); transform:translateY(-2px); box-shadow:0 4px 16px rgba(9,132,227,.10); }
/* .sec-icon — defined once above (display:flex + icon container); old font-size rule removed */
.sec-name { font-family:var(--f-display); font-weight:700; font-size:1.0625rem; color:var(--ink); margin-bottom:6px; }
.sec-desc { font-size:.875rem; color:var(--ink-muted); line-height:1.55; }

/* ── PAGE HERO (inner pages) ───────────────────────────────── */
.page-hero { background:var(--ink); color:var(--on-dark); padding:148px 0 72px; position:relative; overflow:hidden; z-index:var(--z-base); }
.page-hero::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 60% 70% at 80% 0%, rgba(9,132,227,.12) 0%, transparent 65%); }
.page-hero__inner { position:relative; max-width:760px; }
.page-hero h1 { font-family:var(--f-display); font-weight:900; font-style:italic; font-size:clamp(2.25rem, 4vw, 3.25rem); line-height:1.08; letter-spacing:-.026em; color:var(--on-dark-strong); margin-bottom:18px; text-wrap:balance; }
.page-hero .lede { font-size:1.0625rem; line-height:1.7; color:var(--on-dark-soft); max-width:560px; }

/* ── PROSE ─────────────────────────────────────────────────── */
.prose { max-width:68ch; }
.prose p { margin-bottom:18px; color:var(--ink-2); line-height:1.75; }
.prose p:last-child { margin-bottom:0; }
.prose h3 { font-family:var(--f-display); font-weight:700; font-size:1.375rem; color:var(--ink); margin:36px 0 12px; }

/* ── SERVICE GROUP (services page) ─────────────────────────── */
.svc-group { margin-bottom:64px; }
.svc-group:last-child { margin-bottom:0; }
.svc-group__head { display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-bottom:16px; margin-bottom:28px; border-bottom:1px solid var(--border); }
.svc-group__title { font-family:var(--f-display); font-weight:900; font-size:1.5rem; color:var(--ink); letter-spacing:-.02em; }
.svc-group__count { font-size:.8125rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-muted); }
.svc-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.svc { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl); padding:28px; transition:border-color .2s, box-shadow .2s, transform .2s; }
.svc:hover { border-color:var(--blue); box-shadow:0 4px 20px rgba(9,132,227,.08); transform:translateY(-2px); }
.svc__index { font-family:var(--f-display); font-weight:900; font-size:.875rem; color:var(--blue-text); letter-spacing:.04em; }
.svc__title { font-family:var(--f-display); font-weight:700; font-size:1.1875rem; color:var(--ink); margin:8px 0 10px; line-height:1.25; }
.svc__body { font-size:.9375rem; color:var(--ink-2); line-height:1.6; margin-bottom:16px; }
.svc__list { display:grid; gap:9px; }
.svc__list li { position:relative; padding-left:20px; font-size:.875rem; color:var(--ink); line-height:1.5; }
.svc__list li::before { content:''; position:absolute; left:0; top:.55em; width:7px; height:7px; border-radius:2px; background:var(--blue); }

/* ── CONTACT FORM ──────────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:start; }
.form { display:grid; gap:18px; max-width:560px; }
.form__row { display:grid; gap:6px; }
.form__row--2 { grid-template-columns:repeat(auto-fit, minmax(200px,1fr)); gap:18px; }
.form label { font-size:.75rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); }
.form input, .form select, .form textarea { font-family:var(--f-body); font-size:1rem; padding:12px 16px; border:1px solid var(--border-hi); border-radius:var(--r-sm); background:var(--surface); color:var(--ink); transition:border-color .15s, box-shadow .15s; width:100%; }
.form input:focus-visible, .form select:focus-visible, .form textarea:focus-visible { outline:none; border-color:var(--blue-deep); box-shadow:0 0 0 3px var(--blue-soft); }
.form textarea { resize:vertical; min-height:140px; }
.form__note { font-size:.8125rem; color:var(--ink-muted); }
.form__success { display:none; padding:16px 18px; border-radius:var(--r-md); background:var(--blue-soft); border:1px solid var(--border-hi); color:var(--ink); font-size:.9375rem; }
.form__success.is-visible { display:block; }
.info-block { margin-bottom:32px; }
.info-list { display:grid; gap:10px; margin-top:8px; }
.info-list li { font-size:.9375rem; color:var(--ink-2); }
.info-list a { color:var(--blue-text); font-weight:600; }

/* ── PROCESS TIMELINE ──────────────────────────────────────── */
.process-grid { position:relative; display:grid; grid-template-columns:repeat(5,1fr); gap:24px; margin-top:48px; }
.process-grid::before { content:''; position:absolute; top:23px; left:9%; right:9%; height:2px; background:var(--border); }
.js .process-grid::after { content:''; position:absolute; top:23px; left:9%; height:2px; background:var(--blue); width:0; transition:width 1.3s cubic-bezier(.22,1,.36,1) .15s; }
.js .process-grid.in::after { width:82%; }
.step { position:relative; }
.step__num { width:46px; height:46px; border-radius:var(--r-pill); background:var(--surface); border:2px solid var(--border-hi); color:var(--blue-text); font-family:var(--f-display); font-weight:900; font-size:1.0625rem; display:flex; align-items:center; justify-content:center; position:relative; z-index:1; margin-bottom:16px; transition:border-color .4s ease, box-shadow .4s ease; }
.js .process-grid.in .step__num { border-color:var(--blue); box-shadow:0 0 0 4px var(--blue-soft); }
.step__title { font-family:var(--f-display); font-weight:700; font-size:1.0625rem; color:var(--ink); margin-bottom:6px; }
.step__body { font-size:.875rem; color:var(--ink-2); line-height:1.55; }
@media (max-width:860px) {
  .process-grid { grid-template-columns:1fr; gap:0; margin-top:36px; }
  .process-grid::before { left:23px; right:auto; top:8%; bottom:8%; width:2px; height:auto; }
  .js .process-grid::after { left:23px; top:8%; width:2px; height:0; transition:height 1.3s cubic-bezier(.22,1,.36,1) .15s; }
  .js .process-grid.in::after { height:84%; width:2px; }
  .step { display:grid; grid-template-columns:46px 1fr; gap:18px; align-items:start; padding-bottom:30px; }
  .step:last-child { padding-bottom:0; }
  .step__num { margin-bottom:0; }
  .step__body { grid-column:2; }
}
@media (prefers-reduced-motion:reduce) { .js .process-grid::after { transition:none; } }
/* timeline — testo step appare con stagger sincronizzato alla linea */
.js .process-grid .step__title,.js .process-grid .step__body { opacity:0; transform:translateY(6px); transition:opacity .45s ease, transform .45s ease; }
.js .process-grid.in .step__title,.js .process-grid.in .step__body { opacity:1; transform:none; }
.js .process-grid.in .step:nth-child(1) .step__num { transition-delay:.0s; }
.js .process-grid.in .step:nth-child(2) .step__title,.js .process-grid.in .step:nth-child(2) .step__body,.js .process-grid.in .step:nth-child(2) .step__num { transition-delay:.3s; }
.js .process-grid.in .step:nth-child(3) .step__title,.js .process-grid.in .step:nth-child(3) .step__body,.js .process-grid.in .step:nth-child(3) .step__num { transition-delay:.55s; }
.js .process-grid.in .step:nth-child(4) .step__title,.js .process-grid.in .step:nth-child(4) .step__body,.js .process-grid.in .step:nth-child(4) .step__num { transition-delay:.8s; }
.js .process-grid.in .step:nth-child(5) .step__title,.js .process-grid.in .step:nth-child(5) .step__body,.js .process-grid.in .step:nth-child(5) .step__num { transition-delay:1.05s; }
@media (prefers-reduced-motion:reduce) { .js .process-grid .step__title,.js .process-grid .step__body { opacity:1; transform:none; transition:none; } }

/* ── FAQ ACCORDION ─────────────────────────────────────────── */
.faq { max-width:780px; margin-top:44px; }
.faq-item { border:1px solid var(--border); border-radius:var(--r-md); background:var(--surface); margin-bottom:10px; }
.faq-item summary { list-style:none; cursor:pointer; padding:18px 22px; font-family:var(--f-display); font-weight:700; font-size:1.0625rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary:hover { color:var(--blue-text); }
.faq-item .ic { position:relative; flex-shrink:0; width:20px; height:20px; }
.faq-item .ic::before, .faq-item .ic::after { content:''; position:absolute; background:var(--blue-text); border-radius:2px; transition:transform .25s ease, opacity .25s ease; }
.faq-item .ic::before { top:9px; left:2px; right:2px; height:2px; }
.faq-item .ic::after { left:9px; top:2px; bottom:2px; width:2px; }
.faq-item[open] .ic::after { transform:scaleY(0); opacity:0; }
.faq-item__body { padding:0 22px 20px; color:var(--ink-2); font-size:.9375rem; line-height:1.7; }

/* ── FINAL CTA ─────────────────────────────────────────────── */
.cta-section { background:var(--ink); padding:96px 0; position:relative; overflow:hidden; z-index:var(--z-base); }
.cta-section::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 70% 60% at 50% 50%, rgba(9,132,227,.07) 0%, transparent 70%); }
.cta-inner { text-align:center; max-width:600px; margin-inline:auto; position:relative; }
.cta-section .sec-h2 { color:var(--on-dark-strong); margin-bottom:16px; }
.cta-section .cta-sub { color:var(--on-dark-soft); font-size:1.0625rem; line-height:1.72; margin-bottom:40px; }
.cta-section .btn-primary { font-size:1rem; padding:15px 36px; box-shadow:0 0 40px rgba(9,132,227,.4); }
.cta-section .btn-primary:hover { box-shadow:0 0 64px rgba(9,132,227,.55); }

/* ── FOOTER ────────────────────────────────────────────────── */
.footer { background:var(--ink-1); border-top:1px solid rgba(245,246,250,.06); padding:64px 0 40px; position:relative; z-index:var(--z-base); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.f-logo { font-family:var(--f-display); font-weight:700; font-size:1.125rem; color:var(--on-dark-strong); margin-bottom:10px; }
.f-logo em { color:var(--blue-2); font-style:normal; }
.f-brand-desc { font-size:.875rem; color:var(--on-dark-soft); line-height:1.65; max-width:240px; }
.f-col-label { display:block; font-size:.685rem; font-weight:700; text-transform:uppercase; letter-spacing:.10em; color:var(--on-dark-faint); margin-bottom:16px; }
.f-col ul { display:flex; flex-direction:column; gap:10px; }
.f-col ul a { font-size:.875rem; color:var(--on-dark-soft); transition:color .15s; }
.f-col ul a:hover { color:var(--on-dark-strong); }
.f-bar { border-top:1px solid rgba(245,246,250,.08); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.f-copy { font-size:.8125rem; color:var(--on-dark-faint); }
.f-langs { display:flex; gap:16px; }
.f-langs a { font-size:.8125rem; color:var(--on-dark-soft); transition:color .15s; }
.f-langs a:hover { color:var(--on-dark-strong); }
.f-langs a[aria-current="page"] { color:var(--cyan); font-weight:700; }

/* ── WORLD MAP ─────────────────────────────────────────────── */
.map-container { position:relative; margin:48px 0 36px; border-radius:var(--r-xl); overflow:hidden; background:rgba(9,132,227,.03); border:1px solid rgba(9,132,227,.14); }
.world-map { display:block; width:100%; height:auto; }
.map-route { stroke:var(--blue); stroke-width:1.5; fill:none; opacity:.7; stroke-dasharray:500; stroke-dashoffset:500; }
.map-route.r2 { stroke:var(--cyan); opacity:.4; }
.map-route.r-short { stroke:var(--blue-2); stroke-width:1.5; opacity:.9; stroke-dasharray:100; stroke-dashoffset:100; }
.map-container.in .map-route      { animation:draw-route 2s .2s ease forwards; }
.map-container.in .map-route.r2   { animation:draw-route 2.5s .9s ease forwards; }
.map-container.in .map-route.r-short { animation:draw-route .7s .5s ease forwards; }
.pin-ring { fill:none; stroke:var(--blue); stroke-width:1.5; transform-box:fill-box; transform-origin:center; animation:pin-pulse 2.8s ease-in-out infinite; }
.pin-pa .pin-ring { stroke:var(--cyan); animation-delay:.4s; }
.pin-it .pin-ring { animation-delay:.8s; }
.pin-label { font-family:var(--f-body); font-size:11px; font-weight:700; letter-spacing:.03em; fill:rgba(245,246,250,.92); }
.pin-sub   { font-family:var(--f-body); font-size:9px; fill:rgba(245,246,250,.55); }
@media (prefers-reduced-motion:reduce) { .pin-ring { animation:none; } .map-route { stroke-dashoffset:0; } }
.map-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.map-card { background:rgba(245,246,250,.05); border:1px solid rgba(245,246,250,.1); border-radius:var(--r-lg); padding:20px 22px; display:flex; flex-direction:column; gap:6px; }
.map-card__city { font-family:var(--f-display); font-weight:700; font-size:1.0625rem; color:var(--on-dark-strong); }
.map-card__role { font-size:.8125rem; color:var(--on-dark-soft); line-height:1.5; }
.map-card__status { display:flex; align-items:center; gap:6px; font-size:.75rem; color:var(--cyan); font-weight:600; margin-top:4px; }
.map-card__status::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--cyan); animation:blink 2.5s ease infinite; flex-shrink:0; }
@media (max-width:640px) { .map-cards { grid-template-columns:1fr; gap:10px; } }
@media (max-width:480px) { .footer-grid { grid-template-columns:1fr; } }

/* ── STICKY CTA (mobile) ────────────────────────────────────── */
.sticky-cta { display:none; }
@media (max-width:860px) {
  .sticky-cta {
    display:flex; position:fixed; bottom:0; left:0; right:0;
    z-index:var(--z-overlay); padding:12px 20px 22px;
    background:linear-gradient(to top, rgba(245,246,250,.97) 60%, transparent);
    pointer-events:none; opacity:0; transform:translateY(8px);
    transition:opacity .3s ease, transform .3s ease;
  }
  .sticky-cta.is-visible { opacity:1; transform:none; pointer-events:auto; }
  .sticky-cta .btn-primary { flex:1; justify-content:center; }
  /* back-to-top sits above the sticky CTA bar (~84px tall) */
  .to-top { bottom:90px; }
}
@media (prefers-reduced-motion:reduce) { .sticky-cta { transition:none; } }

/* ── REVEAL — visible by default, enhanced only when JS active ─ */
.js .reveal { opacity:0; transform:translateY(16px); transition:opacity .65s ease, transform .65s ease; }
.js .reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce) {
  .js .reveal { opacity:1; transform:none; transition:none; }
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width:960px) {
  .hero { grid-template-columns:1fr; gap:48px; padding-top:120px; }
  .hero-visual { display:none; }
  .bento { grid-template-columns:1fr; }
  .bc-feat { grid-column:span 1; }
  .why-grid { grid-template-columns:1fr; gap:36px; }
  .sectors-grid { grid-template-columns:repeat(2,1fr); }
  .svc-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; gap:40px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:none; }
  .stat:nth-child(3){ border-top:1px solid rgba(245,246,250,.08); border-right:1px solid rgba(245,246,250,.08); }
  .stat:nth-child(4){ border-top:1px solid rgba(245,246,250,.08); border-right:none; }
}
@media (max-width:640px) {
  .wrap { padding-inline:20px; }
  .section { padding:72px 0; }
  .hero { padding:104px 20px 64px; }
  .hero-h1 { font-size:2.25rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:24px; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  /* On phones the in-bar CTA would overflow the pill; navigation lives in the
     hamburger menu (incl. Contatti) and the hero shows a prominent CTA. */
  .nav-cta { display:none; }
}

/* ── SECTOR CARDS — stagger reveal on scroll ─────────────────── */
.js .sectors-grid .sector { opacity:0; transform:translateY(14px); transition:opacity .5s ease, transform .5s ease; }
.js .sectors-grid.in .sector { opacity:1; transform:none; }
.js .sectors-grid.in .sector:nth-child(2) { transition-delay:.07s; }
.js .sectors-grid.in .sector:nth-child(3) { transition-delay:.14s; }
.js .sectors-grid.in .sector:nth-child(4) { transition-delay:.21s; }
.js .sectors-grid.in .sector:nth-child(5) { transition-delay:.28s; }
.js .sectors-grid.in .sector:nth-child(6) { transition-delay:.35s; }
@media (prefers-reduced-motion:reduce) { .js .sectors-grid .sector { opacity:1; transform:none; transition:none; } }

/* ── BENTO CARDS — stagger reveal on scroll ──────────────────── */
.js .bento .bc { opacity:0; transform:translateY(14px); transition:opacity .55s ease, transform .55s ease; }
.js .bento.in .bc { opacity:1; transform:none; }
.js .bento.in .bc:nth-child(2) { transition-delay:.09s; }
.js .bento.in .bc:nth-child(3) { transition-delay:.18s; }
.js .bento.in .bc:nth-child(4) { transition-delay:.27s; }
.js .bento.in .bc:nth-child(5) { transition-delay:.36s; }
@media (prefers-reduced-motion:reduce) { .js .bento .bc { opacity:1; transform:none; transition:none; } }

/* ── WORLD MAP — real SVG img + SVG overlay ──────────────────── */
.world-map {
  display:block; width:100%; height:auto;
  /* Convert simplemaps SVG (light fills) to dark-tech look matching --ink section */
  filter: invert(1) sepia(0.25) saturate(3) hue-rotate(185deg) brightness(0.32);
}
.map-overlay { position:absolute; top:0; left:0; width:100%; height:100%; pointer-events:none; overflow:visible; }
/* pathLength="1000" normalises all route paths — dasharray 1000 = full path */
.map-route, .map-route.r2, .map-route.r-short { stroke-dasharray:1000; stroke-dashoffset:1000; }

/* ── CHI SIAMO — about stats ─────────────────────────────────── */
.about-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:40px; }
@media (max-width:700px) { .about-stats { grid-template-columns:repeat(2,1fr); } }
.about-stat { padding:24px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl); }
.about-stat__n { font-family:var(--f-display); font-size:2rem; font-weight:900; color:var(--ink); line-height:1; margin-bottom:8px; }
.about-stat__n span { font-size:1.2rem; color:var(--blue); }
.about-stat__l { font-size:.8rem; color:var(--ink-2); margin-bottom:14px; line-height:1.4; }
.about-stat__bar { background:var(--border); border-radius:99px; height:4px; overflow:hidden; }
.about-stat__fill { height:100%; border-radius:99px; background:linear-gradient(90deg,var(--blue),var(--cyan)); }

/* ── BENTO CARD MOCKUPS ───────────────────────────────────────── */
.bc-mockup { margin-top:18px; padding:11px 13px; background:var(--paper); border-radius:var(--r-md); border:1px solid var(--border); font-size:.76rem; line-height:1.4; }
/* Alert rows (Market Intelligence card) */
.bcm-row { display:flex; align-items:center; gap:8px; padding:5px 0; border-bottom:1px solid rgba(0,0,0,.06); }
.bcm-row:last-child { border-bottom:none; }
.bcm-dot { width:7px; height:7px; border-radius:50%; background:var(--cyan); flex-shrink:0; animation:pulse-cta 2s ease-in-out infinite; }
.bcm-row--alert .bcm-label { color:var(--blue-text); font-weight:700; }
.bcm-label { color:var(--ink-2); }
.bcm-val { margin-left:auto; font-weight:700; color:var(--ink); }
.bcm-val.up { color:var(--cyan); }
.bcm-val.down { color:#e17055; }
.bcm-val.flat { color:var(--ink-muted,#6B7A89); }
/* Supplier bar (Sourcing card) */
.bcm-sup-name { font-weight:700; color:var(--ink); margin-bottom:8px; font-size:.76rem; }
.bcm-bar-wrap { background:var(--border); border-radius:99px; height:5px; overflow:hidden; margin-bottom:5px; }
.bcm-bar { height:100%; border-radius:99px; background:linear-gradient(90deg,var(--blue),var(--cyan)); transition:width .8s ease; }
.bcm-sup-score { font-size:.7rem; color:var(--cyan); font-weight:700; letter-spacing:.02em; }
/* Checklist (Quality card) */
.bcm-check { display:flex; align-items:center; gap:8px; padding:4px 0; color:var(--ink-muted,#6B7A89); font-size:.76rem; }
.bcm-check + .bcm-check { border-top:1px solid rgba(0,0,0,.05); }
.bcm-check::before { content:''; width:15px; height:15px; border-radius:3px; border:1.5px solid var(--border); flex-shrink:0; background-repeat:no-repeat; background-position:center; background-size:11px; }
.bcm-check.done { color:var(--ink-2); }
.bcm-check.done::before { background-color:var(--blue); border-color:var(--blue); background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.5 6l2.5 2.5 4.5-5' stroke='white' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.bcm-check.active::before { border-color:var(--cyan); }
/* Shipment tracker (Logistics card) */
.bcm-track { display:flex; align-items:flex-start; gap:0; padding-top:4px; }
.bcm-step { display:flex; flex-direction:column; align-items:center; gap:4px; flex:0 0 auto; }
.bcm-step-dot { width:10px; height:10px; border-radius:50%; background:var(--border); border:2px solid var(--border); flex-shrink:0; }
.bcm-step.done .bcm-step-dot { background:var(--blue); border-color:var(--blue); }
.bcm-step.active .bcm-step-dot { background:var(--surface); border-color:var(--cyan); box-shadow:0 0 0 3px rgba(0,206,201,.2); animation:pulse-cta 2s ease-in-out infinite; }
.bcm-step-lbl { font-size:.65rem; font-weight:600; color:var(--ink-muted,#6B7A89); text-align:center; width:44px; line-height:1.2; }
.bcm-step.done .bcm-step-lbl { color:var(--blue); }
.bcm-step.active .bcm-step-lbl { color:var(--cyan); }
.bcm-track-line { flex:1; height:2px; background:var(--border); margin-top:4px; align-self:flex-start; margin-top:8px; }
.bcm-track-line.done { background:var(--blue); }

/* ── SUPPLIER CARD TABS ───────────────────────────────────────── */
.sc-tabs { display:flex; gap:4px; margin-bottom:14px; padding:3px; background:var(--surface-2); border-radius:var(--r-sm); }
.sc-tab { flex:1; padding:6px 10px; border-radius:calc(var(--r-sm) - 2px); font-size:.72rem; font-weight:700; letter-spacing:.02em; color:var(--ink-muted); cursor:pointer; transition:background .15s, color .15s; text-align:center; }
.sc-tab.active { background:var(--surface); color:var(--ink); box-shadow:0 1px 4px rgba(30,39,46,.1); }
.sc-panel { display:none; }
.sc-panel.active { display:block; }
