/* FUSAUSD static scaffold v3 (root-level, file:// safe) */
:root{
  --bg:#07090f;
  --fg:#ffffff;
  --muted:rgba(255,255,255,0.74);
  --muted2:rgba(255,255,255,0.56);
  --card:rgba(10,12,18,0.72);
  --stroke:rgba(255,255,255,0.14);
  --stroke2:rgba(255,255,255,0.20);
  /* Majorelle Blue (placeholder hex; insert Pantone/RGB/CMYK later) */
  --majorelle:#6050dc;
  --majorelle2:rgba(96,80,220,0.24);
  --shadow:0 20px 80px rgba(0,0,0,0.55);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:Roboto,system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
a:hover{opacity:0.92}

/* header */
.header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  background:rgba(7,9,15,0.66);
  border-bottom:1px solid rgba(255,255,255,0.10);
  backdrop-filter:blur(10px);
}
.header-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 18px;
  gap:14px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:180px;
}
.brand img{height:26px;width:auto;display:block}
.brand .brand-text{font-weight:700;letter-spacing:0.06em}
.nav{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:flex-end}
.nav a{font-size:13px;color:var(--muted)}
.nav a.active{color:var(--fg)}

/* language selector */
.header-right{display:flex;align-items:center;gap:14px}
.lang{
  position:relative;
  display:flex;
  align-items:center;
}
.lang-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.30);
  color:rgba(255,255,255,0.86);
  font-size:12px;
  cursor:pointer;
}
.lang-menu{
  position:absolute;
  right:0;
  top:42px;
  min-width:180px;
  padding:10px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(5,6,10,0.92);
  backdrop-filter:blur(12px);
  box-shadow:0 20px 70px rgba(0,0,0,0.55);
}
.lang-menu button{
  width:100%;
  text-align:left;
  border:none;
  background:transparent;
  color:rgba(255,255,255,0.82);
  padding:8px 10px;
  border-radius:12px;
  font-size:12px;
  cursor:pointer;
}
.lang-menu button:hover{background:rgba(255,255,255,0.06)}

/* hero */
.hero{
  position:relative;
  /* Cap hero footprint on very tall displays (e.g., 4K) to avoid a large empty gap. */
  min-height: clamp(650px, 80vh, 880px);
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  /* HERO background is an animated scrolling map (no static hero image). */
  background:
    radial-gradient(1200px 700px at 70% 30%, rgba(96,80,220,0.16) 0%, rgba(7,9,15,0.00) 55%),
    radial-gradient(900px 520px at 20% 15%, rgba(255,255,255,0.05) 0%, rgba(7,9,15,0.00) 55%),
    linear-gradient(180deg, rgba(7,9,15,1.00) 0%, rgba(7,9,15,0.92) 35%, rgba(7,9,15,1.00) 100%);
}
.hero-bg::after{
  content:"";
  position:absolute;
  inset:0;
  /* darken + preserve readability over animation (reduced so map remains readable) */
  background:linear-gradient(180deg, rgba(7,9,15,0.06) 0%, rgba(7,9,15,0.18) 55%, rgba(7,9,15,0.30) 100%);
}

#heroMap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

#heroVanta{
  position:absolute;
  inset:0;
}
#heroFx{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0.18;
  pointer-events:none;
  mix-blend-mode:screen;
}
.hero-inner{
  position:relative;
  /* Match the hero container height (which is capped on very tall screens). */
  min-height:100%;
  max-width:1200px;
  margin:0 auto;
  padding-top:72px; /* header offset */
}
.hero-grid{
  position:relative;
  /* Keep the hero content block tied to the capped hero height. */
  min-height:calc(100% - 72px);
  display:grid;
  grid-template-columns: 1fr 420px;
  align-items:flex-start;
  gap:18px;
}
.hero-left{
  position:relative;
  display:flex;
  align-items:flex-start;
}
.hero-content{
  padding:34px 60px 60px 60px;
  max-width:680px;
}
.hero-title{
  margin:0 0 14px 0;
  font-weight:800;
  font-size:42px;
  line-height:1.06;
  letter-spacing:0.02em;
  text-transform:uppercase;
}
.hero-text{
  margin:0 0 18px 0;
  color:var(--muted);
  font-size:16px;
  line-height:1.55;
}
.hero-text p{margin:0 0 12px 0}

