@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;900&display=swap');

/* ---------- Fonts ---------- */
@font-face {
  font-family: 'TT Norms Pro';
  src: url('fonts/AnyConv.com__TTNORMS-REGULAR.woff2') format('woff2'),
       url('fonts/TT-Norms-Regular.otf') format('opentype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'TT Norms Pro';
  src: url('fonts/AnyConv.com__TTNORMS-MEDIUM.woff2') format('woff2'),
       url('fonts/TT-Norms-Medium.otf') format('opentype');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'TT Norms Pro';
  src: url('fonts/AnyConv.com__TTNORMS-BOLD.woff2') format('woff2'),
       url('fonts/TT-Norms-Bold.otf') format('opentype');
  font-weight: 700; font-style: normal; font-display: swap;
}

/* ---------- Resets & base ---------- */
* { margin: 0; padding: 0; box-sizing: border-box; font-synthesis: none; }
html { -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; scroll-behavior: smooth; }
body {
  font-family: 'TT Norms Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  line-height: 1.6; background: #fff; width: 100%;
}

/* keep the reset, but exclude checkbox/radio */
input:not([type="checkbox"]):not([type="radio"]), select, textarea {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
}

/* restore native checkbox + brand color */
input[type="checkbox"]{
  -webkit-appearance: checkbox; -moz-appearance: checkbox; appearance: checkbox;
  width: 18px; height: 18px; accent-color: #00C389;
}

/* iOS form tweaks */
input, select, textarea { border-radius: 0; font-size: 16px; font-family: inherit; }
input::placeholder, input::-webkit-input-placeholder { opacity: 1; }
select { background-image: none; padding-right: 20px; }

/* Typography helpers */
.hero-right, .hero-eyebrow, .hero-title, .hero-launch,
.contest-content, .contest-heading-inline, .contest-subtitle-inline,
.contest-form, .contest-form-title, .contest-copy {
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  font-variant-ligatures: none; font-feature-settings: 'liga' 0, 'clig' 0, 'calt' 0;
}

:root {
  --unnamed-color-ffffff: #FFFFFF;
  --unnamed-font-family-tt-norms-pro: 'TT Norms Pro', 'Inter', Arial, sans-serif;
  --unnamed-font-style-normal: normal;
  --unnamed-font-weight-medium: 500;
  --unnamed-font-size-59: 59px;
  --unnamed-character-spacing--0-71: -0.71px;
  --unnamed-line-spacing-79: 79px;
}

/* ---------- Shared containers ---------- */
.container { width: 100%; max-width: 1920px; margin: 0 auto; background: #fff; position: relative; }

/* ---------- Hero ---------- */
.hero {
  width: 100%;
  aspect-ratio: 1920 / 1009;
  position: relative;
  background-color: #fff;
  overflow: hidden;
}
.hero-content {
  position: absolute; inset: 0; z-index: 10;
  display: flex; align-items: center;
  padding: 0 clamp(24px, 5vw, 120px);
  left: -59px;
  color: #000;
}
.hero-brand { margin: 0; }
.hero-logo { width: clamp(220px, 19.5vw, 375px); height: auto; display: block; mix-blend-mode: lighten; }

.hero-eyebrow {
  font-weight: 500; font-size: clamp(18px, 2.6vw, 59px);
  line-height: 79px; letter-spacing: -0.71px; margin: 0; color:#202944;
}
.hero-title {
  font-weight: 1000; font-size: clamp(64px, 14vw, 293px);
  line-height: 0.93; letter-spacing: -10px; margin: 0; color:#202944;
}
.hero-title-sim { color: #0677ca; }
.hero-launch {
  font-weight: 700; font-size: clamp(18px, 2.1vw, 50px);
  line-height: 104px; letter-spacing: 0; margin: 0; color:#202944;
}

.hero-left { flex: 1; position: relative; display: flex; align-items: flex-end; justify-content: flex-start; z-index: 2; }
.hero-right {
  flex: 1; color: #FFFFFF;
  display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-end;
  gap: clamp(6px, 1.4vw, 24px); padding-bottom: clamp(12px, 6vw, 96px);
}
.hero-phones { width: clamp(360px, 40vw, 760px); height: auto; display: block; position: relative; top: -36px; }

/* Tablet baseline positioning for inline SVGs */
@media (min-width: 577px) {
  .hero-triangle-svg {
    position: absolute; top: -28%; left: -71%;
    width: 113%; height: 178%; z-index: 1; pointer-events: none;
  }
  .hero-right { position: static; text-align: left; align-items: flex-start; }
  .hero-brand, .hero-logo { position: static; margin: 0; background: transparent; }
}

/* Tablet general tweaks (not hiding vectors) */
@media (max-width: 1024px) {
  .hero-phones { width: clamp(320px, 37vw, 560px); top: -16px; }
  .hero-right { margin-left: 58px; }
  .hero { padding-top: clamp(24px, 5vw, 64px); }
}
@media (max-width: 768px) {
  .hero-content { align-items: flex-end; }
  .hero-right { padding-left: 48px; margin-left: -52px; }
  .hero-phones { width: min(62vw, 440px); top: 0; }
}

/* ---------- Intro ---------- */
.intro {
  width: 100%; background: #f5f5f5; position: relative;
  display: flex; align-items: center;
  padding: clamp(40px, 8vw, 120px) clamp(20px, 4.2vw, 80px);
}
@media (max-width: 576px) { .intro { padding: 28px 16px; } }

.intro-content {
  width: 100%; max-width: 1920px; margin: 0 auto;
  display: flex; justify-content: center; align-items: center;
}
.intro-left { width: 100%; max-width: 980px; text-align: center; margin: 0 auto; }

.intro-eyebrow {
  display: inline-flex; align-items: center; justify-content: center;
  gap: clamp(10px, 1.6vw, 20px); margin: 0 0 clamp(16px, 2.2vw, 28px) 0; line-height: 1;
}
.intro-introducing {
  font-weight: 700; font-size: clamp(32px, 6.2vw, 96px);
  color: #0077CB; white-space: nowrap; letter-spacing: -1px;
}
.intro-logo { height: clamp(36px, 6vw, 80px); width: auto; display: inline-block; vertical-align: -5px;
    margin-top: 20px !important;
    
}

.intro-headline {
  font-weight: 700; font-size: clamp(24px, 3.8vw, 56px);
  line-height: 1.25; color: #202A44; margin: 0 0 clamp(14px, 2vw, 22px) 0; letter-spacing: -1px;
}
.intro-highlight { color: #0077CB; }
.intro-description {
  font-weight: 400; font-size: clamp(16px, 2vw, 22px);
  line-height: 1.6; color: #202A44; max-width: 700px; margin: 0 auto;
}
@media (max-width: 640px) { .intro-introducing { white-space: normal; text-wrap: balance; } }

/* ---------- Contest ---------- */
.contest {
  width: 100%; aspect-ratio: 1920 / 1008; position: relative;
  background-color: #202A44; overflow: hidden;
}

/* Use the inline SVGs for the background (avoid duplicate CSS diamond) */
.contest::before { content: none; }

.contest-content {
  position: absolute; inset: 0; z-index: 10; width: 100%; height: 100%;
  display: flex; align-items: stretch;
  padding: 0 clamp(20px, 4.2vw, 80px);
  column-gap: clamp(24px, 3vw, 48px);
}
.contest-left {
  flex: 1; position: relative; display: flex; align-items: flex-end; justify-content: flex-start;
  z-index: 2; height: 100%; overflow: visible;
}
.contest-left picture { position: absolute; left: 0; bottom: 0; display: block; }
.contest-right {
  flex: 1; display: flex; align-items: center; justify-content: flex-start;
  padding-left: clamp(12px, 2vw, 24px); z-index: 3;
}
.contest-copy {
  position: absolute; left: clamp(20px, 4.2vw, 80px); top: clamp(24px, 6vw, 140px);
  z-index: 3; color: #fff;
}
.contest-title {
  margin: 0 0 clamp(8px, 1vw, 16px) 0; color: #fff;
  font-weight: 700; font-size: clamp(36px, 5vw, 120px);
  line-height: 1.05; letter-spacing: -0.5px;
}
.contest-subtitle {
  margin: 0; font-weight: 700; font-size: clamp(16px, 2.2vw, 32px);
  line-height: 1.2; color: #8BD4FF;
}
.contest-phones { width: clamp(360px, 42vw, 920px); height: auto; display: block; position: static; }

/* Contest responsiveness */
@media (min-width: 1200px) {
  .contest-left picture { left: -72px; }
  .contest-phones { width: 880px; }
  .contest-form { width: 100%; margin-left: 0; }
  .contest-content { column-gap: 160px; }
  .contest-right { padding-left: 72px; }
}
@media (max-width: 1440px) {
  .contest-left picture { left: -24px; }
  .contest-phones { width: min(54vw, 1100px); }
}
@media (max-width: 992px) {
  .contest-left picture { left: 0; }
  .contest-phones { width: min(66vw, 720px); }
  .contest-right { justify-content: center; padding-left: 0; }
  .contest-form { width: 100%; }
}
@media (max-width: 768px) { .contest-left picture { margin-top: clamp(-160px, -22vw, -84px); } }
@media (max-width: 576px) {
  .contest { aspect-ratio: auto; min-height: 178vw; }
  .contest-content { padding: 0 clamp(12px, 4vw, 24px); display: flex; flex-direction: column; row-gap: 0; }
  .contest-right { width: 100%; padding-left: 0; align-items: stretch; }
  .contest-form { width: 100%; }
  .contest-left { width: 100%; order: 2; align-items: center; justify-content: center; height: auto; }
  .contest-left picture { position: static; left: auto; bottom: auto; margin-top: clamp(-180px, -18vw, -102px); }
  .contest-phones { width: 100%; height: auto; max-width: none; }
  .contest-content { padding-left: 8px; padding-right: 8px; }
  .contest-form { padding-left: 12px; padding-right: 12px; }
  .contest-form-title { font-weight: 200; font-size: clamp(18px, 2.2vw, 32px); }
}
@media (max-width: 400px) {
  .contest-content { padding-left: 8px; padding-right: 8px; }
  .contest-form { padding-left: 12px; padding-right: 12px; }
}

/* Contest form */
.contest-form {
  width: 100%; max-width: none; background: transparent;
  border-radius: 12px; box-shadow: none;
  padding: clamp(16px, 2.2vw, 28px);
  display: flex; flex-direction: column; gap: clamp(12px, 1.6vw, 18px);
}
.contest-form-title {
  margin: 0 0 clamp(8px, 1.6vw, 12px) 0;
  font-weight: 500; font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.25; color: #fff;
}
.desktop-br { display: none; }
@media (min-width: 1200px) {
  .desktop-br { display: inline; }
  .contest-form-title { max-width: 28ch; text-wrap: balance; font-size: 28px; }
}

/* Inline heading */
.contest-heading-inline {
  margin: 20px 0 0 0; color: #fff;
  font-weight: 700; font-size: clamp(20px, 6vw, 56px);
  line-height: 1.1; letter-spacing: -0.3px; white-space: nowrap; max-width: 100%;
  display: none;
}
@media (max-width: 576px) {
  .contest-heading-inline { display: block; }
  .contest-copy { display: none; }
  .contest-right { display: flex; flex-direction: column; align-items: flex-start; }
  .contest-subtitle-inline {
    display: block; margin: 10px 0;
    font-weight: 700; font-size: clamp(16px, 4.5vw, 22px);
    line-height: 1.2; color: #8BD4FF;
  }
}
@media (min-width: 577px) { .contest-subtitle-inline { display: none; } }

/* Form fields */
.form-field { display: flex; flex-direction: column; gap: 8px; }
.form-label { font-weight: 400; font-size: 16px; color: #fff; }
.form-input, .form-select {
  appearance: none; width: 100%; height: 52px; border-radius: 4px; border: 1px solid #D7DFE9;
  padding: 0 44px 0 14px; font-size: 16px; color: #202A44; background: #fff;
}
.form-input::placeholder { color: #9AA7B2; }
.form-select:invalid { color: #959595; }
.form-select option[disabled] { color: #9AA7B2; }
.form-select:valid { color: #202A44; }
.form-select-wrap { position: relative; }
.form-select-caret { display: none; }
.form-select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230F75BD' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat; background-position: right 14px center; background-size: 26px 26px;
}
.form-select::-ms-expand { display: none; }

.form-consent { display: flex; align-items: flex-start; gap: 10px; }
.form-consent input { width: 18px; height: 18px; margin-top: 2px; }
.form-consent-text { font-size: 12px; color: #fff; }

.form-submit {
  height: 54px; border: none; border-radius: 10px; background: #00C389; color: #fff;
  font-weight: 700; font-size: 18px; cursor: pointer;
}
.form-submit:hover { filter: brightness(0.95); }

@media (max-width: 1440px) { .contest-form-title { position: static; } }
@media (max-width: 992px)  { .contest-form-title { position: static; color: #fff; margin-bottom: 8px; } .contest-form { width: 100%; } .contest-right { align-items: center; } }
@media (max-width: 576px)  { .form-input, .form-select { height: 48px; } .form-submit { height: 50px; font-size: 16px; } }
@media (max-width: 400px)  { .contest-form-title { font-weight: 200; font-size: clamp(18px, 2.2vw, 32px); } }

/* ---------- Footer ---------- */
.footer {
  width: 100%; min-height: 430px; background: #202A44;
  position: relative; display: flex; align-items: center;
  padding: clamp(24px, 3vw, 48px) clamp(20px, 4.2vw, 80px);
}
.footer-inner {
  width: min(1100px, 92vw); height: 100%; margin: 0 auto;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; text-align: center;
}
.footer-logo-top { height: 86px; width: auto; display: block; }
.footer-logo-bottom { height: 81px; width: auto; display: block; }
.footer-middle { max-width: 740px; display: flex; flex-direction: column; gap: 14px; }
.footer-links { display: inline-flex; gap: 14px; align-items: center; justify-content: center; }
.footer-link { font-size: 14px; color: #fff; text-decoration: none; }
.footer-link:hover { text-decoration: underline; }
.footer-dot { color: #fff; opacity: 0.6; }
.footer-lorem { margin: 0; font-weight: 300; font-size: 16px; line-height: 1.5; color: #fff; }

@media (max-width: 576px) {
  .footer { height: auto; padding: 32px 16px; }
  .footer-inner { gap: 24px; justify-content: flex-start; }
}

/* ---------- Buttons ---------- */
.hero-cta {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 28px; border-radius: 8px; background: #00C389; color: #fff;
  font-weight: 700; font-size: clamp(16px, 1.6vw, 20px); line-height: 1;
  text-decoration: none; box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
  align-self: flex-start; transition: transform .06s ease, filter .2s ease, box-shadow .2s ease;
  margin-top: 6px;
}
.hero-cta:hover { filter: brightness(0.95); }
.hero-cta:active { transform: translateY(1px); }
.hero-cta:focus-visible {
  outline: 3px solid rgba(0, 195, 137, 0.35); outline-offset: 2px; box-shadow: 0 0 0 4px rgba(0, 195, 137, 0.15);
}

.hero-cta-group{
  display:inline-flex; gap:12px; align-items:center; flex-wrap:wrap; align-self:flex-start; margin-top:6px;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:14px 24px; border-radius:10px; font-weight:700; font-size:18px; line-height:1;
  text-decoration:none;
  transition:transform .06s ease, filter .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn--primary{ background: transparent; color: #00C389; border: 2px solid #00C389; box-shadow: none; }
.btn--primary:hover{ background: rgba(0,195,137,0.12); transform: translateY(-1px); }
.btn--primary:active{ transform: none; }
.btn--primary:focus-visible{ outline: 3px solid rgba(0,195,137,0.45); outline-offset: 2px; }

.btn--secondary{ background: transparent; color:#0077CB; border:2px solid #8BD4FF; }
.btn--secondary:hover{ background: rgba(139,212,255,0.12); transform: translateY(-1px); }
.btn--secondary:active{ transform: none; }
.btn--secondary:focus-visible{ outline:3px solid rgba(139,212,255,0.5); outline-offset:2px; }

@media (max-width:576px){ .btn{ padding:14px 20px; } }

/* ---------- MOBILE (≤576px): Hide header vectors, tidy layout ---------- */
@media (max-width: 576px) {
  /* hero vectors OFF on phones */
  .hero-triangle-desktop,
  .hero-triangle-mobile,
  .hero-triangle-svg { display: none !important; }
  .hero::before { content: none !important; }

  .hero { aspect-ratio: auto; min-height: 60vh; background:#fff; position: relative; overflow: hidden; }
  .hero-content {
    position: relative; inset: auto; left: auto;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 20px 16px; gap: 10px;
  }
  .hero-left { display: none; }
  .hero-right { align-items: center; text-align: center; gap: 8px; margin: 0; padding: 0; }
  .hero-logo { width: 132px; mix-blend-mode: normal; }
  .hero-eyebrow { font-size: 18px; line-height: 1.2; color: #202944; }
  .hero-title   { font-size: clamp(40px, 16vw, 64px); letter-spacing: -0.5px; color: #202944; }
  .hero-launch  { font-size: 16px; line-height: 1.2; color: #202944; }
  .hero-cta-group { justify-content: center; flex-wrap: wrap; gap: 10px; }
  .btn { font-size: 14px; }

  /* mobile intro small type tweaks */
  .intro { padding: 28px 16px; }
  .intro-headline { font-size: 22px; }
  .intro-description { font-size: 14px; }

  /* mobile contest: blue vector off (handled by SVG mobile) */
  .contest { min-height: 420px; }
}

/* ---------- TABLET (577–1024px): Show header vectors & size nicely ---------- */
@media (min-width: 577px) and (max-width: 1024px) {
  /* hero vectors ON for tablets: use the desktop variant */
  section.hero svg.hero-triangle-svg.hero-triangle-desktop { display: block !important; }
  section.hero svg.hero-triangle-svg.hero-triangle-mobile  { display: none  !important; }
  .hero-triangle-svg { display: block !important; }

  .hero { min-height: 560px; overflow: hidden; }
  .hero-content {
    position: relative; inset: auto; left: 0;
    display: flex; align-items: center; justify-content: space-between;
    padding: 32px 40px;
    gap: clamp(16px, 4vw, 48px);
  }
  .hero-left  { display: flex; align-items: flex-end; justify-content: flex-start; }
  .hero-phones{ width: min(48vw, 520px); height: auto; top: 0; }
  .hero-right {
    display: flex; flex-direction: column; align-items: flex-start;
    gap: 10px; padding: 0; margin: 0; text-align: left;
  }
  .hero-logo   { width: 200px; mix-blend-mode: normal; }
  .hero-eyebrow{ font-size: 28px; line-height: 1.2; color:#202944; }
  .hero-title  { font-size: clamp(72px, 10vw, 140px); line-height: .95; letter-spacing: -6px; color:#202944; }
  .hero-launch { font-size: 20px; line-height: 1.2; color:#202944; }
}

/* ---------- DESKTOP+ (≥577px): allow contest SVG background ---------- */
@media (min-width: 577px) {
  .contest-triangle-svg { display: block !important; }
}

/* ---------- Misc named style ---------- */
.unnamed-character-style-1 {
  font-family: var(--unnamed-font-family-tt-norms-pro);
  font-style: var(--unnamed-font-style-normal);
  font-weight: var(--unnamed-font-weight-medium);
  font-size: var(--unnamed-font-size-59);
  line-height: var(--unnamed-line-spacing-79);
  letter-spacing: var(--unnamed-character-spacing--0-71);
  color: var(--unnamed-color-ffffff);
}
/* --- Mobile toggle --- */ @media (max-width: 576px) 
{ .hero-triangle-desktop, .contest-triangle-desktop { display: none !important; } .hero-triangle-mobile, .contest-triangle-mobile { display: block !important; } /* ensure sections have height on phones so SVGs can fill */ .hero { min-height: 60vh; } .contest { min-height: 420px; } /* adjust to your content */ } @media (max-width: 576px) { .intro { padding: 38px 38px !important; margin-top: -100px !important; } .hero-right .hero-eyebrow { margin: 20px 0 0 0 !important; font-size: 22px !important; } .hero-logo { width: 192px !important; } .hero-right .hero-title { margin: 0 0 8px 0px !important; font-size: 90px !important; letter-spacing: -6px !important; } .hero-right .hero-launch { margin: 20px 0 0 0px !important; font-size: 24px !important; } .contest-form-title { font-size: 18px !important; } .contest-heading-inline { margin: 50px 0 0 0 !important; } .form-label { font-size: 18px !important; } .form-input, .form-select { font-size: 18px !important; } .intro-headline { font-size:22px; } .intro-description { font-size:14px; }

.intro-logo {
    margin-top: 8px !important;}


/* ---------- MOBILE (≤576px): Hide header vectors, tidy layout ---------- */
@media (max-width: 576px) {
  /* hero vectors OFF on phones */
  .hero-triangle-desktop,
  .hero-triangle-mobile,
  .hero-triangle-svg { display: none !important; }
  .hero::before { content: none !important; }

  .hero { aspect-ratio: auto; min-height: 60vh; background:#fff; position: relative; overflow: hidden; }
  .hero-content {
    position: relative; inset: auto; left: auto;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 20px 16px; gap: 10px;
  }
  .hero-left { display: none; }
  .hero-right { align-items: center; text-align: center; gap: 8px; margin: 0; padding: 0; }
  .hero-logo { width: 132px; mix-blend-mode: normal; }
  .hero-eyebrow { font-size: 20px; line-height: 1.2; color: #202944; }
  .hero-title   { font-size: clamp(40px, 16vw, 64px); letter-spacing: -0.5px; color: #202944; }
  .hero-launch  { font-size: 18px; line-height: 1.2; color: #202944; }
  .hero-cta-group { justify-content: center; flex-wrap: wrap; gap: 10px; }
  .btn { font-size: 14px; }

  /* mobile intro small type tweaks */
  .intro { padding: 28px 16px; }
  .intro-headline { font-size: 28px; }
  .intro-description { font-size: 18px; }

  /* mobile contest: blue vector off (handled by SVG mobile) */
  .contest { min-height: 420px; }
}

