/* ============================================================
   GLOBAL — shared across all templates
   ============================================================ */

/* ── TOKENS ── */
:root {
  --blue:         #2B3690;
  --blue-deep:    #222C76;
  --blue-soft:    #EAEEFC;
  --blue-softer:  #F3F5FD;
  --white:        #FFFFFF;
  --ink:          #1C2350;
  --ink-dim:      #5C6493;
  --ink-faint:    #9298BD;
  --paper:        #F2F5FE;
  --paper-dim:    rgba(242, 245, 254, .74);
  --paper-faint:  rgba(242, 245, 254, .48);
  --steel:        #4A6FA5;
  --steel-soft:   #8198C7;
  --red:          #C8302A;
  --red-bright:   #E0433C;
  --line-light:   rgba(28, 35, 80, .12);
  --line-blue:    rgba(242, 245, 254, .20);
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-label:   "Syne", sans-serif;
  --font-body:    "DM Sans", system-ui, sans-serif;
  --font-mono:    "DM Mono", ui-monospace, monospace;
  --maxw:         1280px;
  --gutter:       clamp(20px, 5vw, 72px);
}

/* ── BASE ── */
* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body {
  margin: 0;
  background: var(--blue-soft);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.75;
  font-weight: 400;
  overflow-x: hidden;
}

::selection { background: var(--red); color: #fff; }
a           { color: inherit; text-decoration: none; }
img         { max-width: 100%; display: block; }

.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-inline: var(--gutter);
}

/* ── SHARED COMPONENTS ── */
.eyebrow {
  font-family: var(--font-label);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--steel);
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.eyebrow::before {
  content: "";
  width: 34px;
  height: 2px;
  background: var(--red);
  display: inline-block;
}
.on-blue .eyebrow { color: var(--steel-soft); }

.num-idx {
  font-family: var(--font-label);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--red);
}

/* ── REVEAL ANIMATION ── */
.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition:
    opacity   .9s cubic-bezier(.16, .84, .44, 1),
    transform .9s cubic-bezier(.16, .84, .44, 1);
}
.reveal.in               { opacity: 1; transform: none; }
.reveal[data-d="1"]      { transition-delay: .08s; }
.reveal[data-d="2"]      { transition-delay: .16s; }
.reveal[data-d="3"]      { transition-delay: .24s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ── PROGRESS BAR ── */
.progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: var(--red);
  z-index: 120;
  transition: width .1s linear;
}

/* ── BUTTON ── */
.btn {
  font-family: var(--font-label);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: transform .25s, background .25s, box-shadow .25s, color .25s;
}
.btn-red {
  background: var(--red);
  color: #fff;
  padding: 13px 24px;
  border-radius: 3px;
}
.btn-red:hover {
  background: var(--red-bright);
  transform: translateY(-2px);
  box-shadow: 0 14px 30px -12px rgba(200, 48, 42, .7);
}
.btn-red svg  { transition: transform .25s; }
.btn-red:hover svg { transform: translateX(4px); }

/* ── NAV ── */
header.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  transition: background .4s, backdrop-filter .4s, border-color .4s, padding .4s;
  border-bottom: 1px solid transparent;
  padding: 22px 0;
}
header.nav.scrolled {
  background: rgba(255, 255, 255, .86);
  backdrop-filter: blur(16px) saturate(140%);
  border-bottom-color: var(--line-light);
  padding: 14px 0;
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 13px;
  flex-shrink: 0;
}
.brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--red);
  flex-shrink: 0;
  display: grid;
  place-items: center;
}
.brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 50%;
  display: block;
}
.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.brand-text b {
  font-family: var(--font-label);
  font-weight: 800;
  font-size: 15px;
  letter-spacing: .5px;
  color: var(--paper);
  transition: color .35s;
}
.brand-text span {
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 2.5px;
  color: var(--paper-faint);
  text-transform: uppercase;
  transition: color .35s;
}
header.nav.scrolled .brand-text b    { color: var(--ink); }
header.nav.scrolled .brand-text span { color: var(--steel); }