.contract-box{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-top:10px;
}
.pill{
  display:flex;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(0,0,0,0.35);
  border:1px solid var(--stroke);
  box-shadow:0 10px 40px rgba(0,0,0,0.35);
}
.pill .k{font-size:12px;color:var(--muted2);letter-spacing:0.02em}
.pill .v{font-size:12px;color:var(--fg);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--stroke2);
  background:linear-gradient(180deg, rgba(96,80,220,0.90) 0%, rgba(96,80,220,0.62) 100%);
  color:var(--fg);
  font-weight:700;
  font-size:12px;
  cursor:pointer;
}
.btn.secondary{
  background:rgba(0,0,0,0.35);
  border:1px solid var(--stroke);
  color:var(--muted);
  font-weight:600;
}
.btn:active{transform:translateY(1px)}

.hero-right{
  position:relative;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
}
.hero-logo{
  padding:34px 22px 0 22px;
  width:100%;
  display:flex;
  justify-content:flex-end;
}
.hero-logo img{
  width:260px;
  max-width:100%;
  height:auto;
  filter:drop-shadow(0 24px 70px rgba(0,0,0,0.70));
}
.hero-links{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.center-links{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
}
.center-links .ext-link{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.center-links .ext-label{
  font-size:12px;
  line-height:1.2;
  color:rgba(255,255,255,0.78);
}
.center-links img{height:26px;width:auto;opacity:0.95}

/* placeholders */
.section{
  max-width:1200px;
  margin:0 auto;
  padding:64px 18px;
}

/* Majorelle Blue contact bar (beneath the 5-panel) */
.cta-bar{
  position:relative;
  width:100%;
  background:var(--majorelle);
  padding:26px 18px;
  overflow:hidden;
}
.cta-bar::before{
  content:"";
  position:absolute;
  inset:0;
  /* Vertical fade to black at top/bottom for a cleaner transition */
  background:linear-gradient(180deg,
    rgba(7,9,15,0.95) 0%,
    rgba(7,9,15,0.00) 22%,
    rgba(7,9,15,0.00) 78%,
    rgba(7,9,15,0.95) 100%
  );
  pointer-events:none;
}
.cta-bar-inner{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.cta-bar-title{
  font-weight:800;
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.92);
}
.cta-bar-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  justify-content:flex-end;
}
.cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.28);
  background:rgba(0,0,0,0.22);
  color:rgba(255,255,255,0.94);
  font-weight:800;
  font-size:12px;
  letter-spacing:0.04em;
  text-transform:uppercase;
}
.cta-btn:hover{opacity:0.92}
.cta-btn:active{transform:translateY(1px)}

@media (max-width: 720px){
  .cta-bar-inner{flex-direction:column; align-items:flex-start;}
  .cta-bar-actions{justify-content:flex-start;}
}

