:root {
  --navy: #071527;
  --navy-soft: #0d223b;
  --orange: #ff6b1a;
  --orange-light: #ff914d;
  --green: #18a36a;
  --paper: #f3f2ef;
  --white: #fff;
  --ink: #111d2a;
  --muted: #69727d;
  --line: rgba(17, 29, 42, .14);
  font-family: "DM Sans", "Noto Sans SC", sans-serif;
  color: var(--ink);
  background: var(--paper);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: var(--paper); }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button { font: inherit; }

.site-header {
  position: absolute;
  z-index: 20;
  top: 0;
  left: 0;
  width: 100%;
  height: 84px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 0 5vw;
  color: var(--white);
  border-bottom: 1px solid rgba(255,255,255,.13);
}
.brand { display: inline-flex; width: fit-content; align-items: center; gap: 12px; font-size: 15px; font-weight: 500; letter-spacing: .08em; }
.brand b { font-weight: 900; }
.brand-icon { position: relative; display: flex; width: 38px; height: 38px; align-items: flex-end; justify-content: center; gap: 3px; padding: 8px; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; }
.brand-icon i { display: block; width: 4px; border-radius: 4px; background: var(--orange); transform: rotate(14deg); }
.brand-icon i:nth-child(1) { height: 12px; }.brand-icon i:nth-child(2) { height: 20px; }.brand-icon i:nth-child(3) { height: 16px; }
.desktop-nav { display: flex; gap: 34px; font-size: 13px; font-weight: 600; }
.desktop-nav a { transition: color .2s; }
.desktop-nav a:hover { color: var(--orange-light); }
.nav-cta { justify-self: end; padding: 12px 19px; border: 1px solid rgba(255,255,255,.45); border-radius: 4px; font-size: 13px; font-weight: 700; }
.nav-cta span { color: var(--orange-light); }
.menu-button { display: none; }

