.btn { display: inline-flex; align-items: center; justify-content: center; min-width: 166px; height: 58px; padding: 0 25px; border-radius: 0; font-size: 19px; font-weight: 600; transition: .25s; }
.btn.red { color: #fff; background: linear-gradient(135deg, var(--red), #ff4652); box-shadow: 0 22px 44px rgba(230,0,18,.3); }
.btn.line { color: #fff; border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.055); }
.btn:hover { transform: translateY(-3px); }

section { position: relative; padding: 126px 0; }

.hero-index { align-self: stretch; display: flex; flex-direction: column; justify-content: center; gap: 12px; }

.index-title { margin-bottom: 10px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.12); }
.index-title span { display: block; color: var(--red2); font-size: 12px; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; }
.index-title strong { display: block; margin-top: 8px; font-size: 24px; line-height: 1.25; letter-spacing: -.05em; }
.index-list a { position: relative; display: grid; grid-template-columns: 48px 1fr; gap: 16px; align-items: center; padding: 18px 0; border-bottom: 1px solid rgba(255,255,255,.08); color: rgba(255,255,255,.76); transition: .25s; }
.index-list a:before { content: ""; position: absolute; left: -18px; top: 50%; width: 4px; height: 0; transform: translateY(-50%); background: var(--red); transition: .25s; }
.index-list a:hover { color: #fff; padding-left: 12px; }
.index-list a:hover:before { height: 52%; }
.index-list b { color: rgba(255,255,255,.28); font-size: 18px; font-weight: 900; }
.index-list strong { display: block; font-size: 19px; font-weight: 900; letter-spacing: -.04em; }
.index-list small { display: block; margin-top: 2px; color: var(--gray2); font-size: 12px; }

.marquee { position: relative; z-index: 3; overflow: hidden; border-top: 1px solid rgba(255,255,255,.08); border-bottom: 1px solid rgba(255,255,255,.08); background: #08090d; }
.marquee-track { display: flex; width: max-content; animation: rolling 28s linear infinite; }
.marquee span { display: block; padding: 25px 40px; color: rgba(255,255,255,.58); font-size: 20px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; white-space: nowrap; }
.marquee em { color: var(--red2); font-style: normal; }


@keyframes rolling   {
  0% { transform: translateX(0); } 
  100% { transform: translateX(-50%); } 
  }

.section-head { margin-bottom: 56px; }
.section-num { color: rgba(255,255,255,.24); font-size: 72px; line-height: .9; font-weight: 900; letter-spacing: -.08em; }
.section-kicker { display: block; margin-bottom: 14px; color: #ff8d95; font-size: 13px; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; }
.section-head h2 { font-size: clamp(36px, 4vw, 58px); line-height: 1.15; font-weight: 900; }
.section-head p { margin-top: 22px; color: var(--gray); font-size: 17px; line-height: 1.85; }

.about { background: radial-gradient(circle at 88% 14%, rgba(230,0,18,.14), transparent 28%), linear-gradient(180deg, #050507 0%, #0a0b0f 100%); }
.about-layout { display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; align-items: stretch; }


.company-table { display: grid; border-top: 1px solid var(--line-red); border-bottom: 1px solid var(--line); }
.company-table li { display: grid; grid-template-columns: 120px 1fr; gap: 22px; padding: 23px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.company-table li:last-child { border-bottom: 0; }
.company-table span { color: #ff8d95; font-size: 13px; font-weight: 900; letter-spacing: .08em; }
.company-table strong { color: #fff; font-size: 17px; font-weight: 700; letter-spacing: -.035em; }

.solutions { overflow: hidden; background: linear-gradient(115deg, rgba(230,0,18,.08) 0 20%, transparent 20% 100%), #050507; }
.solution-map { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid rgba(255,255,255,.12); border-left: 1px solid rgba(255,255,255,.12); }
.solution-item { position: relative; min-height: 260px; padding: 34px 36px; border-right: 1px solid rgba(255,255,255,.12); border-bottom: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.026); transition: .28s; }
.solution-item.big { grid-row: span 2; min-height: 520px; padding: 48px; background: radial-gradient(circle at 70% 18%, rgba(230,0,18,.22), transparent 34%), rgba(255,255,255,.038); }
.solution-item:hover { background: rgba(230,0,18,.095); }
.solution-item .no { display: block; margin-bottom: 52px; color: rgba(255,255,255,.25); font-size: 22px; font-weight: 900; }
.solution-item.big .no { margin-bottom: 130px; font-size: 36px; }
.solution-item h3 { margin-bottom: 16px; color: #fff; font-size: 32px; line-height: 1.12; font-weight: 900; }
.solution-item.big h3 { font-size: 56px; }
.solution-item p { max-width: 560px; color: var(--gray); font-size: 1em; line-height: 1.75; }
.solution-item .arrow { position: absolute; right: 28px; top: 28px; width: 42px; height: 42px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.16); color: #fff; font-size: 20px; transition: .25s; }
.solution-item:hover .arrow { background: var(--red); border-color: var(--red); transform: translate(4px, -4px); }


.process { background: radial-gradient(circle at 14% 26%, rgba(230,0,18,.12), transparent 30%), linear-gradient(180deg, #050507 0%, #0a0b0f 100%); }
.process-line { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(255,255,255,.12); }
.process-item { min-height: 320px; padding: 34px 28px; border-right: 1px solid rgba(255,255,255,.1); }
.process-item:first-child { border-left: 1px solid rgba(255,255,255,.1); }
.process-item b { display: inline-flex; align-items: center; justify-content: center; width: 58px; height: 58px; margin-bottom: 92px; color: #fff; font-size: 15px; background: linear-gradient(135deg, var(--red3), var(--red)); ; }
.process-item h3 { margin-bottom: 12px; color: #fff; font-size: 25px; line-height: 1.2; font-weight: 900; letter-spacing: -.05em; }
.process-item p { color: var(--gray); font-size: 1em; line-height: 1.75; }



.contact { padding-bottom: 130px; background: #050507; }
.contact-panel { position: relative; overflow: hidden; display: grid; grid-template-columns: .95fr 1.05fr; gap: 56px; padding:70px 58px; border: 1px solid rgba(230,0,18,.35); }
.contact-panel h2 { position: relative; z-index: 2; margin-bottom: 22px; font-size: clamp(36px, 4vw, 58px); line-height: 1.12; font-weight: 900; letter-spacing: -.07em; }
.contact-panel p { position: relative; z-index: 2; width:100%; color: var(--gray); font-size: 1em; line-height: 1.85; }
.contact-info { position: relative; z-index: 2; display: grid; align-content: start; border-top: 1px solid rgba(255,255,255,.12); }
.contact-info li { display: flex; align-items:center;  gap: 24px; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.1); }
.contact-info span { color: #ff8d95; width:100px; flex-shrink:0; font-size: 13px; font-weight: 900; letter-spacing: .12em; }
.contact-info strong { color: #fff; font-size: 18px; letter-spacing: -.035em; }
.contact .hero-actions {margin-top:30px}

footer {margin-top:0}


@media all and (max-width:900px) {
		section {padding:70px 0}
		.marquee span {font-size:16px}
		.section-head h2 {font-size:1.7em; line-height:1.3; letter-spacing:0}
		.section-head h2 br {display:none}
		.solution-item {width:100%; min-height:auto; padding:20px}
		.solution-item.big {min-height:auto; padding:20px }
		.solution-map {display:flex; flex-wrap:wrap}
		.solution-item .no {margin-bottom:10px}
		.solution-item.big .no {margin-bottom:10px}
		.solution-item h3 { font-size:1.5em }
		.solution-item.big h3 { font-size:1.5em}
		.solution-item .no {font-size:1.5em}
		.solution-item.big .no {font-size:1.5em}
		.solution-item .arrow {top:-1px; right:-1px}
		.solution-item:hover .arrow { transform: translate(0, 0px); }


		.process-line {width:100%;display:flex; flex-wrap:wrap}
		.process-item {width:100%; min-height:auto; padding:20px;  border-right: 1px solid rgba(255,255,255,.12); border-left: 1px solid rgba(255,255,255,.12);}
		.process-item b {width:45px; height:45px; margin-bottom:20px}
		.process-item h3 {font-size:1.5em}
		
		.contact {width:100%; padding-bottom:0}
		.contact-panel {padding:0; width:100%; border:none; display:inline-block}
		.btn {width:100%; box-sizing:border-box}
		.contact-info {margin-top:40px; width:100%}
		.contact-info li {   gap: 10px;  }
		.contact-info li a {color:#fff}
		.contact-panel h2 {font-size:1.7em; line-height:1.3; letter-spacing:0}
		 


}