/* Case studies (sticky coin image on right, scrolling text on left) */
.case-studies{
  position:relative;
  width:100%;
  padding:72px 0;
  /* NOTE: avoid breaking `position: sticky` in some browsers.
     We don't need to clip overflow here. */
  overflow:visible;
  background:
    radial-gradient(900px 520px at 80% 25%, rgba(96,80,220,0.18) 0%, rgba(7,9,15,0.00) 58%),
    radial-gradient(700px 460px at 18% 80%, rgba(255,255,255,0.05) 0%, rgba(7,9,15,0.00) 55%),
    linear-gradient(180deg, rgba(7,9,15,1.00) 0%, rgba(7,9,15,0.98) 35%, rgba(7,9,15,1.00) 100%);
}
.case-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 18px;
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap:32px;
  /* IMPORTANT: keep the right column tall so the sticky coin remains in view
     across the full scroll of the left column. */
  align-items:stretch;
}
.case-left{
  min-width:0;
  /* Keep the left content top-aligned while the right column stretches. */
  align-self:start;
}
.case-head{
  padding:0 0 18px 0;
}
.case-kicker{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.28);
  font-weight:900;
  font-size:12px;
  letter-spacing:0.10em;
  text-transform:uppercase;
}
.case-items{
  display:flex;
  flex-direction:column;
  gap:0;
}
.case-item{
  /* Taller than a card but shorter than a full screen so adjacent items overlap
     visually during scroll transitions (works with JS fadeSpan). */
  min-height:80vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:10px 0;
  max-width:560px;
  opacity:0.20; /* JS will ramp this up near viewport center */
  transform:translate3d(0, 20px, 0);
  will-change:opacity, transform;
}
.case-title{
  margin:0 0 10px 0;
  font-weight:900;
  font-size:34px;
  line-height:1.08;
  letter-spacing:-0.02em;
}
.case-text{
  margin:0;
  color:var(--muted);
  font-size:16px;
  line-height:1.60;
}

.case-right{
  min-width:0;
  /* Stretch the column to the full height of the grid row, so sticky has room. */
  align-self:stretch;
}
.case-sticky{
  position:sticky;
  top:96px; /* below header */
  height: calc(100vh - 120px);
  padding:22px 0;
  display:flex;
  justify-content:center;
  align-items:center;
}
.case-coin{
  width:min(520px, 44vw);
  max-width:100%;
  height:auto;
  display:block;
  filter: drop-shadow(0 28px 90px rgba(0,0,0,0.60));
  opacity:0.98;
}

@media (max-width: 980px){
  .case-inner{grid-template-columns: 1fr;}
  .case-sticky{position:relative; top:auto; justify-content:flex-start;}
  .case-coin{width:min(520px, 78vw);} 
  .case-item{min-height:66vh;}
}

@media (max-width: 520px){
  .case-title{font-size:28px;}
  .case-item{min-height:58vh;}
}
.placeholder{
  border:1px dashed rgba(255,255,255,0.22);
  border-radius:var(--radius);
  padding:38px 22px;
  background:rgba(255,255,255,0.03);
  color:var(--muted);
}