.hero {
  position: relative;
  min-height: 850px;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 140px 5vw 190px;
  background:
    radial-gradient(circle at 84% 33%, rgba(10,109,94,.7), transparent 20%),
    radial-gradient(circle at 72% 52%, rgba(255,107,26,.2), transparent 28%),
    linear-gradient(117deg, #050e1a 0%, #08182b 58%, #0a2d3c 100%);
  color: var(--white);
}
.hero-grid { position: absolute; inset: 0; opacity: .17; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); background-size: 90px 90px; mask-image: linear-gradient(90deg, black, transparent 85%); }
.hero-glow { position: absolute; right: 7%; top: 18%; width: 480px; height: 480px; border: 1px solid rgba(255,255,255,.12); border-radius: 50%; box-shadow: 0 0 0 90px rgba(255,255,255,.025), 0 0 0 180px rgba(255,255,255,.018); }
.hero-content { position: relative; z-index: 2; max-width: 900px; }
.hero-kicker { display: flex; align-items: center; gap: 12px; margin-bottom: 30px; color: #aab5c1; font-size: 12px; font-weight: 700; letter-spacing: .14em; }
.hero-kicker span { width: 35px; height: 2px; background: var(--orange); }
.hero h1 { margin: 0; font-family: "Noto Sans SC", sans-serif; font-size: clamp(60px, 7.4vw, 116px); font-weight: 900; line-height: 1.06; letter-spacing: -.065em; }
.hero h1 span { position: relative; display: inline-block; margin-left: .14em; color: var(--orange); }
.hero h1 span::after { content: ""; position: absolute; left: 0; bottom: -10px; width: 100%; height: 5px; background: var(--orange); transform: skewX(-24deg); }
.hero-content > p { max-width: 650px; margin: 38px 0 35px; color: #b6c0ca; font-size: 18px; line-height: 1.8; }
.hero-actions { display: flex; gap: 14px; }
.button { display: inline-flex; min-height: 52px; align-items: center; justify-content: center; gap: 20px; padding: 0 25px; border-radius: 3px; font-weight: 700; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button.orange { background: var(--orange); color: var(--white); }
.button.orange:hover { background: var(--orange-light); }
.button.ghost { border: 1px solid rgba(255,255,255,.28); color: var(--white); }
.button.ghost span { color: var(--orange); }
.market-card { position: absolute; z-index: 3; right: 5vw; top: 30%; width: 260px; padding: 24px; border: 1px solid rgba(255,255,255,.18); background: rgba(4,18,29,.67); backdrop-filter: blur(12px); }
.mexico-mark { display: flex; align-items: center; margin-bottom: 22px; }
.mexico-mark span { width: 33%; height: 6px; }.mexico-mark span:first-child { background: #15965f; }.mexico-mark span:last-child { background: #d02d28; }
.mexico-mark b { flex: 1; text-align: center; font-size: 12px; }
.market-card small { color: #9daab6; letter-spacing: .12em; }
.market-card strong { display: block; margin: 5px 0 0; color: var(--orange); font-size: 58px; line-height: 1; }
.market-card p { margin: 12px 0 0; color: #b5c0ca; font-size: 12px; line-height: 1.6; }
.hero-stats { position: absolute; z-index: 4; left: 5vw; right: 5vw; bottom: 0; display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid rgba(255,255,255,.16); }
.hero-stats article { padding: 28px 0 30px; border-right: 1px solid rgba(255,255,255,.13); }
.hero-stats article:not(:first-child) { padding-left: 28px; }
.hero-stats strong { display: block; font-size: 35px; }
.hero-stats sup { color: var(--orange); font-size: 18px; }
.hero-stats span { color: #8f9baa; font-size: 12px; }

.trust-strip { display: flex; justify-content: center; gap: 35px; overflow: hidden; padding: 18px 20px; background: var(--orange); color: var(--white); font-size: 12px; font-weight: 800; letter-spacing: .12em; white-space: nowrap; }
.trust-strip i { color: var(--navy); font-style: normal; }
.section { padding: 120px 5vw; }
.section-label { display: flex; align-items: center; gap: 15px; color: var(--muted); font-size: 11px; font-weight: 800; letter-spacing: .14em; }
.section-label span { display: grid; width: 30px; height: 30px; place-items: center; border: 1px solid currentColor; border-radius: 50%; letter-spacing: 0; }
.section-label.light { color: #96a3b1; }
.section h2 { margin: 0; font-family: "Noto Sans SC", sans-serif; font-size: clamp(42px, 5.5vw, 76px); line-height: 1.13; letter-spacing: -.055em; }
.section h2 em { color: var(--orange); font-style: normal; }

.intro { display: grid; grid-template-columns: .5fr 1.25fr .8fr; gap: 6vw; align-items: start; }
.intro-copy .eyebrow { margin: 0 0 18px; color: var(--orange); font-weight: 700; }
.intro-detail { padding-top: 38px; }
.intro-detail > p { margin: 0 0 45px; color: var(--muted); font-size: 17px; line-height: 1.9; }
.mini-stats { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.mini-stats div { padding: 22px 0; }
.mini-stats div + div { padding-left: 24px; border-left: 1px solid var(--line); }
.mini-stats b { display: block; color: var(--navy); font-size: 35px; }
.mini-stats span { color: var(--muted); font-size: 12px; }

.services { background: var(--navy); color: var(--white); }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 50px; margin-bottom: 60px; }
.section-head .section-label { margin-bottom: 25px; }
.section-head > p { max-width: 420px; margin: 0; color: #9ba7b4; line-height: 1.8; }
.service-grid { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid rgba(255,255,255,.13); border-left: 1px solid rgba(255,255,255,.13); }
.service-grid article { position: relative; min-height: 300px; padding: 28px; border-right: 1px solid rgba(255,255,255,.13); border-bottom: 1px solid rgba(255,255,255,.13); transition: background .25s; }
.service-grid article:hover { background: var(--navy-soft); }
.service-grid article > b { color: #657283; font-size: 11px; }
.service-icon { display: grid; width: 52px; height: 52px; place-items: center; margin: 48px 0 25px; border: 1px solid #405065; border-radius: 50%; color: var(--orange); font-size: 22px; }
.service-grid h3 { margin: 0 0 12px; font-size: 24px; }
.service-grid p { max-width: 280px; margin: 0; color: #8f9baa; line-height: 1.7; }
.service-grid .service-highlight { background: var(--orange); }
.service-highlight > b, .service-highlight .service-icon, .service-highlight p { color: var(--white); }
.service-highlight .service-icon { border-color: rgba(255,255,255,.5); }

.creator-model { display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; align-items: center; }
.creator-copy .section-label { margin-bottom: 30px; }
.creator-copy h2 span { color: var(--orange); }
.creator-copy > p { max-width: 560px; margin: 28px 0; color: var(--muted); font-size: 17px; line-height: 1.8; }
.creator-copy > a { display: inline-flex; gap: 30px; padding-bottom: 8px; border-bottom: 1px solid var(--ink); font-weight: 700; }
.creator-copy > a span { color: var(--orange); }
.pyramid { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.tier { display: grid; grid-template-columns: 100px 1fr; align-items: center; min-height: 110px; padding: 18px 35px; color: var(--white); clip-path: polygon(8% 0,92% 0,100% 100%,0 100%); }
.tier b { grid-row: 1 / 3; font-size: 40px; }
.tier span { font-size: 17px; font-weight: 800; }
.tier small { color: rgba(255,255,255,.7); }
.tier-top { width: 45%; background: var(--orange); }
.tier-mid { width: 72%; background: #ef7f27; }
.tier-base { width: 100%; background: var(--navy); }

.cases { background: #09101c; color: var(--white); }
.dark-head > p { color: #8e99a7; }
.case-feature { display: grid; grid-template-columns: 1.15fr .85fr; min-height: 520px; background: #111d2c; }
.case-image { display: grid; place-items: center; overflow: hidden; background: #e8e7e3; }
.case-image img { height: 100%; object-fit: cover; }
.case-content { display: flex; flex-direction: column; justify-content: center; padding: 55px; }
.case-content > span { color: var(--orange); font-size: 11px; font-weight: 800; letter-spacing: .14em; }
.case-content h3 { margin: 15px 0 20px; font-size: 48px; }
.case-content > p { color: #99a5b1; line-height: 1.8; }
.case-numbers { display: grid; grid-template-columns: repeat(3,1fr); gap: 15px; margin-top: 45px; padding-top: 25px; border-top: 1px solid rgba(255,255,255,.13); }
.case-numbers b { display: block; color: var(--orange); font-size: 27px; }
.case-numbers span { color: #7f8b98; font-size: 11px; }
.case-tabs { display: grid; grid-template-columns: repeat(4,1fr); margin-top: 55px; border-bottom: 1px solid rgba(255,255,255,.14); }
.case-tabs button { padding: 22px 15px; border: 0; border-top: 2px solid transparent; background: none; color: #778492; text-align: left; cursor: pointer; }
.case-tabs button.active { border-color: var(--orange); color: var(--white); }
.case-tabs b, .case-tabs span { display: block; }.case-tabs span { margin-top: 4px; font-size: 11px; }
.case-panel { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 55px; padding-top: 35px; }
.case-panel img { background: #eee; }
.case-panel span { color: var(--orange); font-size: 12px; font-weight: 800; }
.case-panel h3 { margin: 12px 0; font-size: 38px; }
.case-panel p { color: #929eab; line-height: 1.8; }

.plans { display: grid; grid-template-columns: .55fr 1.45fr; column-gap: 6vw; }
.plans-heading .section-label { margin-bottom: 30px; }
.plans-heading > p { color: var(--muted); line-height: 1.8; }
.plan-grid { display: grid; grid-template-columns: repeat(3,1fr); align-items: stretch; gap: 12px; }
.plan-grid article { position: relative; display: flex; flex-direction: column; min-height: 540px; padding: 28px; border: 1px solid var(--line); background: #f9f8f5; }
.plan-grid article.recommended { background: var(--navy); color: var(--white); transform: translateY(-20px); }
.recommend-label { position: absolute; top: 0; right: 0; padding: 8px 13px; background: var(--orange); color: var(--white); font-size: 10px; font-weight: 800; }
.plan-index { color: var(--orange); font-weight: 800; }
.plan-type { margin-top: 45px; color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .14em; }
.recommended .plan-type { color: #8e9aa7; }
.plan-grid h3 { margin: 10px 0 28px; font-size: 29px; }
.price { padding: 20px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.recommended .price { border-color: rgba(255,255,255,.14); }
.price b { display: block; font-size: 36px; }
.price span { color: var(--muted); font-size: 11px; }
.plan-grid ul { display: grid; gap: 14px; margin: 28px 0; padding: 0; list-style: none; }
.plan-grid li { position: relative; padding-left: 18px; color: var(--muted); font-size: 13px; line-height: 1.5; }
.recommended li { color: #acb6c0; }
.plan-grid li::before { content: ""; position: absolute; left: 0; top: 7px; width: 6px; height: 6px; border-radius: 50%; background: var(--orange); }
.plan-grid small { margin-top: auto; padding-top: 20px; border-top: 1px solid var(--line); color: var(--muted); line-height: 1.5; }
.recommended small { border-color: rgba(255,255,255,.14); color: #8e9aa7; }
.plan-note { grid-column: 2; margin-top: 25px; color: var(--muted); font-size: 11px; line-height: 1.7; }

.process { display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; background: #e9e8e4; }
.process-title .section-label { margin-bottom: 28px; }
.process-list { border-top: 1px solid var(--line); }
.process-list article { display: grid; grid-template-columns: 70px 1fr; gap: 15px; padding: 28px 0; border-bottom: 1px solid var(--line); }
.process-list article > b { color: var(--orange); }
.process-list h3 { margin: 0 0 6px; font-size: 21px; }
.process-list p { margin: 0; color: var(--muted); line-height: 1.7; }

.contact { position: relative; overflow: hidden; display: grid; min-height: 700px; place-items: center; padding: 100px 5vw; background: var(--navy); color: var(--white); text-align: center; }
.contact-content { position: relative; z-index: 2; }
.contact-content > span { color: var(--orange); font-size: 11px; font-weight: 800; letter-spacing: .18em; }
.contact h2 { margin: 25px 0; font-size: clamp(48px,7vw,100px); line-height: 1.08; letter-spacing: -.06em; }
.contact h2 span { color: var(--orange); }
.contact p { max-width: 660px; margin: 0 auto 35px; color: #98a4b0; line-height: 1.8; }
.button.large { min-height: 60px; padding: 0 35px; }
.contact-email { display: block; width: fit-content; margin: 25px auto 0; color: #9ca7b3; font-size: 13px; text-decoration: underline; }
.contact-orbit { position: absolute; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; }
.orbit-a { width: 800px; height: 800px; }.orbit-b { width: 1100px; height: 420px; transform: rotate(-20deg); }

footer { display: grid; grid-template-columns: 1fr 1fr auto; align-items: center; gap: 30px; padding: 40px 5vw; background: #050d18; color: #8f9aa6; font-size: 12px; }
footer .brand { color: var(--white); }
footer p { line-height: 1.7; }
footer > div { display: flex; gap: 22px; }
footer small { grid-column: 1 / -1; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); }

@media (max-width: 1100px) {
  .market-card { display: none; }
  .intro { grid-template-columns: .4fr 1fr; }
  .intro-detail { grid-column: 2; }
  .plans { grid-template-columns: 1fr; }
  .plans-heading { max-width: 700px; margin-bottom: 55px; }
  .plan-note { grid-column: 1; }
}

@media (max-width: 820px) {
  .site-header { grid-template-columns: 1fr auto; }
  .desktop-nav, .nav-cta { display: none; }
  .menu-button { display: grid; gap: 6px; width: 42px; height: 42px; place-content: center; border: 1px solid rgba(255,255,255,.3); background: transparent; }
  .menu-button i { display: block; width: 18px; height: 2px; background: white; }
  .desktop-nav.open { position: absolute; top: 84px; left: 0; right: 0; display: grid; gap: 0; padding: 15px 5vw; background: var(--navy); }
  .desktop-nav.open a { padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.1); }
  .hero { min-height: 800px; padding-bottom: 220px; }
  .hero-stats { grid-template-columns: repeat(2,1fr); }
  .hero-stats article:nth-child(3), .hero-stats article:nth-child(4) { border-top: 1px solid rgba(255,255,255,.13); }
  .section-head { align-items: flex-start; flex-direction: column; }
  .service-grid { grid-template-columns: repeat(2,1fr); }
  .creator-model, .case-feature, .case-panel, .process { grid-template-columns: 1fr; }
  .pyramid { margin-top: 40px; }
  .case-image { min-height: 380px; }
  .plan-grid { grid-template-columns: 1fr; }
  .plan-grid article { min-height: 460px; }
  .plan-grid article.recommended { transform: none; }
}

@media (max-width: 600px) {
  .site-header { height: 72px; padding: 0 22px; }
  .brand { font-size: 12px; }
  .brand-icon { width: 34px; height: 34px; }
  .hero { min-height: 760px; padding: 125px 22px 225px; }
  .hero h1 { font-size: 53px; }
  .hero h1 span { margin-left: 0; }
  .hero-content > p { font-size: 15px; }
  .hero-actions { align-items: stretch; flex-direction: column; }
  .hero-stats { left: 22px; right: 22px; }
  .hero-stats article, .hero-stats article:not(:first-child) { padding: 18px 10px 18px 0; }
  .hero-stats strong { font-size: 25px; }
  .trust-strip { justify-content: flex-start; }
  .section { padding: 80px 22px; }
  .section h2 { font-size: 42px; }
  .intro { grid-template-columns: 1fr; }
  .intro-detail { grid-column: 1; }
  .service-grid { grid-template-columns: 1fr; }
  .service-grid article { min-height: 260px; }
  .tier { grid-template-columns: 75px 1fr; padding: 15px 22px; }
  .tier-top { width: 58%; }.tier-mid { width: 78%; }
  .tier b { font-size: 29px; }.tier small { font-size: 10px; }
  .case-content { padding: 35px 25px; }
  .case-numbers { grid-template-columns: 1fr; }
  .case-tabs { grid-template-columns: repeat(2,1fr); }
  .case-panel { gap: 25px; }
  .process-list article { grid-template-columns: 42px 1fr; }
  .contact { min-height: 650px; padding: 80px 22px; }
  .contact h2 { font-size: 50px; }
  footer { grid-template-columns: 1fr; padding: 35px 22px; }
  footer small { grid-column: 1; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