nav.links {
  display: flex;
  gap: 34px;
  align-items: center;
}
nav.links a {
  font-family: var(--font-label);
  font-weight: 600;
  font-size: 13.5px;
  letter-spacing: .8px;
  color: var(--paper-dim);
  position: relative;
  padding: 4px 0;
  transition: color .25s;
}
nav.links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  height: 2px;
  width: 0;
  background: var(--red);
  transition: width .3s;
}
nav.links a:hover             { color: var(--paper); }
nav.links a:hover::after      { width: 100%; }
header.nav.scrolled nav.links a       { color: var(--ink-dim); }
header.nav.scrolled nav.links a:hover { color: var(--ink); }

.nav-right {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
}

.lang {
  display: flex;
  align-items: center;
  font-family: var(--font-label);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1px;
  border: 1px solid var(--line-blue);
  border-radius: 40px;
  overflow: hidden;
  transition: border-color .35s;
}
header.nav.scrolled .lang { border-color: var(--line-light); }

.lang a,
.lang button {
  background: none;
  border: none;
  color: var(--paper-faint);
  cursor: pointer;
  font: inherit;
  padding: 7px 12px;
  transition: color .2s, background .2s;
  text-transform: uppercase;
  font-size: 12px;
  font-family: var(--font-label);
  font-weight: 700;
  letter-spacing: 1px;
}
.lang a.active,
.lang button.active              { background: var(--paper); color: var(--blue); }
header.nav.scrolled .lang a,
header.nav.scrolled .lang button { color: var(--ink-faint); }
header.nav.scrolled .lang a.active,
header.nav.scrolled .lang button.active { background: var(--blue); color: #fff; }

.burger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  flex-direction: column;
  gap: 5px;
  padding: 6px;
}
.burger span {
  width: 24px;
  height: 2px;
  background: var(--paper);
  display: block;
  transition: .3s;
}
header.nav.scrolled .burger span { background: var(--ink); }

/* ── NAV DROPDOWN ── */
.menu-item { position: relative; display: flex; align-items: center; }

.drop-toggle {
  background: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  padding: 4px 2px;
  color: var(--paper-dim);
  transition: color .25s;
}
header.nav.scrolled .drop-toggle            { color: var(--ink-dim); }
.menu-item:hover .drop-toggle              { color: var(--paper); }
header.nav.scrolled .menu-item:hover .drop-toggle { color: var(--ink); }

.chev { transition: transform .25s; flex-shrink: 0; }
.menu-item:hover .chev { transform: rotate(180deg); }

.dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  padding-top: 10px;
  min-width: 190px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s, transform .2s;
}
.dropdown-inner {
  background: #fff;
  border: 1px solid var(--line-light);
  border-radius: 8px;
  box-shadow: 0 12px 36px -8px rgba(28, 35, 80, .18);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.menu-item:hover .dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
nav.links .dropdown-inner a {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  padding: 9px 14px;
  border-radius: 5px;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
nav.links .dropdown-inner a::after  { display: none; }
nav.links .dropdown-inner a:hover   { background: var(--blue-softer); color: var(--blue); }

/* ── MOBILE MENU ── */
.mmenu {
  position: fixed;
  inset: 0;
  z-index: 99;
  background: rgba(34, 44, 118, .98);
  backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  padding: 0 var(--gutter);
  transform: translateX(100%);
  transition: transform .4s cubic-bezier(.7, 0, .2, 1);
  color: var(--paper);
  overflow-y: auto;
}
.mmenu.open { transform: none; }

.mmenu > a,
.mmenu .menu-item > a {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 34px;
  letter-spacing: -.02em;
  padding: 12px 0;
  color: var(--paper);
  flex: 1;
}
.mmenu > a,
.mmenu .menu-item {
  border-bottom: 1px solid var(--line-blue);
}
.mmenu .dropdown-inner a {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 500;
  padding: 8px 0;
  color: var(--paper-dim);
}
.mmenu .menu-item          { width: 100%; }
.mmenu .drop-toggle        { color: var(--paper); padding: 12px 4px 12px 14px; }
.mmenu .dropdown {
  position: static;
  transform: none;
  opacity: 1;
  pointer-events: auto;
  box-shadow: none;
  border: none;
  border-left: 2px solid var(--blue-soft);
  border-radius: 0;
  padding: 4px 0 4px 16px;
  margin-top: 4px;
  background: none;
  display: none;
}
.mmenu .dropdown-inner         { background: none; box-shadow: none; border: none; padding: 0; }
.mmenu .menu-item.open .dropdown { display: flex; }

.mmenu .mfoot {
  margin-top: 30px;
  display: flex;
  gap: 16px;
  align-items: center;
}
.mmenu .lang {
  display: flex;
  border-color: var(--line-blue);
}

/* ── FOOTER ── */
footer.site {
  background: var(--blue-deep);
  color: var(--paper);
  padding: clamp(64px, 8vh, 96px) 0 40px;
}
.foot-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--line-blue);
}
.foot-brand .brand          { margin-bottom: 24px; }
.foot-brand .brand-text b   { color: var(--paper); }
.foot-brand .brand-text span { color: var(--steel-soft); }
.foot-brand p {
  color: var(--paper-dim);
  font-size: 15px;
  max-width: 34ch;
  margin: 0 0 28px;
}
.foot-tag {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 18px;
  color: var(--steel-soft);
}
.foot-col h4 {
  font-family: var(--font-label);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--paper-faint);
  margin: 0 0 22px;
}
.foot-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 13px;
}
.foot-col a           { font-size: 15px; color: var(--paper-dim); transition: color .2s; }
.foot-col a:hover     { color: var(--paper); }

.partners      { display: flex; flex-direction: column; gap: 14px; }
.plogo {
  border: 1px solid var(--line-blue);
  border-radius: 3px;
  padding: 13px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-label);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .5px;
  color: var(--paper-dim);
}
.plogo .pdot {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1.5px solid var(--steel-soft);
  flex-shrink: 0;
}

.foot-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding-top: 32px;
  flex-wrap: wrap;
}
.foot-bottom .credit {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .5px;
  color: var(--paper-faint);
  line-height: 1.7;
}
.socials { display: flex; gap: 12px; }
.socials a {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid var(--line-blue);
  display: grid;
  place-items: center;
  color: var(--paper-dim);
  transition: .25s;
}
.socials a:hover {
  border-color: var(--red);
  color: var(--red);
  transform: translateY(-3px);
}

/* ── NEWSLETTER ── */
.news-cta          { background: var(--blue); color: var(--paper); }
.news-cta .wrap    { padding-block: clamp(60px, 8vh, 100px); }

.nc-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}
.nc-grid h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(26px, 3.4vw, 44px);
  line-height: 1.04;
  letter-spacing: -.035em;
  margin: 14px 0 0;
  max-width: 16ch;
}
.nc-grid h2 .it { color: var(--red); }

.nc-form {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  min-width: min(420px, 80vw);
}
.nc-form input {
  flex: 1;
  min-width: 220px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid var(--line-blue);
  border-radius: 3px;
  padding: 15px 18px;
  color: var(--paper);
  font-family: var(--font-body);
  font-size: 15px;
  outline: none;
  transition: border-color .2s, background .2s;
}
.nc-form input::placeholder { color: var(--paper-faint); }
.nc-form input:focus {
  border-color: var(--steel-soft);
  background: rgba(255, 255, 255, .11);
}
.nc-note {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .5px;
  color: var(--paper-faint);
  margin-top: 14px;
}

/* ── RESPONSIVE ── */
@media (max-width: 880px) {
  nav.links,
  .lang          { display: none; }
  .burger        { display: flex; }
  .nav-right .btn-red { display: none; }
  .foot-top      { grid-template-columns: 1fr; gap: 40px; }
  .nc-grid       { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  body              { font-size: 16px; }
  .foot-bottom      { flex-direction: column; align-items: flex-start; }
}