/* Five-panel section (5 cards: 3 top, 2 bottom) */
.five-panel{
  /* Pull section upward so it sits closer to the hero on large (incl. 4K) screens.
     On smaller screens we reduce/disable this to avoid overlapping hero text. */
  position:relative;
  z-index:3;
  /* Moderate lift: keep the 5-panel visible on tall screens without overlapping HERO copy/CTAs. */
  margin-top: calc(-1 * clamp(80px, 6vh, 180px));
  padding-top: 12px;
  padding-bottom:72px;
}
.five-head{
  max-width:1100px;
  margin:0 auto;
  padding:0 8px;
  text-align:center;
}
.five-title{
  font-size:28px;
  line-height:1.18;
  font-weight:800;
  letter-spacing:-0.02em;
  margin:0;
  text-align:center;
}
.five-grid{
  max-width:1100px;
  margin:22px auto 0;
  display:grid;
  gap:16px;
  padding:0 8px;
}
.five-grid-top{ grid-template-columns: repeat(3, minmax(0,1fr)); }
.five-grid-bottom{
  grid-template-columns: repeat(2, minmax(0,1fr));
  max-width:820px;
  margin-top:16px;
}
.five-card{
  position:relative;
  border-radius:16px;
  padding:22px 22px 20px;
  background: rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow: 0 14px 40px rgba(0,0,0,0.35);
  overflow:hidden;
  min-height:240px;
}
.five-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(600px 180px at 20% -20%, var(--majorelleSoft), transparent 60%),
    radial-gradient(600px 220px at 80% 120%, rgba(255,255,255,0.05), transparent 60%);
  pointer-events:none;
}
.five-iconWrap{
  width: 39.0625%;
  min-width: 115px;
  max-width: 173px;
  height: 0;
  padding-bottom: 39.0625%;
  border-radius: 18px;
  background: rgba(90,74,170,0.10);
  border: 1px solid rgba(90,74,170,0.22);
  display: grid;
  place-items: center;
  margin-bottom: 16px;
}
.five-icon{
  width:82%;
  height:82%;
  display:block;
  filter: drop-shadow(0 10px 18px rgba(96,80,220,0.18));
}
.five-cardTitle{
  position:relative;
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  letter-spacing:-0.01em;
}
.five-cardText{
  position:relative;
  margin:0;
  color: rgba(255,255,255,0.78);
  font-size:14px;
  line-height:1.55;
}
@media (max-width: 980px){
  .five-panel{
    margin-top: calc(-1 * clamp(40px, 8vh, 140px));
    padding-top:24px;
    padding-bottom:64px;
  }
  .five-grid-top{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .five-grid-bottom{ grid-template-columns: repeat(2, minmax(0,1fr)); max-width:1100px; }
}
@media (max-width: 720px){
  .iconWrap{width:72px; height:72px; border-radius:20px;}
  .five-panel{ margin-top: 0; padding-top: 48px; padding-bottom: 64px; }
  .five-title{ font-size:22px; }
  .five-grid-top{ grid-template-columns: 1fr; }
  .five-grid-bottom{ grid-template-columns: 1fr; }
  .five-card{ min-height:unset; }
  .five-iconWrap{ width:120px; min-width:120px; }
}


.footer{
  border-top:1px solid rgba(255,255,255,0.10);
  padding:30px 18px;
  color:var(--muted2);
  max-width:1200px;
  margin:0 auto;
  font-size:12px;
}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-logo{justify-content:flex-start; padding:10px 22px 0 22px;}
  .hero-left{align-items:flex-start;}
  .hero-content{padding:28px 22px 32px 22px;}
  .hero-title{font-size:34px;}
}
@media (max-width: 520px){
  .hero-title{font-size:28px;}
  .pill{padding:9px 10px}
  .btn{padding:9px 10px}
}

/* HERO map animation canvas */
#heroMap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}

/* ================================
   Contact page (Part 1)
   Two-panel layout: form (left) + Vanta globe (right)
   ================================ */

.contact-stage{
  display: grid;
  grid-template-columns: minmax(320px, 540px) 1fr;
  min-height: calc(100vh - 72px - 64px);
  background: #050608;
}

.contact-stage__left{
  position: relative;
  z-index: 2;
  padding: 28px 18px;
  /* avoid hugging the viewport edge on wide screens */
  padding-left: clamp(24px, 4vw, 84px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-left-inner{
  width: 100%;
  max-width: 520px;
}

.contact-brand{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.contact-logo{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: radial-gradient(circle at 30% 25%, #7f5af0, #2cb67d);
  box-shadow: 0 0 18px rgba(127,90,240,0.35);
}

.contact-logo-img{
  width: 34px;
  height: 34px;
  display: block;
  filter: drop-shadow(0 0 10px rgba(0,0,0,0.6));
}

.contact-brand-text{
  font-weight: 800;
  letter-spacing: 0.06em;
}

.contact-card{
  background: rgba(9,10,12,0.86);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
}

.contact-title{
  margin: 0;
  font-size: 44px;
  line-height: 1.05;
  color: var(--gold);
  letter-spacing: -0.02em;
}

.contact-subtitle{
  margin: 8px 0 16px;
  color: rgba(255,255,255,0.82);
  font-size: 13px;
  line-height: 1.45;
}

.contact-tabs{
  display: flex;
  gap: 10px;
  margin: 10px 0 14px;
  /* thicker blue band with a wider fade to black */
  background:
    linear-gradient(90deg,
      rgba(0,0,0,0.85) 0%,
      rgba(96,80,220,0.62) 18%,
      rgba(96,80,220,0.62) 82%,
      rgba(0,0,0,0.85) 100%
    ),
    linear-gradient(180deg,
      rgba(0,0,0,0.88) 0%,
      rgba(0,0,0,0.10) 38%,
      rgba(0,0,0,0.10) 62%,
      rgba(0,0,0,0.88) 100%
    );
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 999px;
  padding: 10px;
  box-shadow: 0 0 40px rgba(96,80,220,0.16);
}

.contact-tab{
  flex: 1;
  border: 1px solid rgba(255,255,255,0.55);
  border-radius: 999px;
  padding: 10px 12px;
  cursor: pointer;
  font-weight: 700;
  font-size: 12px;
  color: rgba(255,255,255,0.92);
  background: rgba(0,0,0,0.20);
}

.contact-tab.is-active{
  background: var(--majorelle);
  color: #ffffff;
  border-color: rgba(255,255,255,0.92);
  box-shadow: 0 0 18px rgba(96,80,220,0.26);
}

.contact-form{
  display: block;
}

.contact-panel[hidden]{
  display: none;
}

/* Honeypot spam trap: keep it out of sight but present in DOM */
.hp{
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}

.row2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.field{
  margin-bottom: 10px;
}

.label{
  display: block;
  font-size: 12px;
  margin: 0 0 6px;
  color: rgba(255,255,255,0.74);
}

.input,
.textarea,
.select{
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.35);
  color: rgba(255,255,255,0.92);
  padding: 10px 12px;
  font-size: 13px;
  outline: none;
}

.textarea{
  resize: vertical;
  min-height: 112px;
}

.input:focus,
.textarea:focus,
.select:focus{
  border-color: rgba(96,80,220,0.65);
  box-shadow: 0 0 0 3px rgba(96,80,220,0.14);
}

.select{
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(255,255,255,0.55) 50%),
    linear-gradient(135deg, rgba(255,255,255,0.55) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(1em + 2px), calc(100% - 13px) calc(1em + 2px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 36px;
}

/* intl-tel-input container */
.iti{
  width: 100%;
}

.contact-status{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.88);
  font-size: 12px;
}

.contact-status[data-kind="ok"]{
  border-color: rgba(44,182,125,0.35);
}

.contact-status[data-kind="error"]{
  border-color: rgba(255,77,77,0.35);
}

.contact-send{
  margin-top: 12px;
  width: 100%;
  border: 1px solid rgba(255,255,255,0.92);
  border-radius: 999px;
  padding: 11px 14px;
  font-weight: 800;
  cursor: pointer;
  background: var(--majorelle);
  color: #ffffff;
  box-shadow: 0 0 18px rgba(96,80,220,0.22);
}

.contact-send:disabled{
  opacity: 0.7;
  cursor: not-allowed;
}

.contact-stage__right{
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at 15% 20%, rgba(127,90,240,0.35), transparent 50%),
    radial-gradient(circle at 70% 60%, rgba(44,182,125,0.22), transparent 55%),
    #050608;
}

.contact-stage__right #heroVanta{
  position: absolute;
  inset: 0;
}

@media (max-width: 980px){
  .contact-stage{
    grid-template-columns: 1fr;
  }
  .contact-stage__right{
    min-height: 320px;
    order: -1;
  }
  .contact-title{
    font-size: 38px;
  }
}

@media (max-width: 520px){
  .row2{ grid-template-columns: 1fr; }
  .contact-stage__left{ padding: 22px 14px; padding-left: 14px; }
  .contact-card{ padding: 16px 14px 14px; }
  .contact-title{ font-size: 34px; }
}



/* ================================
   Legal page (PDF document list)
   Left column: documents. Right column: Vanta globe.
   ================================ */

.legal-stage{
  display: grid;
  grid-template-columns: minmax(320px, 560px) 1fr;
  min-height: calc(100vh - 72px - 64px);
  background: #050608;
}

.legal-stage__left{
  position: relative;
  z-index: 2;
  padding: 28px 18px;
  padding-left: clamp(24px, 4vw, 84px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.legal-left-inner{
  width: 100%;
  max-width: 560px;
}

.legal-card{
  background: rgba(9,10,12,0.86);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
}

.legal-stage .legal-title{
  margin: 0;
  font-size: 44px;
  line-height: 1.05;
  color: var(--gold);
  letter-spacing: -0.02em;
}

.legal-stage .legal-subtitle{
  margin: 8px 0 16px;
  color: rgba(255,255,255,0.82);
  font-size: 13px;
  line-height: 1.45;
}

.legal-docs{
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
}

.legal-doc{
  display: flex;
  gap: 14px;
  align-items: center;
  text-decoration: none;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
}

.legal-doc:hover{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.16);
  transform: translateY(-1px);
}

.legal-stamp{
  width: 68px;
  min-width: 68px;
  height: 86px;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.20);
  box-shadow: 0 14px 38px rgba(0,0,0,0.48);
}

.legal-stamp img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: contrast(1.04) brightness(1.02);
}

.legal-stamp::after{
  /* subtle stamp-style inner border */
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: 10px;
  border: 1px dashed rgba(255,255,255,0.18);
  pointer-events: none;
}

.legal-stamp-badge{
  position: absolute;
  bottom: 6px;
  left: 6px;
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(0,0,0,0.62);
  border: 1px solid rgba(255,255,255,0.24);
  color: rgba(255,255,255,0.88);
  letter-spacing: 0.06em;
}

.legal-doc-title{
  font-size: 13px;
  font-weight: 800;
  color: rgba(255,255,255,0.92);
  line-height: 1.35;
}

.legal-stage__right{
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at 15% 20%, rgba(127,90,240,0.35), transparent 50%),
    radial-gradient(circle at 70% 60%, rgba(44,182,125,0.22), transparent 55%),
    #050608;
}

.legal-stage__right #heroVanta{
  position: absolute;
  inset: 0;
}

/* RTL tweak: keep stamp + title aligned cleanly */
[dir="rtl"] .legal-doc{
  flex-direction: row-reverse;
}
[dir="rtl"] .legal-stamp-badge{
  left: auto;
  right: 6px;
}

@media (max-width: 980px){
  .legal-stage{
    grid-template-columns: 1fr;
  }
  .legal-stage__right{
    min-height: 320px;
    order: -1;
  }
  .legal-stage .legal-title{
    font-size: 38px;
  }
}

@media (max-width: 520px){
  .legal-stage__left{ padding: 22px 14px; padding-left: 14px; }
  .legal-card{ padding: 16px 14px 14px; }
  .legal-stage .legal-title{ font-size: 34px; }
  .legal-doc{ padding: 11px 10px; }
  .legal-stamp{ width: 62px; min-width: 62px; height: 80px; }
}

/* =============================
   Legal footnote (index.html)
   ============================= */

.legal-footnote{
  width: 100%;
  padding: 58px 0 46px;
  background:
    radial-gradient(700px 380px at 18% 30%, rgba(96,80,220,0.12) 0%, rgba(7,9,15,0.00) 62%),
    radial-gradient(760px 420px at 82% 74%, rgba(255,255,255,0.05) 0%, rgba(7,9,15,0.00) 58%),
    linear-gradient(180deg, rgba(7,9,15,1.00) 0%, rgba(7,9,15,1.00) 100%);
}

.legal-inner{
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 22px;
}

.legal-kicker{
  display: inline-block;
  font-weight: 900;
  letter-spacing: 0.18em;
  font-size: 12px;
  color: rgba(255,255,255,0.72);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 999px;
  padding: 7px 12px;
  background: rgba(255,255,255,0.04);
}

.legal-title{
  margin: 14px 0 10px;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.01em;
}

.legal-lead{
  margin: 0 0 14px;
  color: rgba(255,255,255,0.72);
  font-size: 13.5px;
  line-height: 1.55;
  max-width: 920px;
}

.legal-list{
  margin: 0;
  padding-left: 18px;
  max-width: 980px;
  color: rgba(255,255,255,0.70);
  font-size: 12.6px;
  line-height: 1.64;
}

.legal-list li{
  margin: 10px 0;
}

html[dir="rtl"] .legal-list{
  padding-left: 0;
  padding-right: 18px;
}

.legal-more{
  margin-top: 16px;
}

.legal-link{
  display: inline-block;
  color: #ffffff;
  text-decoration: none;
  font-weight: 800;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(96,80,220,0.16);
}

.legal-link:hover{
  background: rgba(96,80,220,0.24);
}

@media (max-width: 980px){
  .legal-footnote{ padding: 52px 0 40px; }
  .legal-title{ font-size: 20px; }
  .legal-lead{ font-size: 13px; }
  .legal-list{ font-size: 12.4px; }
}

@media (max-width: 520px){
  .legal-inner{ padding: 0 14px; }
  .legal-title{ font-size: 18px; }
  .legal-lead{ font-size: 12.8px; }
  .legal-list{ font-size: 12.1px; }
}


/* Ecosystem page */
.eco-hero{
  position:relative;
  padding-top:110px; /* below fixed header */
  padding-bottom:72px;
  overflow:hidden;
}
.eco-bg{
  position:absolute;
  inset:0;
  background-image: url("../assets/F1%20Drama%20shot%20HERO%20WEB.png");
  background-size:cover;
  background-position:center top;
  background-repeat:no-repeat;
  filter:saturate(1.12) contrast(1.08) brightness(1.04);
  transform:scale(1.02);
}
.eco-shade{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1200px 700px at 70% 22%, rgba(96,80,220,0.16) 0%, rgba(7,9,15,0.00) 58%),
    radial-gradient(900px 520px at 22% 18%, rgba(255,255,255,0.06) 0%, rgba(7,9,15,0.00) 60%),
    linear-gradient(180deg, rgba(7,9,15,0.68) 0%, rgba(7,9,15,0.54) 38%, rgba(7,9,15,0.72) 100%);
  pointer-events:none;
}
.eco-inner{
  position:relative;
  max-width:1200px;
  margin:0 auto;
  padding:0 18px;
}
.eco-card{
  max-width:980px;
  margin:0 auto;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,0.14);
  background: rgba(10,12,18,0.80);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  padding: 34px 34px 26px;
}
.eco-title{
  margin:0 0 16px 0;
  font-weight:900;
  font-size:38px;
  letter-spacing:-0.02em;
  line-height:1.06;
}
.eco-copy{
  color: var(--muted);
  font-size:16px;
  line-height:1.70;
}
.eco-p{margin:0 0 16px 0;}
.eco-list{
  margin: 0 0 18px 18px;
  padding: 0 0 0 18px;
}
.eco-list li{margin:0 0 10px 0;}
.eco-block{margin: 10px 0 14px 0;}
.eco-sub{
  margin: 0 0 10px 0;
  font-weight:900;
  color: rgba(255,255,255,0.92);
  letter-spacing:-0.01em;
}
.eco-link{
  color: rgba(255,255,255,0.92);
  text-decoration: underline;
  text-decoration-color: rgba(96,80,220,0.60);
  text-underline-offset: 3px;
}
.eco-link:hover{opacity:0.92;}

/* RTL support */
html[dir="rtl"] .eco-card{direction:rtl;}
html[dir="rtl"] .eco-list{margin-left:0; margin-right:18px; padding-left:0; padding-right:18px;}

@media (max-width: 980px){
  .eco-card{max-width:100%;}
}

@media (max-width: 720px){
  .eco-hero{padding-top:96px; padding-bottom:56px;}
  .eco-card{padding: 24px 20px 18px;}
  .eco-title{font-size:30px;}
  .eco-copy{font-size:15px;}
  .eco-list{margin-left:14px; padding-left:16px;}
  html[dir="rtl"] .eco-list{margin-right:14px; padding-right:16px;}
}

@media (max-width: 420px){
  .eco-title{font-size:26px;}
}

/* Brand assets page */
.brand-preview-link{display:block; text-decoration:none;}
.brand-preview-link:focus{outline:2px solid rgba(96,80,220,0.9); outline-offset:3px; border-radius:16px;}

.hero--compact .hero-inner{padding-top: 108px; padding-bottom: 52px;}
.hero-logo--sm{width: 320px; max-width: 78vw;}

.brand-actions{margin-top: 18px;}
.brand-canonical{margin: 14px 0 0 0; color: rgba(255,255,255,0.82); font-size: 13px; line-height: 1.55;}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}

.brand-section{padding-top: 18px; padding-bottom: 62px; margin-top: -24px;}
.brand-shell{max-width: 1120px; margin: 0 auto; padding: 0 20px;}

.brand-block{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(10,12,18,0.70);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  padding: 22px;
}
.brand-block--mt{margin-top: 14px;}

.brand-head{display:flex; align-items:flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap;}
.brand-h2{margin:0; font-weight: 900; letter-spacing: -0.02em;}

.brand-tabs{display:flex; align-items:center; gap: 8px; padding: 6px; border-radius: 999px; border:1px solid rgba(255,255,255,0.14); background: rgba(0,0,0,0.22);}
.brand-tab{
  appearance:none; border:0; cursor:pointer;
  padding: 10px 14px;
  border-radius: 999px;
  background: transparent;
  color: rgba(255,255,255,0.86);
  font-weight: 800;
  letter-spacing: -0.01em;
}
.brand-tab:hover{background: rgba(255,255,255,0.06);}
.brand-tab.is-active{
  background: rgba(96,80,220,0.92);
  color: #fff;
  box-shadow: 0 10px 30px rgba(96,80,220,0.20);
}

.brand-panels{margin-top: 14px;}
.brand-grid{display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px;}
.brand-card{
  border-radius: 16px;
  border:1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.20);
  overflow:hidden;
}
.brand-preview{display:flex; align-items:center; justify-content:center; padding: 26px; min-height: 180px;}
.brand-preview--dark{background: rgba(0,0,0,0.35);} 
.brand-preview--mid{background: rgba(255,255,255,0.04);} 
.brand-preview--light{background: rgba(255,255,255,0.92);} 
.brand-preview img{max-width: 100%; max-height: 120px; object-fit: contain;}

.brand-meta{display:flex; align-items:center; justify-content:space-between; gap: 10px; padding: 14px 14px 16px;}
.brand-name{font-weight: 800; color: rgba(255,255,255,0.88); font-size: 13px;}
.brand-actions-row{display:flex; gap: 10px;}

.color-card{display:flex; align-items: stretch; gap: 18px; margin-top: 16px;}
.color-swatch{width: 120px; border-radius: 16px; background: #6050DC; border:1px solid rgba(255,255,255,0.14); box-shadow: 0 20px 40px rgba(96,80,220,0.25);}
.color-meta{flex:1; min-width: 220px;}
.color-name{font-weight: 900; margin-bottom: 10px;}
.color-values{list-style:none; padding:0; margin:0; display:grid; grid-template-columns: 1fr 1fr; gap: 10px 14px;}
.color-values li{display:flex; justify-content: space-between; gap: 12px; border:1px solid rgba(255,255,255,0.10); background: rgba(0,0,0,0.18); border-radius: 14px; padding: 10px 12px;}
.color-values .k{color: rgba(255,255,255,0.78); font-weight: 800;}
.color-values .v{color: rgba(255,255,255,0.92); font-weight: 800;}

/* RTL */
html[dir="rtl"] .brand-head{flex-direction: row-reverse;}
html[dir="rtl"] .brand-meta{flex-direction: row-reverse;}
html[dir="rtl"] .color-values li{flex-direction: row-reverse;}

@media (max-width: 980px){
  .brand-grid{grid-template-columns: repeat(2, minmax(0, 1fr));}
}

@media (max-width: 720px){
  .hero--compact .hero-inner{padding-top: 100px; padding-bottom: 46px;}
  .brand-section{padding-top: 14px; padding-bottom: 56px; margin-top: -16px;}
  .brand-block{padding: 20px;}
  .brand-grid{grid-template-columns: 1fr;}
  .color-card{flex-direction: column;}
  .color-swatch{width: 100%; height: 86px;}
  .color-values{grid-template-columns: 1fr;}
}
