@import url("https://fonts.googleapis.com/css2?family=Syne:wght@300;400;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap");  .engineering-bridge-section {
padding: 120px 0;
background: #f7f5f1;
position: relative;
overflow: visible; width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);
}
.bridge-container-wrapper {
max-width: 100%;
margin: 0;
padding: 0;
}
.section-header {
text-align: center;
margin-bottom: 80px;
max-width: 1200px;
margin-left: auto;
margin-right: auto;
padding: 0 40px;
}
.bridge-visual-container {
position: relative;
margin: 0;
max-width: 100%;
padding: 0; }
.bridge-image-wrapper {
position: relative;
width: 100%;
padding-bottom: 56.25%;
} .use-case-cards-container {
max-width: 1000px;
margin: 60px auto 0;
padding: 0 20px;
} .section-header {
text-align: center;
margin-bottom: 80px;
}
.section-title {
font-family: 'Syne', sans-serif;
font-size: clamp(34px, 4vw, 58px);
font-weight: 700;
color: #111118;
letter-spacing: -2px;
margin-bottom: 16px;
line-height: 1.08;
}
.section-subtitle {
font-family: 'Syne', sans-serif;
font-size: 17px;
color: rgba(17, 17, 24, 0.50);
max-width: 700px;
margin: 0 auto;
line-height: 1.75;
} .bridge-visual-container {
position: relative;
margin: 0 auto;
max-width: 1200px;
}
.bridge-image-wrapper {
position: relative;
width: 100%;
padding-bottom: 56.25%; }
.bridge-main-image {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: contain;
filter: drop-shadow(0 20px 60px rgba(0, 0, 0, 0.15));
} .pillar-hotspot {
position: absolute;
cursor: pointer;
display: flex;
flex-direction: column;
align-items: center;
gap: 8px;
transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
z-index: 10;
} .pillar-software {
left: 23%;
top: 58%;
}
.pillar-ai {
left: 40%;
top: 58%;
}
.pillar-embedded {
left: 57%;
top: 58%;
}
.pillar-hardware {
left: 74%;
top: 58%;
}
.pillar-hotspot:hover {
transform: translateY(-8px);
} .hotspot-pulse {
position: absolute;
width: 60px;
height: 60px;
border-radius: 50%;
background: rgba(232, 41, 74, 0.25);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
pointer-events: none;
}
@keyframes pulse {
0%, 100% {
transform: translate(-50%, -50%) scale(1);
opacity: 0.6;
}
50% {
transform: translate(-50%, -50%) scale(1.5);
opacity: 0;
}
} .pillar-icon {
width: 56px;
height: 56px;
background: #E8294A;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: white;
box-shadow: 0 8px 24px rgba(232, 41, 74, 0.28);
transition: all 0.3s ease;
position: relative;
z-index: 2;
}
.pillar-hotspot:hover .pillar-icon {
background: #c82333;
transform: scale(1.1);
box-shadow: 0 12px 32px rgba(232, 41, 74, 0.38);
}
.pillar-label {
font-family: 'JetBrains Mono', monospace;
font-size: 9px;
font-weight: 700;
color: #111118;
text-transform: uppercase;
letter-spacing: 2px;
background: white;
padding: 5px 12px;
border-radius: 2px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
white-space: nowrap;
} .use-case-cards-container {
position: relative;
margin-top: 60px;
}
.use-case-card {
background: white;
border-radius: 4px;
border-top: 2px solid #E8294A;
padding: 40px;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
max-width: 800px;
margin: 0 auto;
position: relative;
opacity: 0;
transform: translateY(30px);
pointer-events: none;
transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
display: none;
}
.use-case-card.active {
opacity: 1;
transform: translateY(0);
pointer-events: auto;
display: block;
} .card-close {
position: absolute;
top: 20px;
right: 20px;
background: none;
border: none;
font-size: 32px;
color: #999;
cursor: pointer;
width: 36px;
height: 36px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 50%;
transition: all 0.2s ease;
line-height: 1;
}
.card-close:hover {
background: #f5f5f5;
color: #333;
} .project-tag {
display: inline-block;
padding: 6px 16px;
border-radius: 20px;
font-size: 12px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
margin-bottom: 20px;
}
.tag-startup {
background: #e3f2fd;
color: #1976d2;
}
.tag-corporation {
background: #f3e5f5;
color: #7b1fa2;
}
.tag-public {
background: #e8f5e9;
color: #388e3c;
} .case-title {
font-family: 'Syne', sans-serif;
font-size: 28px;
font-weight: 700;
letter-spacing: -0.8px;
color: #111118;
margin-bottom: 28px;
line-height: 1.2;
} .case-content {
display: grid;
gap: 32px;
}
.case-block h4 {
font-family: 'JetBrains Mono', monospace;
font-size: 10px;
font-weight: 700;
color: #E8294A;
text-transform: uppercase;
letter-spacing: 2px;
margin-bottom: 12px;
display: flex;
align-items: center;
gap: 8px;
}
.block-icon {
font-size: 16px;
}
.case-block p {
font-size: 16px;
color: #555;
line-height: 1.7;
} .result-list {
list-style: none;
padding: 0;
margin: 0;
}
.result-list li {
font-size: 16px;
color: #555;
line-height: 1.8;
padding-left: 24px;
position: relative;
margin-bottom: 8px;
}
.result-list li::before {
content: "✓";
position: absolute;
left: 0;
color: #28a745;
font-weight: 700;
}
.result-list strong {
color: #1a1a1a;
font-weight: 600;
} .case-link {
display: inline-flex;
align-items: center;
gap: 8px;
margin-top: 32px;
font-size: 16px;
font-weight: 600;
color: #E8294A;
text-decoration: none;
transition: all 0.3s ease;
}
.case-link:hover {
gap: 12px;
color: #c82333;
}
.case-link span {
transition: transform 0.3s ease;
}
.case-link:hover span {
transform: translateX(4px);
} .bridge-quote {
text-align: center;
margin-top: 80px;
padding: 36px 48px;
border-left: 3px solid #E8294A;
background: rgba(232, 41, 74, 0.04);
border-radius: 2px;
max-width: 900px;
margin-left: auto;
margin-right: auto;
}
.bridge-quote p {
font-family: 'Syne', sans-serif;
font-size: 24px;
font-weight: 300;
color: rgba(17, 17, 24, 0.55);
font-style: italic;
line-height: 1.6;
margin: 0;
} .fade-in-up {
opacity: 0;
transform: translateY(36px);
transition:
opacity   0.7s cubic-bezier(0.22, 1, 0.36, 1) calc(var(--i, 0) * 80ms),
transform 0.9s cubic-bezier(0.34, 1.56, 0.64, 1) calc(var(--i, 0) * 80ms);
}
.fade-in-up.animated {
opacity: 1;
transform: translateY(0);
}
.fade-in-scale {
opacity: 0;
transform: translateY(20px) scale(0.97);
transition:
opacity   0.75s cubic-bezier(0.22, 1, 0.36, 1) calc(var(--i, 0) * 80ms),
transform 1s    cubic-bezier(0.34, 1.56, 0.64, 1) calc(var(--i, 0) * 80ms);
}
.fade-in-scale.animated {
opacity: 1;
transform: translateY(0) scale(1);
} @media (max-width: 1024px) {
.section-title {
font-size: 40px;
}
.pillar-hotspot {
transform: scale(0.9);
}
}
@media (max-width: 768px) {
.engineering-bridge-section {
padding: 80px 20px;
}
.section-header {
margin-bottom: 50px;
}
.section-title {
font-size: 32px;
}
.section-subtitle {
font-size: 18px;
} .bridge-image-wrapper {
position: static;
padding-bottom: 0;
margin-bottom: 40px;
}
.bridge-main-image {
position: static;
width: 100%;
height: auto;
}
.pillar-hotspot {
position: static;
margin-bottom: 16px;
flex-direction: row;
justify-content: flex-start;
padding: 16px;
background: white;
border-radius: 4px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
transform: none !important;
}
.hotspot-pulse {
display: none;
}
.pillar-icon {
margin-right: 12px;
}
.use-case-card {
padding: 24px;
}
.case-title {
font-size: 24px;
}
.bridge-quote p {
font-size: 20px;
}
}
@media (max-width: 480px) {
.engineering-bridge-section {
padding: 60px 15px;
}
.section-title {
font-size: 28px;
}
.use-case-card {
padding: 20px;
}
.case-title {
font-size: 20px;
}
}@import url("https://fonts.googleapis.com/css2?family=Syne:wght@300;400;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap"); :root {
--bs-red:           #E8294A;
--bs-red-dim:       rgba(232, 41, 74, 0.45);
--bs-red-glow:      rgba(232, 41, 74, 0.32); --bs-light:         #f7f5f1;
--bs-light-2:       #eeeae4; --bs-dark:          #09090d;
--bs-dark-2:        #0f1018;
--bs-dark-3:        #161720; --bs-border:        rgba(0, 0, 0, 0.07); --bs-text:          #111118;
--bs-text-dim:      rgba(17, 17, 24, 0.48); --bs-text-inv:      #dde1ec;
--bs-text-inv-dim:  rgba(221, 225, 236, 0.48); --bs-spring:        cubic-bezier(0.34, 1.56, 0.64, 1);
--bs-ease-out:      cubic-bezier(0.22, 1, 0.36, 1);
--bs-ff-display: 'Syne', sans-serif;
--bs-ff-mono:    'JetBrains Mono', monospace;
} .bs-section {
background: var(--bs-light);
color: var(--bs-text);
position: relative;
overflow: hidden;
width: 100vw;
margin-left: calc(50% - 50vw);
padding-bottom: 120px;
} .bs-section::before {
content: '';
position: absolute;
inset: 0;
background-image:
radial-gradient(circle, rgba(17, 17, 24, 0.055) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
z-index: 0;
opacity: 0;
transition: opacity 2.2s var(--bs-ease-out) 0.4s;
}
.bs-section.is-visible::before {
opacity: 1;
} .bs-section::after {
content: '';
position: absolute;
top: 0;
left: -100%;
height: 3px;
width: 100%;
background: linear-gradient(
90deg,
transparent 0%,
var(--bs-red) 20%,
var(--bs-red) 80%,
transparent 100%
);
z-index: 10;
transition: left 1.4s var(--bs-ease-out) 0.15s;
}
.bs-section.is-visible::after {
left: 0;
} .bs-header {
text-align: center;
padding: 100px 40px 64px;
position: relative;
z-index: 2;
}
.bs-eyebrow {
display: inline-flex;
align-items: center;
gap: 14px;
font-family: var(--bs-ff-mono);
font-size: 10px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--bs-red);
margin-bottom: 28px;
opacity: 0;
transform: translateY(20px);
transition: opacity 0.7s ease 0.2s, transform 0.8s var(--bs-ease-out) 0.2s;
}
.bs-section.is-visible .bs-eyebrow {
opacity: 1;
transform: translateY(0);
}
.bs-eyebrow-line {
display: block;
width: 36px;
height: 1px;
background: var(--bs-red);
opacity: 0.6;
}
.bs-title {
font-family: var(--bs-ff-display);
font-size: clamp(38px, 5vw, 68px);
font-weight: 700;
letter-spacing: -2px;
color: var(--bs-text);
margin: 0 0 22px;
line-height: 1.05;
perspective: 900px;
transform-style: preserve-3d;
} .bs-word {
display: inline-block;
opacity: 0;
transform: translateY(70px) rotateX(-28deg);
transform-origin: bottom center;
transition:
opacity  0.65s ease            calc(var(--word-i, 0) * 80ms + 320ms),
transform 0.95s var(--bs-spring) calc(var(--word-i, 0) * 80ms + 320ms);
}
.bs-section.is-visible .bs-word {
opacity: 1;
transform: translateY(0) rotateX(0deg);
} .bs-title:not(:has(.bs-word)) {
opacity: 0;
transform: translateY(32px);
transition: opacity 0.9s ease 0.35s, transform 0.9s var(--bs-ease-out) 0.35s;
}
.bs-section.is-visible .bs-title:not(:has(.bs-word)) {
opacity: 1;
transform: translateY(0);
}
.bs-subtitle {
font-family: var(--bs-ff-mono);
font-size: 13px;
color: var(--bs-text-dim);
max-width: 500px;
margin: 0 auto;
line-height: 1.9;
letter-spacing: 0.3px;
opacity: 0;
transform: translateY(18px);
transition: opacity 0.8s ease 0.78s, transform 0.8s var(--bs-ease-out) 0.78s;
}
.bs-section.is-visible .bs-subtitle {
opacity: 1;
transform: translateY(0);
} .bs-stage {
position: relative;
display: flex;
align-items: center;
padding: 0 32px;
max-width: 1600px;
margin: 0 auto;
z-index: 2;
} .bs-edge {
flex-shrink: 0;
width: 130px;
display: flex;
flex-direction: column;
align-items: center;
gap: 12px;
opacity: 0;
transition:
opacity   0.7s ease             0.9s,
transform 1s   var(--bs-spring) 0.9s;
}
.bs-edge--left  { transform: translateX(-60px); }
.bs-edge--right { transform: translateX(60px); flex-direction: column; }
.bs-section.is-visible .bs-edge {
opacity: 1;
transform: translateX(0) !important;
}
.bs-edge-label {
font-family: var(--bs-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 2px;
text-transform: uppercase;
color: var(--bs-text);
line-height: 1.8;
text-align: center;
}
.bs-edge-dot {
width: 12px;
height: 12px;
border-radius: 50%;
background: var(--bs-red);
box-shadow: 0 0 12px var(--bs-red-glow);
opacity: 0.7;
}
.bs-edge-arrow {
font-size: 40px;
color: var(--bs-red);
opacity: 0.35;
line-height: 1;
} .bs-bridge-wrap {
flex: 1;
min-width: 0;
}
.bs-image-container {
position: relative;
width: 100%;
padding-bottom: 56.25%;
background: var(--bs-dark);
overflow: hidden;
border-radius: 4px; opacity: 0;
transform: translateY(40px) scale(0.96);
filter: blur(6px);
transition:
opacity   1.3s var(--bs-ease-out) 0.55s,
transform 1.5s var(--bs-ease-out) 0.55s,
filter    1.1s ease               0.55s,
box-shadow 0.4s ease;
box-shadow:
0 20px 70px rgba(0, 0, 0, 0.18),
0 4px  16px rgba(0, 0, 0, 0.1),
0 0 0 1px rgba(0, 0, 0, 0.05);
}
.bs-section.is-visible .bs-image-container {
opacity: 1;
transform: translateY(0) scale(1);
filter: blur(0);
}
.bs-image-container:hover {
box-shadow:
0 32px 100px rgba(0, 0, 0, 0.24),
0 8px  32px  rgba(0, 0, 0, 0.14),
0 0 0 1px rgba(232, 41, 74, 0.08);
}
.bs-bridge-img {
position: absolute;
top: 0; left: 0;
width: 100%; height: 100%;
object-fit: contain;
object-position: center;
display: block;
opacity: 0;
transform: scale(0.97);
transition:
opacity   1.4s var(--bs-ease-out) 0.7s,
transform 1.6s var(--bs-ease-out) 0.7s;
}
.bs-section.is-visible .bs-bridge-img {
opacity: 1;
transform: scale(1);
} .bs-scanline {
position: absolute;
top: 0; left: -130px;
width: 130px; height: 100%;
background: linear-gradient(
90deg,
transparent 0%,
rgba(232, 41, 74, 0.22) 50%,
transparent 100%
);
z-index: 5;
pointer-events: none;
}
.bs-section.is-visible .bs-scanline {
animation: bsScanReveal 2.2s cubic-bezier(0.25, 0, 0.25, 1) 0.65s forwards;
}
@keyframes bsScanReveal {
0%   { left: -130px; opacity: 0; }
8%   { opacity: 1; }
88%  { opacity: 1; }
100% { left: 110%;  opacity: 0; }
} .bs-nodes-bar {
position: relative;
width: 100%;
height: 112px;
background: var(--bs-dark-2);
border-top: 1px solid rgba(232, 41, 74, 0.22);
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.14);
} .bs-node {
position: absolute;
top: 50%;
transform: translateX(-50%) translateY(calc(-50% + 18px));
display: flex;
flex-direction: column;
align-items: center;
gap: 8px;
background: none;
border: none;
cursor: pointer;
padding: 0;
z-index: 20;
opacity: 0;
transition:
opacity  0.6s ease,
transform 0.8s var(--bs-spring);
}
.bs-section.is-visible .bs-node--software  { opacity: 1; transform: translateX(-50%) translateY(-50%); transition-delay: 0.72s; }
.bs-section.is-visible .bs-node--ai        { opacity: 1; transform: translateX(-50%) translateY(-50%); transition-delay: 0.88s; }
.bs-section.is-visible .bs-node--embedded  { opacity: 1; transform: translateX(-50%) translateY(-50%); transition-delay: 1.04s; }
.bs-section.is-visible .bs-node--hardware  { opacity: 1; transform: translateX(-50%) translateY(-50%); transition-delay: 1.20s; }
.bs-node--software { left: 23%; }
.bs-node--ai       { left: 40%; }
.bs-node--embedded { left: 57%; }
.bs-node--hardware { left: 74%; } .bs-node-core {
width: 50px;
height: 50px;
border-radius: 50%;
background: rgba(9, 9, 13, 0.9);
border: 1.5px solid rgba(232, 41, 74, 0.38);
display: flex;
align-items: center;
justify-content: center;
color: rgba(232, 41, 74, 0.78);
position: relative;
z-index: 2;
transition: all 0.32s cubic-bezier(0.4, 0, 0.2, 1);
box-shadow:
0 0 18px rgba(232, 41, 74, 0.1),
inset 0 0 14px rgba(232, 41, 74, 0.05);
backdrop-filter: blur(4px); animation: bsCoreFloat 4.2s ease-in-out infinite;
}
.bs-node--ai       .bs-node-core { animation-duration: 3.7s; animation-delay: -1.1s; }
.bs-node--embedded .bs-node-core { animation-duration: 4.6s; animation-delay: -2.4s; }
.bs-node--hardware .bs-node-core { animation-duration: 3.4s; animation-delay: -0.6s; }
@keyframes bsCoreFloat {
0%, 100% { transform: translateY(0px); }
50%       { transform: translateY(-8px); }
} .bs-node:hover     .bs-node-core,
.bs-node.is-active .bs-node-core {
animation: none;
} .bs-node-ring {
position: absolute;
width: 50px;
height: 50px;
border-radius: 50%;
border: 1px solid rgba(232, 41, 74, 0.28);
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
pointer-events: none;
z-index: 1;
animation: bsRingPulse 3.5s ease-out infinite;
}
.bs-node-ring--2 {
animation-delay: 1.2s;
}
@keyframes bsRingPulse {
0%   { width: 50px;  height: 50px;  opacity: 0.5; }
100% { width: 110px; height: 110px; opacity: 0; }
} .bs-node-label {
font-family: var(--bs-ff-mono);
font-size: 9px;
font-weight: 700;
letter-spacing: 2.5px;
color: #fff;
background: transparent;
border: none;
padding: 4px 0;
white-space: nowrap;
transition: all 0.3s ease;
position: relative;
z-index: 2;
} .bs-node:hover .bs-node-core {
border-color: var(--bs-red);
color: #fff;
background: rgba(232, 41, 74, 0.88);
box-shadow:
0 0 28px rgba(232, 41, 74, 0.55),
0 0 64px rgba(232, 41, 74, 0.28),
0 0 120px rgba(232, 41, 74, 0.12),
inset 0 0 14px rgba(255, 255, 255, 0.12);
transform: scale(1.12) translateY(-3px);
}
.bs-node:hover .bs-node-label {
color: #fff;
letter-spacing: 3px;
}
.bs-node:hover .bs-node-ring {
border-color: rgba(232, 41, 74, 0.42);
} .bs-node.is-active .bs-node-core {
border-color: var(--bs-red);
color: #fff;
background: var(--bs-red);
box-shadow:
0 0 40px rgba(232, 41, 74, 0.65),
0 0 90px rgba(232, 41, 74, 0.38),
0 0 160px rgba(232, 41, 74, 0.18),
inset 0 0 20px rgba(255, 255, 255, 0.16);
transform: scale(1.18) translateY(-5px);
}
.bs-node.is-active .bs-node-label {
color: var(--bs-red);
letter-spacing: 3.5px;
}
.bs-node.is-active .bs-node-ring {
animation-duration: 1.8s;
border-color: rgba(232, 41, 74, 0.48);
} .bs-section.has-active .bs-node:not(.is-active) {
opacity: 0.32;
} .bs-beam {
position: absolute;
top: 58%;
width: 2px;
height: 0;
transform: translateX(-50%);
background: linear-gradient(to bottom, var(--bs-red), rgba(232, 41, 74, 0));
box-shadow: 0 0 14px var(--bs-red-glow);
z-index: 15;
pointer-events: none;
opacity: 0;
transition: left 0.22s ease; }
.bs-beam.is-active {
animation: bsBeamDraw 0.6s var(--bs-ease-out) forwards;
}
@keyframes bsBeamDraw {
0%   { height: 0;   opacity: 0;   filter: brightness(5) blur(3px); }
12%  {              opacity: 1;   filter: brightness(3) blur(1px); }
50%  { height: 28%; opacity: 1;   filter: brightness(1.6); }
100% { height: 42%; opacity: 1;   filter: brightness(1); }
} .bs-cards-area {
max-width: 1200px;
margin: 0 auto;
padding: 0 40px;
position: relative;
z-index: 2;
min-height: 100px;
} .bs-prompt {
display: flex;
align-items: center;
justify-content: center;
gap: 14px;
padding: 48px 20px;
font-family: var(--bs-ff-mono);
font-size: 12px;
color: var(--bs-text-dim);
letter-spacing: 1.5px;
transition: opacity 0.35s ease, transform 0.35s ease;
}
.bs-prompt.is-hidden {
opacity: 0;
pointer-events: none;
transform: translateY(-8px);
display: none;
}
.bs-prompt-arrow {
display: inline-block;
color: var(--bs-red);
opacity: 0.6;
animation: bsPromptBounce 1.8s ease-in-out infinite;
font-size: 18px;
}
@keyframes bsPromptBounce {
0%, 100% { transform: translateY(0); }
50%       { transform: translateY(-7px); }
} .bs-card {
display: none;
grid-template-columns: 80px 1fr;
background: var(--bs-dark-2);
border: 1px solid rgba(255, 255, 255, 0.04);
border-top: 2px solid var(--bs-red);
border-radius: 2px 2px 12px 12px;
overflow: hidden;
margin-top: 0; opacity: 0;
transform: perspective(1100px) rotateX(-10deg) translateY(32px);
transition:
opacity   0.6s var(--bs-ease-out),
transform 0.85s var(--bs-spring);
box-shadow:
0 20px 60px rgba(0, 0, 0, 0.2),
0 4px  16px rgba(0, 0, 0, 0.1);
}
.bs-card.is-active {
display: grid;
}
.bs-card.is-visible {
opacity: 1;
transform: perspective(1100px) rotateX(0deg) translateY(0);
box-shadow:
0 32px 90px rgba(0, 0, 0, 0.22),
0 8px  24px rgba(0, 0, 0, 0.12),
0 0 0 1px rgba(232, 41, 74, 0.07);
} .bs-card-sidebar {
background: var(--bs-red);
display: flex;
align-items: center;
justify-content: center;
font-family: var(--bs-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 4px;
color: rgba(255, 255, 255, 1) !important;
writing-mode: vertical-lr;
text-orientation: mixed;
transform: rotate(180deg);
padding: 28px 0;
} .bs-card-body {
padding: 40px 48px;
}
.bs-card-top {
margin-bottom: 32px;
padding-bottom: 24px;
border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.bs-card-tag {
display: inline-block;
font-family: var(--bs-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 2px;
text-transform: uppercase;
color: var(--bs-red) !important;
border: 1px solid rgba(232, 41, 74, 0.35);
padding: 5px 14px;
border-radius: 2px;
margin-bottom: 14px;
}
.bs-card-top h3 {
font-family: var(--bs-ff-display);
font-size: clamp(24px, 2.5vw, 34px);
font-weight: 600;
color: #fff !important;
margin: 0;
line-height: 1.2;
letter-spacing: -0.5px;
} .bs-card-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 36px;
}
.bs-block h4 {
display: flex;
align-items: center;
gap: 10px;
font-family: var(--bs-ff-mono);
font-size: 10px;
font-weight: 700;
letter-spacing: 1.5px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.7);
margin: 0 0 14px;
}
.bs-badge {
font-family: var(--bs-ff-mono);
font-size: 10px;
font-weight: 700;
letter-spacing: 2px;
padding: 4px 10px;
border-radius: 2px;
}
.bs-badge--why  { background: rgba(255, 200, 0, 0.12);  color: #ffc800; border: 1px solid rgba(255, 200, 0, 0.25); }
.bs-badge--how  { background: rgba(0, 200, 150, 0.12);  color: #00c896; border: 1px solid rgba(0, 200, 150, 0.25); }
.bs-badge--what { background: rgba(232, 41, 74, 0.12);  color: var(--bs-red); border: 1px solid rgba(232, 41, 74, 0.25); }
.bs-block p {
font-size: 14px;
color: var(--bs-text-inv-dim);
line-height: 1.8;
margin: 0;
}
.bs-results {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 10px;
}
.bs-results li {
font-size: 14px;
color: var(--bs-text-inv-dim);
padding-left: 20px;
position: relative;
line-height: 1.7;
}
.bs-results li::before {
content: '→';
position: absolute;
left: 0;
color: var(--bs-red);
font-size: 11px;
line-height: 1.8;
}
.bs-results strong {
color: #fff;
font-weight: 600;
} .bs-card-footer {
margin-top: 20px;
padding-top: 16px;
border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.bs-card-link {
display: inline-flex;
align-items: center;
gap: 6px;
font-family: var(--bs-ff-mono);
font-size: 11px;
font-weight: 600;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--bs-red) !important;
text-decoration: none !important;
transition: gap 0.3s var(--bs-ease-out), opacity 0.2s ease;
opacity: 0.85;
}
.bs-card-link:hover {
gap: 12px;
opacity: 1;
color: var(--bs-red) !important;
} .bs-quote-wrap {
text-align: center;
padding: 80px 40px 0;
position: relative;
z-index: 2;
opacity: 0;
transform: translateY(28px);
transition: opacity 0.9s ease 1.4s, transform 0.9s var(--bs-ease-out) 1.4s;
}
.bs-section.is-visible .bs-quote-wrap {
opacity: 1;
transform: translateY(0);
}
.bs-quote-line {
width: 1px;
height: 64px;
background: linear-gradient(to bottom, transparent, rgba(232, 41, 74, 0.4));
margin: 0 auto 48px;
}
.bs-quote {
font-family: var(--bs-ff-display);
font-size: clamp(20px, 2.8vw, 36px);
font-weight: 300;
font-style: italic;
color: var(--bs-text-dim);
line-height: 1.55;
max-width: 860px;
margin: 0 auto;
border: none;
padding: 0;
}
.bs-quote-mark {
color: var(--bs-red);
font-style: normal;
font-size: 1.3em;
line-height: 0;
vertical-align: -0.25em;
opacity: 0.7;
} @media (max-width: 1200px) {
.bs-edge { width: 90px; }
.bs-edge-label { font-size: 8px; }
}
@media (max-width: 900px) {
.bs-stage { padding: 0 16px; }
.bs-edge  { display: none; }
.bs-card.is-active { grid-template-columns: 1fr; }
.bs-card-sidebar {
writing-mode: horizontal-tb;
transform: none;
padding: 14px 24px;
}
.bs-card-grid {
grid-template-columns: 1fr;
gap: 24px;
}
.bs-node-core { width: 40px; height: 40px; }
.bs-node-ring { width: 40px; height: 40px; }
@keyframes bsRingPulse {
0%   { width: 40px;  height: 40px;  opacity: 0.5; }
100% { width: 90px;  height: 90px;  opacity: 0; }
}
}
@media (max-width: 600px) {
.bs-header { padding: 60px 20px 40px; }
.bs-stage  { padding: 0; }
.bs-cards-area { padding: 0 16px; }
.bs-card-body  { padding: 24px; }
.bs-card-top h3 { font-size: 20px; }
.bs-node-core  { width: 32px; height: 32px; }
.bs-node-core svg { width: 15px; height: 15px; }
.bs-node-label { font-size: 7.5px; padding: 4px 8px; letter-spacing: 1.5px; }
}:root { --thelis-red:       #E8294A;
--thelis-red-dark:  #c91e38;
--thelis-red-glow:  rgba(232, 41, 74, 0.28);
--thelis-red-dim:   rgba(232, 41, 74, 0.06); --thelis-black:     #111118;
--thelis-white:     #ffffff;
--thelis-light:     #f7f5f1; --thelis-light-bg:  #f7f5f1;  --thelis-text:      #111118;
--thelis-gray:      rgba(17, 17, 24, 0.50);
--thelis-border:    rgba(17, 17, 24, 0.08); --thelis-ff-display: 'Syne', sans-serif;
--thelis-ff-mono:    'JetBrains Mono', monospace; --thelis-ff-title:   'Cormorant Garamond', Georgia, serif; --thelis-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);
--thelis-ease-out:  cubic-bezier(0.22, 1, 0.36, 1);
--thelis-ease:      cubic-bezier(0.4, 0, 0.2, 1);
} #thelis-progress {
position: fixed;
top: 0; left: 0;
width: 0%;
height: 3px;
background: var(--thelis-red, #E8294A);
z-index: 99999;
transition: width 0.08s linear;
pointer-events: none;
} .thelis-homepage h1,
.thelis-homepage h2,
.thelis-homepage h3,
.thelis-homepage h4,
.thelis-homepage h5 {
font-family: var(--thelis-ff-display);
color: var(--thelis-text);
}
.thelis-homepage {
overflow-x: hidden;
font-family: var(--thelis-ff-display);
} .container {
max-width: 1400px;
margin: 0 auto;
padding: 0 48px;
}
section {
padding: 120px 0;
}
section:nth-child(even) {
background: var(--thelis-light);
}   .section-label {
display: inline-flex;
align-items: center;
gap: 14px;
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--thelis-red);
margin-bottom: 24px;
}
.bs-subtitle {
font-family: var(--bs-ff-mono);
font-size: 13px;
color: var(--bs-text-dim);
max-width: 500px;
margin: 0 auto;
line-height: 1.9;
letter-spacing: 0.3px;
opacity: 0;
transform: translateY(18px);
transition: opacity 0.8s ease 0.78s, transform 0.8s var(--bs-ease-out) 0.78s;
}
.bs-section.is-visible .bs-subtitle {
opacity: 1;
transform: translateY(0);
}
.section-label::before,
.section-label::after {
content: '';
display: block;
width: 36px;
height: 1px;
background: var(--thelis-red);
opacity: 0.6;
flex-shrink: 0;
} .section-title {
font-family: var(--thelis-ff-display);
font-size: clamp(34px, 4vw, 58px);
font-weight: 700;
letter-spacing: -2px;
color: var(--thelis-text);
line-height: 1.08;
margin-bottom: 22px;
}
.section-intro {
font-family: var(--thelis-ff-display);
text-align: center;
font-size: 17px;
color: var(--thelis-gray);
line-height: 1.75;
max-width: 760px;
margin: 0 auto;
}
.highlight {
color: var(--thelis-red);
}  .fade-in-up {
opacity: 0;
transform: translateY(36px);
transition:
opacity   0.7s var(--thelis-ease-out) calc(var(--i, 0) * 80ms),
transform 0.9s var(--thelis-spring)   calc(var(--i, 0) * 80ms);
}
.fade-in-up.animated {
opacity: 1;
transform: translateY(0);
}
.fade-in-scale {
opacity: 0;
transform: translateY(20px) scale(0.97);
transition:
opacity   0.75s var(--thelis-ease-out) calc(var(--i, 0) * 80ms),
transform 1s    var(--thelis-spring)   calc(var(--i, 0) * 80ms);
}
.fade-in-scale.animated {
opacity: 1;
transform: translateY(0) scale(1);
} .btn {
display: inline-block;
padding: 13px 28px;
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
text-decoration: none;
border-radius: 2px;
transition:
background  0.25s ease,
color       0.25s ease,
border-color 0.25s ease,
transform   0.4s var(--thelis-spring),
box-shadow  0.25s ease;
}
.btn-primary {
background: var(--thelis-red);
color: white;
border: 1.5px solid var(--thelis-red);
}
.btn-primary:hover {
background: var(--thelis-red-dark);
border-color: var(--thelis-red-dark);
transform: translateY(-3px);
box-shadow: 0 10px 28px rgba(232, 41, 74, 0.3);
color: white;
}
.btn-secondary {
background: transparent;
color: var(--thelis-text);
border: 1.5px solid rgba(17, 17, 24, 0.28);
}
.btn-secondary:hover {
background: var(--thelis-text);
border-color: var(--thelis-text);
color: white;
transform: translateY(-3px);
}
.btn-large {
padding: 16px 36px;
font-size: 11px;
letter-spacing: 3.5px;
} .hero-section {
height: 100vh;
min-height: 560px; display: flex;
flex-direction: column;
background: var(--thelis-black);
position: relative;
overflow: hidden;
} .hero-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(232, 41, 74, 0.055) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
z-index: 1;
} .hero-section::after {
content: '';
position: absolute;
top: 0; left: 0;
height: 3px;
width: 55%;
background: linear-gradient(90deg, var(--thelis-red), transparent);
z-index: 10;
} .hero-bg {
position: absolute;
inset: 0;
overflow: hidden;
z-index: 0;
}
.hero-bg-img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: left 40%;
filter: brightness(0.45) saturate(0.55);
transform: scale(1.06);
transition: transform 14s ease-out;
will-change: transform;
display: block;
} .hero-bg-img.is-loaded {
transform: scale(1.0);
} .hero-bg-overlay {
position: absolute;
inset: 0;
background:
radial-gradient(
ellipse 80% 60% at 65% 45%,
rgba(232, 41, 74, 0.04) 0%,
transparent 70%
),
linear-gradient(
180deg,
rgba(17, 17, 24, 0.12) 0%,
rgba(17, 17, 24, 0.00) 30%,
rgba(17, 17, 24, 0.32) 100%
);
pointer-events: none;
} .hero-wrap {
flex: 1;
display: flex;
align-items: center; padding: clamp(72px, 10vh, 110px) 48px clamp(120px, 17vh, 162px);
max-width: 1400px;
width: 100%;
margin: 0 auto;
position: relative;
z-index: 2;
box-sizing: border-box;
}
.hero-content {
max-width: 800px;
}
.hero-title {
font-family: var(--thelis-ff-title);
font-size: clamp(38px, 5vw, 66px);
font-weight: 600;
color: var(--thelis-white) !important;
line-height: 1.08;
letter-spacing: -0.5px;
margin-bottom: clamp(14px, 1.8vh, 24px);
}
.hero-tagline {
font-family: var(--thelis-ff-display);
font-size: clamp(16px, 1.8vh, 19px);
color: rgba(255, 255, 255, 0.68) !important;
line-height: 1.7;
margin-bottom: clamp(18px, 2.5vh, 32px);
font-weight: 400;
}
.hero-tagline strong {
color: rgba(255, 255, 255, 0.92) !important;
font-weight: 600;
}
.hero-badges {
display: flex;
flex-wrap: wrap;
gap: 7px;
margin-bottom: clamp(20px, 2.8vh, 36px);
} .badge {
padding: 7px 15px;
background: rgba(17, 17, 24, 0.45);
border: 1px solid rgba(232, 41, 74, 0.45);
border-radius: 2px;
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 700;
color: rgba(255, 255, 255, 0.90) !important;
text-transform: uppercase;
letter-spacing: 2px;
transition: border-color 0.25s ease, background 0.25s ease;
}
.badge:hover {
border-color: var(--thelis-red);
background: rgba(232, 41, 74, 0.12);
color: var(--thelis-white) !important;
}
.hero-cta {
display: flex;
gap: 12px;
flex-wrap: wrap;
} .btn-secondary--dark {
color: rgba(255, 255, 255, 0.82) !important;
border-color: rgba(255, 255, 255, 0.22) !important;
}
.btn-secondary--dark:hover {
background: rgba(255, 255, 255, 0.06) !important;
border-color: rgba(255, 255, 255, 0.45) !important;
color: var(--thelis-white) !important;
} .hero-journey {
display: flex;
height: clamp(105px, 15vh, 145px);
position: absolute; bottom: 0;
left: 0;
right: 0;
z-index: 2;
border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.hero-journey-item {
flex: 1;
position: relative;
overflow: hidden;
}
.hero-journey-item img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
filter: brightness(0.48) saturate(0.65);
transform: scale(1);
transition: filter 0.7s var(--thelis-ease-out), transform 0.9s var(--thelis-ease-out);
display: block;
} .hero-journey-item--idea img    { object-position: center 22%; }
.hero-journey-item--eng img     { object-position: center 45%; }
.hero-journey-item--reality img { object-position: center center; }
.hero-journey-item:hover img {
filter: brightness(0.82) saturate(0.88);
transform: scale(1.07);
} .hero-journey-veil {
position: absolute;
inset: 0;
background:
radial-gradient(ellipse 85% 75% at 50% 50%, rgba(17, 17, 24, 0.42) 0%, transparent 70%),
linear-gradient(0deg, rgba(17, 17, 24, 0.85) 0%, rgba(17, 17, 24, 0.10) 50%, transparent 100%);
transition: opacity 0.7s ease;
pointer-events: none;
z-index: 1;
}
.hero-journey-item:hover .hero-journey-veil {
opacity: 0.5;
} .hero-journey-meta {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) scale(1);
z-index: 2;
display: flex;
flex-direction: column;
align-items: center;
gap: 10px;
text-align: center;
transition: transform 0.65s var(--thelis-ease-out), opacity 0.65s ease;
will-change: transform, opacity;
pointer-events: none;
}
.hero-journey-item:hover .hero-journey-meta {
transform: translate(-50%, -50%) scale(0.55);
opacity: 0.25;
}
.hero-journey-step {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red) !important;
line-height: 1;
}
.hero-journey-label {
font-family: var(--thelis-ff-display);
font-size: clamp(16px, 2.2vw, 28px);
font-weight: 700;
letter-spacing: 7px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.92) !important;
line-height: 1;
} .hero-journey-item--idea::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: linear-gradient(90deg, var(--thelis-red) 0%, rgba(232, 41, 74, 0.40) 100%);
z-index: 3;
} .hero-journey-item--reality::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: linear-gradient(90deg, rgba(232, 41, 74, 0.40) 0%, var(--thelis-red) 100%);
z-index: 3;
} @keyframes heroArrowPulse {
0%, 100% { transform: translateX(0);   opacity: 1; }
50%       { transform: translateX(5px); opacity: 0.6; }
}
.hero-journey-arrow {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 6px;
width: 58px;
flex-shrink: 0;
background: rgba(17, 17, 24, 0.82);
position: relative;
z-index: 2;
border-left:  1px solid rgba(232, 41, 74, 0.22);
border-right: 1px solid rgba(232, 41, 74, 0.22);
} .hero-journey-arrow::before {
content: '';
width: 20px;
height: 1px;
background: rgba(232, 41, 74, 0.65);
} .hero-journey-arrow::after {
content: '→';
font-family: var(--thelis-ff-mono);
font-size: 22px;
color: var(--thelis-red);
animation: heroArrowPulse 2.2s ease-in-out infinite;
}  .problem-section {
background: var(--thelis-white);
position: relative;
overflow: hidden;
} .problem-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(17,17,24,0.045) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
} .problem-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
} .problem-header {
text-align: center;
margin-bottom: 80px;
position: relative;
z-index: 1;
} .prob-divider {
width: 80px;
height: 2px;
background: linear-gradient(90deg, var(--thelis-red), rgba(232, 41, 74, 0.15));
margin: 28px auto 28px;
transform-origin: left center;
transform: scaleX(0);
} .problem-header.animated .prob-divider {
animation: probDrawLine 0.9s var(--thelis-ease-out) 0.45s forwards;
}
@keyframes probDrawLine {
from { transform: scaleX(0); }
to   { transform: scaleX(1); }
} .problem-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
margin-bottom: 56px;
position: relative;
z-index: 1;
}
.problem-card {
background: var(--thelis-light);
padding: 40px 36px 32px;
border-radius: 4px;
text-align: left;
border-top: 2px solid transparent;
transition:
border-color 0.25s ease,
transform    0.45s var(--thelis-spring),
box-shadow   0.25s ease;
}
.problem-card:hover {
border-top-color: var(--thelis-red);
transform: translateY(-6px);
box-shadow: 0 16px 44px rgba(0, 0, 0, 0.07);
}
.problem-card h3 {
font-family: var(--thelis-ff-display);
font-size: 20px;
font-weight: 700;
letter-spacing: -0.5px;
color: var(--thelis-text);
margin-bottom: 12px;
}
.problem-card p {
font-family: var(--thelis-ff-display);
font-size: 14px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.75;
margin-bottom: 20px;
} .prob-tag {
display: block;
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
border-top: 1px solid var(--thelis-border);
padding-top: 16px;
} .problem-conclusion {
text-align: center;
padding: 32px 48px;
background: var(--thelis-red-dim);
border-left: 3px solid var(--thelis-red);
border-radius: 2px;
position: relative;
z-index: 1;
}
.emphasis {
font-family: var(--thelis-ff-display);
font-size: 18px;
font-weight: 600;
color: var(--thelis-text);
} .engineering-gap-section {
background: var(--thelis-light);
padding-top: 0; } .bs-section .bs-header {
padding-top: 40px;
}
.gap-header {
text-align: center;
margin-bottom: 72px;
}
.gap-visual {
margin-bottom: 60px;
}
.gap-diagram {
display: grid;
grid-template-columns: 1fr 2fr 1fr;
gap: 40px;
align-items: center;
}
.gap-side h3 {
font-size: 20px;
font-weight: 700;
letter-spacing: -0.5px;
margin-bottom: 18px;
}
.gap-side ul {
list-style: none;
padding: 0;
}
.gap-side li {
padding: 9px 0;
font-size: 15px;
color: var(--thelis-gray);
border-bottom: 1px solid var(--thelis-border);
}
.gap-side li:first-child {
border-top: 1px solid var(--thelis-border);
}
.gap-bridge {
text-align: center;
}
.gap-pillars {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 10px;
margin-bottom: 18px;
}
.gap-pillar {
background: var(--thelis-red);
color: white;
padding: 16px 10px;
border-radius: 2px;
font-family: var(--thelis-ff-mono);
font-weight: 700;
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
}
.gap-label {
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 700;
color: var(--thelis-red);
text-transform: uppercase;
letter-spacing: 3px;
}
.gap-conclusion {
text-align: center;
max-width: 860px;
margin: 0 auto;
}
.gap-conclusion p {
font-size: 17px;
color: var(--thelis-gray);
line-height: 1.75;
margin-bottom: 14px;
} .innovation-model-section {
background: var(--thelis-white);
position: relative;
overflow: hidden;
} .innovation-model-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(17,17,24,0.045) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
} .innovation-model-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
} .im-header {
text-align: center;
margin-bottom: 80px;
position: relative;
z-index: 1;
}
.im-intro {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: var(--thelis-gray);
max-width: 640px;
margin: 16px auto 0;
line-height: 1.75;
} .im-flow {
position: relative;
z-index: 1;
margin-bottom: 64px;
}   .im-nodes-row {
--im-conn-w: 64px;
display: grid;
grid-template-columns: 1fr var(--im-conn-w) 1fr var(--im-conn-w) 1fr var(--im-conn-w) 1fr;
align-items: start;
} .im-node-col {
display: flex;
flex-direction: column;
align-items: center;
} .im-node {
position: relative;
width: 56px;
height: 56px;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
} .im-node-ring {
position: absolute;
inset: -10px;
border-radius: 50%;
border: 1.5px solid rgba(232, 41, 74, 0.22);
animation: imRingPulse 2.8s ease-in-out infinite;
pointer-events: none;
}
@keyframes imRingPulse {
0%, 100% { transform: scale(1);   opacity: 0.55; }
50%       { transform: scale(1.6); opacity: 0;    }
} .im-node-core {
width: 56px;
height: 56px;
background: var(--thelis-red);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-family: var(--thelis-ff-mono);
font-size: 13px;
font-weight: 700;
color: #ffffff;
letter-spacing: 0.5px;
box-shadow: 0 8px 24px var(--thelis-red-glow);
position: relative;
z-index: 1;
transition:
transform  0.35s var(--thelis-spring),
box-shadow 0.25s ease;
}
.im-node-col:hover .im-node-core {
transform: scale(1.12);
box-shadow: 0 14px 36px rgba(232, 41, 74, 0.45);
} .im-v-line {
width: 2px;
height: 32px;
background: linear-gradient(
180deg,
var(--thelis-red) 0%,
rgba(232, 41, 74, 0.08) 100%
);
flex-shrink: 0;
} .im-conn {
position: relative;
height: 88px; } .im-conn::before {
content: '';
position: absolute;
left: -2px;
right: -2px;
top: 28px; height: 1px;
background: rgba(17, 17, 24, 0.10);
} .im-conn::after {
content: '';
position: absolute;
left: -28px;
top: 27px;
width: 28px;
height: 2px;
background: linear-gradient(90deg, transparent, var(--thelis-red) 50%, transparent);
animation: imFlowPulse 2.2s ease-in-out infinite;
animation-delay: var(--cd, 0s);
}
@keyframes imFlowPulse {
0%   { left: -28px;              opacity: 0; }
12%  {                            opacity: 1; }
88%  {                            opacity: 1; }
100% { left: calc(100% + 4px);   opacity: 0; }
} .im-chevron {
position: absolute;
top: 28px;
left: 50%;
transform: translate(-50%, -50%);
font-family: var(--thelis-ff-mono);
font-size: 18px;
font-weight: 700;
color: var(--thelis-red);
background: var(--thelis-white); padding: 1px 6px;
line-height: 1;
z-index: 2;
letter-spacing: 0;
}  .im-cards {
display: grid;
grid-template-columns: repeat(4, 1fr);
column-gap: 64px;
row-gap: 0;
}
.im-card {
background: var(--thelis-white);
border: 1px solid var(--thelis-border);
border-top: 2px solid transparent;
border-radius: 4px;
padding: 32px 28px 28px;
position: relative;
overflow: hidden;
transition:
border-top-color 0.3s ease,
transform        0.45s var(--thelis-spring),
box-shadow       0.25s ease;
}
.im-card:hover {
border-top-color: var(--thelis-red);
transform: translateY(-6px);
box-shadow: 0 20px 56px rgba(17, 17, 24, 0.10);
} .im-ghost {
position: absolute;
bottom: -8px;
right: 12px;
font-family: var(--thelis-ff-mono);
font-size: 72px;
font-weight: 700;
color: rgba(17, 17, 24, 0.04);
line-height: 1;
pointer-events: none;
user-select: none;
transition: color 0.3s ease;
}
.im-card:hover .im-ghost {
color: rgba(232, 41, 74, 0.07);
} .im-eyebrow {
display: block;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red);
margin-bottom: 14px;
} .im-card-title {
font-family: var(--thelis-ff-display);
font-size: 26px;
font-weight: 700;
letter-spacing: -1px;
color: var(--thelis-text);
line-height: 1.1;
margin-bottom: 14px;
} .im-card-desc {
font-family: var(--thelis-ff-display);
font-size: 14px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.75;
margin-bottom: 20px;
} .im-tags {
display: flex;
flex-wrap: wrap;
gap: 6px;
}
.im-tags span {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
background: var(--thelis-light);
border: 1px solid var(--thelis-border);
border-radius: 2px;
padding: 4px 10px;
} .model-principle {
padding: 32px 48px;
border-left: 3px solid var(--thelis-red);
background: var(--thelis-red-dim);
border-radius: 2px;
max-width: 860px;
margin: 0 auto;
position: relative;
z-index: 1;
}
.model-principle p {
font-family: var(--thelis-ff-display);
font-size: 18px;
font-weight: 300;
color: rgba(17, 17, 24, 0.60);
font-style: italic;
line-height: 1.65;
text-align: center;
margin: 0;
}
.model-principle strong {
font-weight: 600;
color: var(--thelis-text);
font-style: normal;
} .how-we-work-section {
background: var(--thelis-light);
position: relative;
} .how-we-work-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
} .how-we-work-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(17,17,24,0.045) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
} .hww-header {
text-align: center;
margin-bottom: 80px;
} .hww-diagram {
display: grid;
grid-template-columns: 190px 1fr 190px;
gap: 48px;
align-items: center;
max-width: 1020px;
margin: 0 auto 80px;
} .hww-side {
display: flex;
flex-direction: column;
justify-content: space-around;
align-self: stretch;
gap: 0;
padding: 24px 0;
}
.hww-side--left  { align-items: flex-end; }
.hww-side--right { align-items: flex-start; } .hww-label {
display: flex;
flex-direction: column;
gap: 7px;
}
.hww-side--left  .hww-label { align-items: flex-end; text-align: right; }
.hww-side--right .hww-label { align-items: flex-start; text-align: left; }
.hww-label h4 {
font-family: var(--thelis-ff-display);
font-size: 13px;
font-weight: 700;
letter-spacing: -0.3px;
color: var(--thelis-text);
margin: 0;
line-height: 1.3;
}
.hww-label p {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
margin: 0;
} .hww-dot {
display: block;
width: 7px;
height: 7px;
border-radius: 50%;
background: var(--thelis-red);
flex-shrink: 0;
animation: hwwDotPulse 2.8s ease-in-out infinite;
}
@keyframes hwwDotPulse {
0%, 100% { transform: scale(1);   opacity: 1;   box-shadow: 0 0 0 0   rgba(232,41,74,0.45); }
50%       { transform: scale(1.4); opacity: 0.8; box-shadow: 0 0 0 5px rgba(232,41,74,0);    }
} .hww-svg-wrap { }
.hww-svg {
width: 100%;
height: auto;
display: block;
overflow: visible;
}  .hww-track {
stroke: rgba(17,17,24,0.10);
stroke-width: 1.5;
} .hww-glow {
stroke: var(--thelis-red);
stroke-width: 9;
opacity: 0.15;
stroke-dasharray: 22 78;
animation: hwwFlow 4s linear infinite -0.3s;
} .hww-particle {
stroke: var(--thelis-red);
stroke-width: 2.5;
stroke-linecap: round;
stroke-dasharray: 8 92;
animation: hwwFlow 4s linear infinite;
} .hww-particle-echo {
stroke: var(--thelis-red);
stroke-width: 1.5;
stroke-linecap: round;
stroke-dasharray: 8 92;
opacity: 0.35;
animation: hwwFlow 4s linear infinite -2s;
}
@keyframes hwwFlow {
from { stroke-dashoffset: 0;    }
to   { stroke-dashoffset: -100; }
} .hww-center-ring {
stroke: var(--thelis-red);
stroke-width: 1;
opacity: 0.5;
transform-origin: 250px 100px;
animation: hwwRingPulse 2.8s ease-in-out infinite;
}
@keyframes hwwRingPulse {
0%, 100% { transform: scale(1);   opacity: 0.55; }
50%       { transform: scale(2.2); opacity: 0;    }
} .hww-center-dot {
opacity: 0.9;
animation: hwwDotCenterPulse 2.8s ease-in-out infinite;
transform-origin: 250px 100px;
}
@keyframes hwwDotCenterPulse {
0%, 100% { transform: scale(1);    opacity: 0.9; }
50%       { transform: scale(1.25); opacity: 0.6; }
} .work-principle {
background: rgba(232,41,74,0.04);
border-left: 3px solid var(--thelis-red);
border-radius: 2px;
padding: 32px 48px;
max-width: 760px;
margin: 0 auto;
text-align: center;
}
.work-principle p {
font-family: var(--thelis-ff-display);
font-size: 18px;
color: rgba(17,17,24,0.60);
font-style: italic;
line-height: 1.65;
margin: 0;
}
.work-principle strong {
font-weight: 600;
color: var(--thelis-text);
font-style: normal;
} @media (max-width: 1024px) {
.hww-diagram {
grid-template-columns: 160px 1fr 160px;
gap: 32px;
}
}
@media (max-width: 768px) {
.hww-diagram {
grid-template-columns: 1fr;
gap: 40px;
max-width: 480px;
} .hww-svg-wrap   { order: -1; }
.hww-side--left { order: 0; flex-direction: row; justify-content: space-around; align-items: flex-start; padding: 0; }
.hww-side--right { order: 1; flex-direction: row; justify-content: space-around; align-items: flex-start; padding: 0; }
.hww-side--left  .hww-label,
.hww-side--right .hww-label { align-items: center; text-align: center; }
}
@media (max-width: 480px) {
.hww-side--left,
.hww-side--right { flex-direction: column; gap: 28px; align-items: center; }
.work-principle { padding: 28px 28px; }
.work-principle p { font-size: 16px; }
} .what-we-build-section {
background-color: #111118;
position: relative;
padding: 120px 0 96px;
overflow: hidden;
} .what-we-build-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
z-index: 10;
} .what-we-build-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(232,41,74,0.05) 1.2px, transparent 1.2px);
background-size: 32px 32px;
z-index: 1;
pointer-events: none;
} .wwb-bg {
position: absolute;
inset: 0;
z-index: 0;
overflow: hidden;
}
.wwb-bg img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center 40%;
display: block;
filter: grayscale(0.20) brightness(0.52) contrast(1.10);
transform: scale(1.05);
animation: wwbKenBurns 18s ease-out forwards;
}
@keyframes wwbKenBurns {
from { transform: scale(1.05); }
to   { transform: scale(1.00); }
}
.wwb-bg-overlay {
position: absolute;
inset: 0;
background: linear-gradient(
180deg,
rgba(14, 14, 20, 0.74) 0%,
rgba(14, 14, 20, 0.58) 40%,
rgba(14, 14, 20, 0.68) 100%
);
} .what-we-build-section .container {
position: relative;
z-index: 2;
} .wwb-header {
text-align: center;
margin-bottom: 64px;
} .wwb-label--dark {
display: flex; justify-content: center;
margin-bottom: 28px; }
.wwb-headline {
font-family: 'Cormorant Garamond', Georgia, serif;
font-family: var(--thelis-ff-title);
font-size: clamp(46px, 5.5vw, 76px);
font-weight: 600;
line-height: 1.06;
letter-spacing: -2px;
color: #ffffff !important;
margin: 0 0 24px;
}
.wwb-headline em {
font-style: italic;
color: rgba(255, 255, 255, 0.70) !important;
}
.wwb-subline {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: rgba(255, 255, 255, 0.72) !important;
max-width: 540px;
margin: 0 auto;
line-height: 1.65;
} .wwb-rule {
height: 1px;
background: linear-gradient(
90deg,
transparent 0%,
rgba(255,255,255,0.12) 15%,
rgba(255,255,255,0.12) 85%,
transparent 100%
);
margin-bottom: 0;
} .wwb-grid {
display: grid;
grid-template-columns: repeat(5, 1fr);
border-left: 1px solid rgba(255,255,255,0.08);
}
.wwb-col {
padding: 44px 28px 40px;
border-right: 1px solid rgba(255,255,255,0.10);
border-top: 1px solid rgba(255,255,255,0.10);
position: relative; background: rgba(14, 14, 20, 0.56);
transition: background 0.35s ease;
overflow: hidden;
} .wwb-col::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 2px;
background: var(--thelis-red);
transform: scaleX(0);
transform-origin: left center;
transition: transform 0.45s var(--thelis-ease-out);
}
.wwb-col:hover {
background: rgba(14, 14, 20, 0.28);
}
.wwb-col:hover::after {
transform: scaleX(1);
} .wwb-col__num {
display: none;
} .wwb-col__name {
font-family: var(--thelis-ff-display);
font-size: 22px;
font-weight: 700;
color: #ffffff !important;
letter-spacing: -0.5px;
line-height: 1.22;
margin: 0 0 16px;
transition: color 0.28s ease;
padding-top: 4px;
} .wwb-col__name::before {
content: '';
display: block;
width: 24px;
height: 2px;
background: var(--thelis-red, #E8294A);
margin-bottom: 18px;
transition: width 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.wwb-col:hover .wwb-col__name {
color: var(--thelis-red, #E8294A) !important;
}
.wwb-col:hover .wwb-col__name::before {
width: 36px;
} .wwb-col__desc {
font-family: var(--thelis-ff-display);
font-size: 15px;
font-weight: 300;
color: rgba(255, 255, 255, 0.72) !important;
line-height: 1.62;
margin: 0 0 20px;
transition: color 0.28s ease;
}
.wwb-col:hover .wwb-col__desc {
color: rgba(255, 255, 255, 0.92) !important;
} .wwb-col__tags {
display: flex;
flex-direction: column;
gap: 5px;
opacity: 0.80;
transition: opacity 0.35s ease;
}
.wwb-col:hover .wwb-col__tags {
opacity: 1;
}
.wwb-col__tags span {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 1.8px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.65) !important;
border: 1px solid rgba(255, 255, 255, 0.22);
border-radius: 2px;
padding: 4px 9px;
display: inline-block;
width: fit-content;
} .wwb-footer {
border-top: 1px solid rgba(255, 255, 255, 0.08);
display: flex;
justify-content: center;
padding-top: 52px;
}
.wwb-outcome-card {
border-left: 2px solid var(--thelis-red);
padding: 20px 28px;
background: rgba(232, 41, 74, 0.08);
max-width: 480px;
width: 100%;
}
.wwb-outcome-label {
display: block;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 700;
letter-spacing: 3.5px;
text-transform: uppercase;
color: var(--thelis-red);
margin-bottom: 10px;
}
.wwb-outcome-card p {
font-family: var(--thelis-ff-display);
font-size: 15px;
font-weight: 400;
line-height: 1.55;
color: rgba(255, 255, 255, 0.72) !important;
margin: 0;
} @keyframes wwbScan {
0%   { top: -1px; opacity: 0; }
4%   { opacity: 1; }
90%  { opacity: 0.7; }
100% { top: 100%; opacity: 0; }
}
.wwb-scanline {
position: absolute;
left: 0; right: 0;
height: 1px;
background: linear-gradient(
to right,
transparent 0%,
rgba(232, 41, 74, 0.25) 20%,
rgba(232, 41, 74, 0.50) 50%,
rgba(232, 41, 74, 0.25) 80%,
transparent 100%
);
pointer-events: none;
z-index: 3;
animation: wwbScan 6s cubic-bezier(0.22, 1, 0.36, 1) infinite;
animation-delay: 1.5s;
} @media (max-width: 1200px) {
.wwb-grid { grid-template-columns: repeat(3, 1fr); }
.wwb-col:nth-child(3) { border-right: none; }
.wwb-col:nth-child(4),
.wwb-col:nth-child(5) { border-top: 1px solid rgba(255,255,255,0.08); }
}
@media (max-width: 1024px) {
.wwb-headline { font-size: clamp(40px, 5vw, 60px); }
.wwb-grid { grid-template-columns: repeat(2, 1fr); }
.wwb-col:nth-child(2n) { border-right: none; }
.wwb-col:nth-child(3) { border-right: 1px solid rgba(255,255,255,0.08); }
}
@media (max-width: 768px) {
.what-we-build-section { padding: 80px 0 72px; }
.wwb-headline { font-size: clamp(36px, 7vw, 52px); }
.wwb-grid { grid-template-columns: 1fr; }
.wwb-col { border-right: none; }
.wwb-col__tags { display: none; }
} .case-studies-section {
background: var(--thelis-light);
position: relative;
} .case-studies-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
} .cases-header {
text-align: center;
margin-bottom: 48px;
} .cs-filters {
display: flex;
justify-content: center;
gap: 4px;
margin-bottom: 48px;
}
.cs-filter {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 700;
letter-spacing: 2.5px;
text-transform: uppercase;
color: var(--thelis-gray);
background: transparent;
border: 1px solid var(--thelis-border);
border-radius: 2px;
padding: 8px 22px;
cursor: pointer;
transition: all 0.25s var(--thelis-ease-out);
}
.cs-filter:hover {
color: var(--thelis-black);
border-color: rgba(17,17,24,0.25);
}
.cs-filter.is-active {
background: var(--thelis-red);
color: #fff;
border-color: var(--thelis-red);
} .cs-panels {
display: flex;
height: 560px;
gap: 10px;
} .cs-panel {
flex: 0 0 72px;
background: #fff;
border-radius: 4px;
border-top: 2px solid transparent;
overflow: hidden;
cursor: pointer;
position: relative;
transition:
flex         0.65s var(--thelis-spring),
border-color 0.3s  ease;
}
.cs-panel.is-active {
flex: 1;
border-top-color: var(--thelis-red);
cursor: default;
}
.cs-panel:not(.is-active):hover {
border-top-color: rgba(232,41,74,0.40);
}
.cs-panel.is-hidden {
display: none;
} .cs-panel-collapsed {
position: absolute;
inset: 0;
display: flex;
flex-direction: column;
align-items: center;
padding: 28px 0 24px;
gap: 14px;
opacity: 1;
transition: opacity 0.2s ease;
pointer-events: none;
}
.cs-panel.is-active .cs-panel-collapsed {
opacity: 0;
}
.cs-panel-num {
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 700;
letter-spacing: 2px;
color: var(--thelis-red);
}
.cs-panel-vtitle {
writing-mode: vertical-rl;
transform: rotate(180deg);
font-family: var(--thelis-ff-body);
font-size: 12px;
font-weight: 600;
letter-spacing: 0.3px;
color: var(--thelis-black);
white-space: nowrap;
flex: 1;
}
.cs-panel-vtag {
writing-mode: vertical-rl;
transform: rotate(180deg);
font-family: var(--thelis-ff-mono);
font-size: 7px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
} .cs-panel-expanded {
position: absolute;
inset: 0;
padding: 26px 36px;
display: flex;
flex-direction: column;
opacity: 0;
transform: translateX(18px);
transition:
opacity   0.38s ease 0.18s,
transform 0.5s  var(--thelis-ease-out) 0.12s;
pointer-events: none;
overflow: hidden;
min-width: 420px;
}
.cs-panel.is-active .cs-panel-expanded {
opacity: 1;
transform: translateX(0);
pointer-events: all;
} .cs-panel-top {
display: flex;
align-items: flex-start;
justify-content: space-between;
margin-bottom: 10px;
}
.cs-panel-badges {
display: flex;
gap: 6px;
flex-wrap: wrap;
align-items: center;
}
.cs-badge {
display: inline-block;
padding: 4px 10px;
border-radius: 2px;
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1.5px;
}
.cs-badge--domain {
background: rgba(17,17,24,0.06);
color: var(--thelis-black);
} .tag-corporation { background: rgba(17,17,24,0.07);  color: var(--thelis-black); }
.tag-startup     { background: rgba(232,41,74,0.08); color: var(--thelis-red);   }
.tag-public      { background: rgba(42,59,143,0.07); color: #2a3b8f;             }
.cs-panel-ghost {
font-family: var(--thelis-ff-mono);
font-size: 72px;
font-weight: 700;
color: rgba(17,17,24,0.04);
line-height: 1;
user-select: none;
pointer-events: none;
} .cs-panel-title {
font-family: var(--thelis-ff-body);
font-size: 22px;
font-weight: 700;
letter-spacing: -0.5px;
color: var(--thelis-black);
margin-bottom: 10px;
} .cs-panel-desc {
font-family: var(--thelis-ff-body);
font-size: 14px;
color: var(--thelis-gray);
line-height: 1.65;
margin-bottom: 16px;
max-width: 540px;
} .cs-metrics {
display: flex;
gap: 36px;
padding: 14px 0;
border-top: 1px solid var(--thelis-border);
border-bottom: 1px solid var(--thelis-border);
margin-bottom: 14px;
}
.cs-metric {
display: flex;
flex-direction: column;
gap: 5px;
}
.cs-metric-value {
display: flex;
align-items: baseline;
gap: 1px;
font-family: var(--thelis-ff-mono);
color: var(--thelis-red);
}
.cs-metric-prefix {
font-size: 17px;
font-weight: 700;
line-height: 1;
}
.cs-metric-num {
font-size: 30px;
font-weight: 700;
line-height: 1;
letter-spacing: -1px;
}
.cs-metric-unit {
font-size: 15px;
font-weight: 500;
color: rgba(232,41,74,0.55);
}
.cs-metric-label {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
} .cs-stack {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-bottom: 14px;
}
.cs-stack span {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-black);
background: var(--thelis-light);
border: 1px solid var(--thelis-border);
border-radius: 2px;
padding: 4px 10px;
} .cs-read-link {
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 2.5px;
text-transform: uppercase;
color: var(--thelis-red) !important;
text-decoration: none !important;
display: inline-flex;
align-items: center;
gap: 8px;
margin-top: auto;
padding-top: 14px;
flex-shrink: 0;
transition: gap 0.3s var(--thelis-ease-out), opacity 0.2s ease;
opacity: 0.85;
border-bottom: 1px solid rgba(232, 41, 74, 0.25);
padding-bottom: 2px;
}
.cs-read-link:hover {
gap: 14px;
color: var(--thelis-red) !important;
opacity: 1;
border-bottom-color: rgba(232, 41, 74, 0.65);
} .tech-domains-section {
background: var(--thelis-white);
position: relative;
} .tech-domains-section::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(17,17,24,0.04) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
} .tech-domains-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
} .td-header {
text-align: center;
margin-bottom: 64px;
} .td-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 20px;
} .td-card {
border-radius: 4px;
border: 1px solid var(--thelis-border);
border-top: 2px solid transparent;
background: #fff;
transition:
transform    0.45s var(--thelis-spring),
box-shadow   0.28s ease,
border-color 0.25s ease;
cursor: default;
}
.td-card:hover {
transform: translateY(-7px);
box-shadow: 0 20px 52px rgba(0,0,0,0.08);
border-top-color: var(--thelis-red);
border-color: transparent;
border-top-color: var(--thelis-red);
}
.td-card-inner {
padding: 40px 40px 36px;
display: flex;
flex-direction: column;
height: 100%;
} .td-top {
display: flex;
align-items: flex-start;
justify-content: space-between;
margin-bottom: 28px;
} .td-icon-wrap {
width: 64px;
height: 64px;
border: 1px solid var(--thelis-border);
border-radius: 4px;
background: var(--thelis-light);
display: flex;
align-items: center;
justify-content: center;
position: relative;
overflow: hidden;
color: var(--thelis-red);
transition:
border-color 0.25s ease,
background   0.25s ease;
}
.td-card:hover .td-icon-wrap {
border-color: rgba(232,41,74,0.35);
background: rgba(232,41,74,0.04);
} .td-icon-wrap::after {
content: '';
position: absolute;
left: 0; right: 0;
height: 1px;
background: linear-gradient(90deg, transparent, rgba(232,41,74,0.7), transparent);
top: -100%;
opacity: 0;
}
.td-card:hover .td-icon-wrap::after {
animation: tdScanLine 0.55s var(--thelis-ease-out) 0.05s forwards;
}
@keyframes tdScanLine {
0%   { top: -5%;  opacity: 0; }
10%  { opacity: 1; }
90%  { opacity: 0.8; }
100% { top: 110%; opacity: 0; }
}
.td-icon {
flex-shrink: 0; } .td-num {
font-family: var(--thelis-ff-mono);
font-size: 52px;
font-weight: 700;
line-height: 1;
color: rgba(17,17,24,0.05);
user-select: none;
transition: color 0.25s ease;
}
.td-card:hover .td-num {
color: rgba(232,41,74,0.07);
} .td-title {
font-family: var(--thelis-ff-body);
font-size: 21px;
font-weight: 700;
letter-spacing: -0.5px;
color: var(--thelis-black);
margin-bottom: 10px;
} .td-title::after {
content: '';
display: block;
width: 0;
height: 2px;
background: var(--thelis-red);
margin-top: 10px;
transition: width 0.4s var(--thelis-ease-out);
opacity: 0.7;
}
.td-card:hover .td-title::after {
width: 32px;
} .td-desc {
font-family: var(--thelis-ff-body);
font-size: 14px;
color: var(--thelis-gray);
line-height: 1.75;
margin-bottom: 24px;
} .td-caps {
list-style: none;
margin: 0;
padding: 0;
margin-top: auto;
border-top: 1px solid var(--thelis-border);
padding-top: 16px;
display: flex;
flex-direction: column;
gap: 7px;
}
.td-caps li {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: var(--thelis-gray);
padding-left: 12px;
position: relative;
}
.td-caps li::before {
content: '';
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 4px;
height: 4px;
border-radius: 50%;
background: var(--thelis-red);
opacity: 0.5;
transition: opacity 0.2s ease;
}
.td-card:hover .td-caps li::before {
opacity: 1;
} .impact-section {
background: var(--thelis-light);
position: relative;
} .impact-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
pointer-events: none;
} .impact-header {
text-align: center;
margin-bottom: 80px;
} .impact-rows {
display: flex;
flex-direction: column;
border-top: 1px solid var(--thelis-border);
}
.impact-row {
display: grid;
grid-template-columns: 300px 1fr 220px;
gap: 64px;
align-items: center;
padding: 56px 0 56px 20px;
margin-left: -20px;
border-bottom: 1px solid var(--thelis-border);
position: relative;
transition:
background 0.35s ease;
cursor: default;
} .impact-row::before {
content: '';
position: absolute;
left: 0; top: 0; bottom: 0;
width: 3px;
background: var(--thelis-red);
transform: scaleY(0);
transform-origin: bottom center;
transition: transform 0.55s var(--thelis-spring);
}
.impact-row:hover {
background: rgba(255, 255, 255, 0.65);
}
.impact-row:hover::before {
transform: scaleY(1);
} .impact-row-meta {
position: relative;
padding: 4px 0;
} .impact-ghost {
position: absolute;
top: 50%;
left: -4px;
transform: translateY(-52%);
font-family: var(--thelis-ff-display);
font-size: 116px;
font-weight: 800;
line-height: 1;
letter-spacing: -6px;
color: var(--thelis-red);
opacity: 0.055;
user-select: none;
pointer-events: none;
z-index: 0;
transition: opacity 0.4s ease;
}
.impact-row:hover .impact-ghost {
opacity: 0.11;
} .impact-type {
position: relative;
z-index: 1;
display: flex;
align-items: center;
gap: 10px;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--thelis-red);
margin-bottom: 16px;
}
.impact-type::before {
content: '';
display: inline-block;
width: 24px;
height: 1px;
background: var(--thelis-red);
opacity: 0.6;
flex-shrink: 0;
} .impact-title {
position: relative;
z-index: 1;
font-family: var(--thelis-ff-display);
font-size: 26px;
font-weight: 700;
line-height: 1.2;
letter-spacing: -0.8px;
color: var(--thelis-black);
margin: 0;
} .impact-desc {
font-family: var(--thelis-ff-display);
font-size: 15px;
line-height: 1.8;
color: var(--thelis-gray);
font-weight: 300;
margin: 0;
} .impact-caps {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 14px;
}
.impact-caps li {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 2.5px;
text-transform: uppercase;
color: var(--thelis-black);
opacity: 0.55;
display: flex;
align-items: center;
gap: 10px;
transition:
opacity   0.25s ease,
color     0.25s ease;
}
.impact-caps li::before {
content: '';
width: 16px;
height: 1px;
background: var(--thelis-red);
flex-shrink: 0;
opacity: 0.5;
transition:
width   0.35s var(--thelis-spring),
opacity 0.25s ease;
}
.impact-row:hover .impact-caps li {
opacity: 0.85;
}
.impact-row:hover .impact-caps li::before {
width: 24px;
opacity: 1;
} .wt-section {
background: var(--thelis-white);
position: relative;
} .wt-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
pointer-events: none;
}
.wt-header {
text-align: center;
margin-bottom: 72px;
} .wt-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
margin-bottom: 64px;
} .wt-card {
background: var(--thelis-white);
border: 1px solid var(--thelis-border);
border-radius: 4px;
overflow: hidden;
transition:
transform   0.45s var(--thelis-spring),
box-shadow  0.3s ease;
cursor: default;
}
.wt-card:hover {
transform: translateY(-8px);
box-shadow: 0 24px 60px rgba(0, 0, 0, 0.09);
} .wt-card-top {
background: var(--thelis-black);
padding: 32px 36px 28px;
position: relative;
overflow: hidden;
min-height: 152px;
display: flex;
flex-direction: column;
justify-content: flex-end;
} .wt-card-top::before {
content: '';
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(232, 41, 74, 0.08) 1.2px, transparent 1.2px);
background-size: 28px 28px;
pointer-events: none;
} .wt-card-top::after {
content: '';
position: absolute;
bottom: 0; left: 0;
width: 0;
height: 2px;
background: var(--thelis-red);
transition: width 0.55s var(--thelis-spring);
}
.wt-card:hover .wt-card-top::after {
width: 100%;
} .wt-num {
position: absolute;
top: -10px;
right: 20px;
font-family: var(--thelis-ff-display);
font-size: 100px;
font-weight: 800;
line-height: 1;
letter-spacing: -4px;
color: white;
opacity: 0.04;
user-select: none;
pointer-events: none;
z-index: 0;
transition: opacity 0.4s ease;
}
.wt-card:hover .wt-num {
opacity: 0.08;
} .wt-icon {
position: relative;
z-index: 1;
width: 40px;
height: 40px;
color: white;
opacity: 0.8;
transition:
opacity   0.3s ease,
transform 0.4s var(--thelis-spring);
}
.wt-card:hover .wt-icon {
opacity: 1;
transform: scale(1.08);
} .wt-card-body {
padding: 36px 36px 40px;
display: flex;
flex-direction: column;
} .wt-label {
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--thelis-red);
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 18px;
}
.wt-label::before {
content: '';
display: inline-block;
width: 24px;
height: 1px;
background: var(--thelis-red);
opacity: 0.6;
flex-shrink: 0;
} .wt-heading {
font-family: var(--thelis-ff-display);
font-size: 22px;
font-weight: 700;
line-height: 1.25;
letter-spacing: -0.5px;
color: var(--thelis-black);
margin-bottom: 16px;
} .wt-desc {
font-family: var(--thelis-ff-display);
font-size: 15px;
line-height: 1.8;
color: var(--thelis-gray);
font-weight: 300;
margin-bottom: 24px;
flex: 1;
} .wt-proof {
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 500;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.72) !important;
display: flex;
align-items: center;
gap: 10px;
margin-top: 18px;
padding-top: 14px;
border-top: 1px solid rgba(255, 255, 255, 0.14);
position: relative;
z-index: 4;
}
.wt-proof::before {
content: '';
width: 16px;
height: 1px;
background: var(--thelis-red);
flex-shrink: 0;
} .wt-manifesto {
border-left: 3px solid var(--thelis-red);
background: rgba(232, 41, 74, 0.04);
border-radius: 2px;
padding: 32px 48px;
}
.wt-manifesto blockquote {
font-family: var(--thelis-ff-title);
font-size: clamp(24px, 3vw, 36px);
font-weight: 600;
font-style: italic;
letter-spacing: -0.5px;
line-height: 1.35;
color: var(--thelis-black);
margin: 0 0 14px 0;
border-left: none !important;
padding-left: 0 !important;
}
.wt-manifesto cite {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red);
font-style: normal;
display: flex;
align-items: center;
gap: 10px;
}
.wt-manifesto cite::before {
content: '';
display: inline-block;
width: 24px;
height: 1px;
background: var(--thelis-red);
opacity: 0.6;
} .fcta-section {
background: var(--thelis-black);
position: relative;
min-height: 80vh;
display: flex;
align-items: stretch;
overflow: hidden;
} .fcta-bg-img {
position: absolute;
inset: 0;
width: 100%; height: 100%;
object-fit: cover;
object-position: center 30%;
filter: brightness(0.22) saturate(0.35);
transition: filter 1.2s ease, transform 1.2s ease;
z-index: 0;
}
.fcta-section:hover .fcta-bg-img {
filter: brightness(0.32) saturate(0.45);
transform: scale(1.02);
} .fcta-overlay {
position: absolute;
inset: 0;
background: linear-gradient(
105deg,
rgba(17, 17, 24, 0.88) 0%,
rgba(17, 17, 24, 0.60) 50%,
rgba(17, 17, 24, 0.50) 100%
);
z-index: 1;
pointer-events: none;
} .fcta-vignette {
position: absolute;
inset: 0;
background: radial-gradient(ellipse 110% 100% at 0% 50%, transparent 40%, rgba(17, 17, 24, 0.55) 100%);
z-index: 1;
pointer-events: none;
} .fcta-grid-texture {
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(232, 41, 74, 0.05) 1.2px, transparent 1.2px);
background-size: 32px 32px;
z-index: 2;
pointer-events: none;
} .fcta-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent 70%);
z-index: 4;
} .fcta-section .container {
position: relative;
z-index: 3;
width: 100%;
display: flex;
align-items: center;
}
.fcta-layout {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 80px;
align-items: center;
padding: 110px 0;
width: 100%;
} .fcta-left {
display: flex;
flex-direction: column;
gap: 0;
}
.fcta-eyebrow {
margin-bottom: 28px;
}
.fcta-label {
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--thelis-red) !important;
display: inline-flex;
align-items: center;
gap: 12px;
opacity: 0.80;
}
.fcta-label::before {
content: '';
display: inline-block;
width: 36px;
height: 1px;
background: var(--thelis-red);
opacity: 0.5;
flex-shrink: 0;
} .fcta-title {
font-family: var(--thelis-ff-display) !important;
font-size: clamp(48px, 5.5vw, 88px) !important;
font-weight: 700 !important;
color: rgba(255, 255, 255, 0.96) !important;
letter-spacing: -2px;
line-height: 1.06;
margin-bottom: 36px;
}
.fcta-title em {
font-style: italic;
color: var(--thelis-red) !important;
position: relative;
display: inline-block;
}
.fcta-title em::after {
content: '';
position: absolute;
bottom: 2px;
left: 0; right: 0;
height: 2px;
background: linear-gradient(90deg, var(--thelis-red), rgba(232, 41, 74, 0.15));
border-radius: 1px;
} .fcta-badges {
display: flex;
align-items: center;
gap: 0;
}
.fcta-badge {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.28) !important;
padding: 0 20px 0 0;
transition: color 0.25s ease;
}
.fcta-badge:first-child { padding-left: 0; }
.fcta-badge:hover {
color: rgba(255, 255, 255, 0.55) !important;
}
.fcta-badge-sep {
display: inline-block;
width: 1px;
height: 12px;
background: rgba(255, 255, 255, 0.12);
flex-shrink: 0;
margin-right: 20px;
} .fcta-right {
display: flex;
flex-direction: column;
gap: 0;
padding-left: 0;
border-left: 1px solid rgba(255, 255, 255, 0.08);
padding-left: 80px;
} .fcta-rule {
display: none; }
.fcta-sub {
font-family: var(--thelis-ff-display);
font-size: 17px;
font-weight: 300;
line-height: 1.8;
color: rgba(255, 255, 255, 0.52) !important;
margin-bottom: 48px;
max-width: 380px;
} .fcta-cta-zone {
position: relative;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 24px;
} .fcta-glow-orb {
position: absolute;
top: 50%;
left: 0;
transform: translate(-20%, -50%);
width: 340px;
height: 120px;
background: radial-gradient(ellipse, rgba(232, 41, 74, 0.32) 0%, transparent 68%);
filter: blur(32px);
pointer-events: none;
animation: fctaOrbPulse 3.6s ease-in-out infinite;
z-index: 0;
}
@keyframes fctaOrbPulse {
0%, 100% { opacity: 0.55; transform: translate(-20%, -50%) scale(1); }
50%       { opacity: 0.85; transform: translate(-20%, -50%) scale(1.15); }
} .fcta-btn-wrap {
position: relative;
display: inline-flex;
padding: 48px 64px;
margin: -48px -64px;
z-index: 1;
} .fcta-btn-primary {
position: relative;
display: inline-flex;
align-items: center;
gap: 18px;
padding: 20px 48px;
background: var(--thelis-red);
color: white !important;
border-radius: 2px;
text-decoration: none !important;
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 4px;
text-transform: uppercase;
overflow: hidden;
transition: box-shadow 0.3s ease;
cursor: pointer;
white-space: nowrap;
}
.fcta-btn-fill {
position: absolute;
inset: 0;
background: var(--thelis-red-dark);
transform: scaleX(0);
transform-origin: left center;
transition: transform 0.45s var(--thelis-spring);
z-index: 0;
}
.fcta-btn-primary:hover .fcta-btn-fill {
transform: scaleX(1);
}
.fcta-btn-primary:hover {
box-shadow:
0 0 0 1px rgba(232, 41, 74, 0.55),
0 0 36px rgba(232, 41, 74, 0.45),
0 16px 48px rgba(232, 41, 74, 0.28);
}
.fcta-btn-text,
.fcta-btn-arrow {
position: relative;
z-index: 1;
}
.fcta-btn-arrow {
display: inline-flex;
align-items: center;
transition: transform 0.35s var(--thelis-spring);
}
.fcta-btn-primary:hover .fcta-btn-arrow {
transform: translateX(6px);
} .fcta-btn-ghost {
position: relative;
z-index: 1;
display: inline-flex;
align-items: center;
gap: 10px;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.25) !important;
text-decoration: none !important;
transition: color 0.25s ease, gap 0.3s var(--thelis-spring);
border-bottom: 1px solid rgba(255, 255, 255, 0.10);
padding-bottom: 3px;
}
.fcta-btn-ghost:hover {
color: rgba(255, 255, 255, 0.55) !important;
gap: 16px;
border-bottom-color: rgba(255, 255, 255, 0.28);
}  .problem-section {
background: #111118 !important;
} .problem-section::before {
background-image: radial-gradient(circle, rgba(232,41,74,0.08) 1.2px, transparent 1.2px);
}
.problem-section .section-title        { color: rgba(255, 255, 255, 0.94); }
.problem-section .section-intro        { color: rgba(255, 255, 255, 0.65) !important; }
.problem-section .problem-card {
background: rgba(255, 255, 255, 0.04);
border: 1px solid rgba(255, 255, 255, 0.07);
border-top: 2px solid transparent;
}
.problem-section .problem-card:hover {
background: rgba(255, 255, 255, 0.07);
box-shadow: 0 16px 44px rgba(0, 0, 0, 0.45);
}
.problem-section .problem-card h3      { color: rgba(255, 255, 255, 0.92); }
.problem-section .problem-card p       { color: rgba(255, 255, 255, 0.72) !important; }
.problem-section .prob-tag             { color: rgba(255, 255, 255, 0.65) !important;
border-top-color: rgba(255, 255, 255, 0.08); }
.problem-section .problem-conclusion   { background: rgba(232, 41, 74, 0.12); }
.problem-section .emphasis             { color: rgba(255, 255, 255, 0.88) !important; } .how-we-work-section {
background: #111118 !important;
} .how-we-work-section::before {
background-image: radial-gradient(circle, rgba(232,41,74,0.08) 1.2px, transparent 1.2px);
}
.how-we-work-section .section-title    { color: rgba(255, 255, 255, 0.94); }
.how-we-work-section .section-intro    { color: rgba(255, 255, 255, 0.65) !important; }
.how-we-work-section .hww-label h4     { color: rgba(255, 255, 255, 0.88); }
.how-we-work-section .hww-label p      { color: rgba(255, 255, 255, 0.65) !important; } .how-we-work-section .hww-track        { stroke: rgba(255, 255, 255, 0.18); } .how-we-work-section .work-principle        { background: rgba(232, 41, 74, 0.12); }
.how-we-work-section .work-principle p      { color: rgba(255, 255, 255, 0.72) !important; }
.how-we-work-section .work-principle strong { color: rgba(255, 255, 255, 0.92); } .impact-section {
background: #111118 !important;
} .impact-section .impact-rows              { border-top-color: rgba(255, 255, 255, 0.08); }
.impact-section .impact-row               { border-bottom-color: rgba(255, 255, 255, 0.08); }
.impact-section .impact-row:hover         { background: rgba(255, 255, 255, 0.04); }
.impact-section .section-title            { color: rgba(255, 255, 255, 0.94); }
.impact-section .section-intro            { color: rgba(255, 255, 255, 0.65) !important; }
.impact-section .impact-title             { color: rgba(255, 255, 255, 0.92); }
.impact-section .impact-desc              { color: rgba(255, 255, 255, 0.65) !important; } .impact-section .impact-caps li           { color: rgba(255, 255, 255, 0.65) !important; opacity: 1; }
.impact-section .impact-row:hover .impact-caps li { color: rgba(255, 255, 255, 0.88) !important; } .impact-section .impact-ghost             { color: var(--thelis-red); opacity: 0.08; }
.impact-section .impact-row:hover .impact-ghost { opacity: 0.16; }   .impact-section {
padding-top:    64px;
padding-bottom: 64px;
} .impact-section .impact-header {
margin-bottom: 40px;
} .impact-section .impact-rows {
display:               grid;
grid-template-columns: repeat(3, 1fr);
border-top:            none; gap:                   1px;
background:            rgba(255, 255, 255, 0.07); border-radius:         2px;
overflow:              hidden;
} .impact-section .impact-row {
display:        flex;
flex-direction: column;
align-items:    flex-start;
padding:        32px 28px 28px;
margin-left:    0;
border-bottom:  none;
background:     #111118;
gap:            0;
cursor:         default;
position:       relative;
transition:     background 0.35s ease;
}
.impact-section .impact-row:hover {
background: rgba(255, 255, 255, 0.04);
} .impact-section .impact-row::before {
content:          '';
position:         absolute;
top:              0; left: 0; right: 0; bottom: auto;
width:            auto;
height:           3px;
background:       var(--thelis-red);
transform:        scaleX(0);
transform-origin: left center;
transition:       transform 0.55s var(--thelis-spring);
}
.impact-section .impact-row:hover::before {
transform: scaleX(1);
} .impact-section .impact-ghost {
top:            14px;
left:           auto;
right:          14px;
transform:      none;
font-size:      60px;
letter-spacing: -3px;
line-height:    1;
opacity:        0.07;
}
.impact-section .impact-row:hover .impact-ghost {
opacity: 0.14;
} .impact-section .impact-row-meta {
position:      relative;
z-index:       1;
padding:       0;
margin-bottom: 14px;
}
.impact-section .impact-type {
font-size:     8px;
letter-spacing: 4px;
margin-bottom: 10px;
}
.impact-section .impact-title {
font-size:   20px;
line-height: 1.25;
} .impact-section .impact-desc {
font-size:     13px !important;
line-height:   1.75;
flex:          1;
margin-bottom: 20px;
color:         rgba(255, 255, 255, 0.65) !important;
} .impact-section .impact-caps {
margin-top: auto;
gap:        10px;
}
.impact-section .impact-caps li {
font-size:   8px !important;
letter-spacing: 2px;
opacity:     1;
color:       rgba(255, 255, 255, 0.55) !important;
}
.impact-section .impact-caps li::before {
width:   12px;
opacity: 0.45;
}
.impact-section .impact-row:hover .impact-caps li {
color: rgba(255, 255, 255, 0.80) !important;
}
.impact-section .impact-row:hover .impact-caps li::before {
width:   18px;
opacity: 0.85;
} @media (max-width: 768px) {
.impact-section .impact-rows {
grid-template-columns: 1fr;
}
.impact-section .impact-row {
padding: 28px 20px;
}
} @media (max-width: 1024px) {
.section-title {
font-size: 36px;
letter-spacing: -1.5px;
}
.build-grid {
grid-template-columns: 1fr;
gap: 48px;
} .hero-section {
height: 100vh;
} .hero-wrap {
padding: clamp(60px, 9vh, 90px) 40px clamp(118px, 17vh, 158px);
} .build-img-overlay {
background:
linear-gradient(
0deg,
rgba(17, 17, 24, 0.35) 0%,
transparent 55%
);
} .build-img-frame {
aspect-ratio: 16 / 9;
}
.problem-grid {
grid-template-columns: 1fr;
gap: 16px;
} .fcta-layout {
grid-template-columns: 1fr;
gap: 56px;
padding: 88px 0;
}
.fcta-right {
border-left: none;
padding-left: 0;
border-top: 1px solid rgba(255, 255, 255, 0.08);
padding-top: 48px;
}
.fcta-title {
font-size: clamp(42px, 7vw, 72px) !important;
}
.fcta-btn-wrap {
padding: 44px 60px;
margin: -44px -60px;
} .wt-grid {
grid-template-columns: 1fr;
gap: 16px;
}
.wt-manifesto {
padding: 28px 32px;
} .impact-row {
grid-template-columns: 240px 1fr;
gap: 40px;
padding: 44px 0 44px 16px;
margin-left: -16px;
}
.impact-caps {
grid-column: 1 / -1;
flex-direction: row;
flex-wrap: wrap;
gap: 10px 24px;
}
.impact-ghost {
font-size: 88px;
} .cs-panels {
height: 520px;
}
.cs-panel-expanded {
padding: 22px 26px;
min-width: 340px;
}
.cs-panel-photo { height: 90px; margin-bottom: 12px; }
.cs-panel-title { font-size: 18px; }
.cs-metric-num  { font-size: 24px; }
.cs-metrics     { gap: 24px; } .im-nodes-row {
--im-conn-w: 48px;
}
.im-cards {
column-gap: 48px;
}
}
@media (max-width: 768px) {
section {
padding: 80px 0;
}
.container {
padding: 0 24px;
}
.section-title {
font-size: 28px;
letter-spacing: -1px;
}
.hero-title {
font-size: 44px;
letter-spacing: -0.5px;
} .hero-section {
height: 100svh; min-height: 500px;
}
.hero-wrap {
padding: clamp(56px, 8vh, 80px) 24px clamp(150px, 22vh, 210px);
} .hero-bg-img {
object-position: 38% 40%;
} .hero-journey {
height: clamp(82px, 13svh, 100px);
} @keyframes heroWave {
0%   { transform: translateX(-100%) skewX(-18deg); opacity: 0; }
4%   { opacity: 1; }
55%  { opacity: 1; }
60%  { transform: translateX(200%)  skewX(-18deg); opacity: 0; }
100% { transform: translateX(200%)  skewX(-18deg); opacity: 0; }
}
.hero-journey::before {
content: '';
position: absolute;
top: 0; left: 0;
width: 40%;
height: 100%;
background: linear-gradient(
90deg,
transparent 0%,
rgba(255, 255, 255, 0.07) 40%,
rgba(255, 255, 255, 0.13) 50%,
rgba(255, 255, 255, 0.07) 60%,
transparent 100%
);
animation: heroWave 6s ease-in-out infinite;
pointer-events: none;
z-index: 3;
transform-origin: top left;
} .hero-journey-meta {
top: auto;
left: 14px;
bottom: 10px;
transform: none !important;
align-items: flex-start;
text-align: left;
gap: 4px;
opacity: 1 !important;
}
.hero-journey-label {
font-size: 8px;
letter-spacing: 2px;
font-family: var(--thelis-ff-mono);
}
.hero-journey-step {
font-size: 7px;
} @keyframes heroSpotlight {
0%   { filter: brightness(0.85) saturate(0.88); }
28%  { filter: brightness(0.85) saturate(0.88); } 38%  { filter: brightness(0.46) saturate(0.58); } 100% { filter: brightness(0.46) saturate(0.58); } } .hero-journey-item img {
transform: none;
transition: none;
animation: heroSpotlight 6s ease-in-out infinite;
} .hero-journey-item--idea img    { animation-delay: 0s; } .hero-journey-item--eng img     { animation-delay: -4s; } .hero-journey-item--reality img { animation-delay: -2.5s; } .hero-journey-item:hover img { filter: unset; transform: none; } .hero-journey-veil {
background: linear-gradient(
0deg,
rgba(17, 17, 24, 0.78) 0%,
rgba(17, 17, 24, 0.04) 45%,
transparent 100%
);
} .hero-journey-arrow {
width: 32px;
gap: 4px;
background: rgba(17, 17, 24, 0.88);
border-left:  1px solid rgba(232, 41, 74, 0.50);
border-right: 1px solid rgba(232, 41, 74, 0.50);
}
.hero-journey-arrow::before {
width: 14px;
background: rgba(232, 41, 74, 0.75);
}
.hero-journey-arrow::after {
font-size: 15px;
}
.hero-wrap {
padding: clamp(56px, 8vh, 80px) 24px clamp(108px, 19svh, 135px);
}
.td-grid {
grid-template-columns: 1fr;
gap: 16px;
}
.td-card-inner {
padding: 28px 28px 24px;
}
.td-num {
font-size: 40px;
} .im-nodes-row {
display: none;
}
.im-cards {
grid-template-columns: repeat(2, 1fr);
column-gap: 20px;
row-gap: 20px;
}
.gap-diagram {
grid-template-columns: 1fr;
}
.gap-pillars {
grid-template-columns: repeat(2, 1fr);
}
.cta-content h2 {
letter-spacing: -1.5px;
} .impact-row {
grid-template-columns: 1fr;
gap: 20px;
padding: 36px 0 36px 14px;
margin-left: -14px;
}
.impact-ghost {
font-size: 72px;
opacity: 0.04;
}
.impact-title {
font-size: 22px;
}
.impact-caps {
flex-direction: row;
flex-wrap: wrap;
gap: 8px 20px;
} .wt-card-top {
min-height: 120px;
padding: 24px 24px 20px;
}
.wt-card-body {
padding: 28px 24px 32px;
}
.wt-manifesto {
padding: 24px 24px;
} .cs-panels {
flex-direction: column;
height: auto;
gap: 8px;
}
.cs-panel {
flex: 0 0 auto !important;
} .cs-panel-collapsed {
display: none;
}
.cs-panel-expanded {
position: static;
opacity: 1 !important;
transform: none !important;
pointer-events: all !important;
min-width: 0;
padding: 24px 20px;
}
.cs-panel-ghost { font-size: 48px; }
.cs-metrics     { gap: 20px; flex-wrap: wrap; }
.cs-metric-num  { font-size: 26px; }
}
@media (max-width: 480px) { .im-cards {
grid-template-columns: 1fr;
gap: 16px;
}
.im-card {
padding: 28px 22px 24px;
}
.im-ghost {
font-size: 56px;
}
.model-principle {
padding: 24px 28px;
} .fcta-layout {
padding: 72px 0;
gap: 44px;
}
.fcta-title {
font-size: clamp(36px, 10vw, 54px) !important;
letter-spacing: -1px;
}
.fcta-sub {
font-size: 16px !important;
margin-bottom: 40px;
}
.fcta-glow-orb {
width: 240px;
height: 90px;
}
.fcta-btn-wrap {
padding: 40px 50px;
margin: -40px -50px;
}
.fcta-cta-zone {
align-items: flex-start;
}
.fcta-btn-primary {
padding: 18px 36px;
font-size: 10px;
letter-spacing: 3px;
gap: 14px;
}
.fcta-badges {
flex-wrap: wrap;
gap: 8px;
}
.fcta-badge-sep {
display: none;
}
.fcta-badge {
padding: 0 12px;
}
.fcta-circuit {
opacity: 0.6;
}
} .tech-domains-section {
padding-top:    64px;
padding-bottom: 64px;
}
.tech-domains-section .td-header {
margin-bottom: 28px;
}
.tech-domains-section .td-card-inner {
padding: 20px 24px 16px;
}
.tech-domains-section .td-top {
margin-bottom: 12px;
}
.tech-domains-section .td-icon-wrap {
width:  44px;
height: 44px;
}
.tech-domains-section .td-num {
font-size: 34px;
}
.tech-domains-section .td-title {
font-size: 16px;
margin-bottom: 8px;
}
.tech-domains-section .td-desc {
font-size:     13px;
line-height:   1.6;
margin-bottom: 12px;
}
.tech-domains-section .td-caps {
padding-top: 10px;
gap:          5px;
} .wt-card-top-img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
filter: brightness(0.38) saturate(0.45);
transition: transform 0.75s ease, filter 0.55s ease;
z-index: 0;
}
.wt-card:hover .wt-card-top-img {
transform: scale(1.06);
filter: brightness(0.50) saturate(0.60);
}
.wt-card-top-veil {
position: absolute;
inset: 0;
background: linear-gradient(160deg, rgba(17,17,24,0.25) 0%, rgba(17,17,24,0.68) 65%, rgba(17,17,24,0.82) 100%);
z-index: 1;
pointer-events: none;
} .wt-card-top::before { z-index: 2; }
.wt-card-top::after  { z-index: 3; }
.wt-num, .wt-icon    { position: relative; z-index: 4; } .impact-section .impact-row {
overflow: hidden;
}
.impact-row-bg-img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
filter: brightness(0.18) saturate(0.30);
transition: transform 0.7s ease, filter 0.6s ease;
z-index: 0;
pointer-events: none;
}
.impact-section .impact-row:hover .impact-row-bg-img {
transform: scale(1.04);
filter: brightness(0.28) saturate(0.42);
} .impact-section .impact-row-meta,
.impact-section .impact-desc,
.impact-section .impact-caps {
position: relative;
z-index: 1;
}  .cs-panel-bg-img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
filter: brightness(0.45) saturate(0.55);
transition: transform 0.65s ease, filter 0.45s ease;
z-index: 0;
}
.cs-panel:not(.is-active):hover .cs-panel-bg-img {
transform: scale(1.08);
filter: brightness(0.58) saturate(0.68);
}
.cs-panel-bg-veil {
position: absolute;
inset: 0;
z-index: 1;
pointer-events: none;
} .cs-panel[data-category="corporation"] .cs-panel-bg-veil {
background: linear-gradient(to bottom, rgba(17,17,24,0.28) 0%, rgba(17,17,24,0.62) 100%);
}
.cs-panel[data-category="startup"] .cs-panel-bg-veil {
background: linear-gradient(to bottom, rgba(17,17,24,0.22) 0%, rgba(232,41,74,0.20) 45%, rgba(17,17,24,0.58) 100%);
}
.cs-panel[data-category="public"] .cs-panel-bg-veil {
background: linear-gradient(to bottom, rgba(17,17,24,0.24) 0%, rgba(42,59,143,0.18) 45%, rgba(17,17,24,0.60) 100%);
} .cs-panel-num,
.cs-panel-vtitle,
.cs-panel-vtag {
position: relative;
z-index: 2;
}
.cs-panel-vtitle { color: rgba(255,255,255,0.92) !important; }
.cs-panel-vtag   { color: rgba(255,255,255,0.48) !important; } .cs-panel.is-active .cs-panel-bg-img,
.cs-panel.is-active .cs-panel-bg-veil {
opacity: 0;
transition: opacity 0.35s ease;
} .cs-panel-photo {
width: 100%;
height: 112px;
overflow: hidden;
border-radius: 3px;
margin-bottom: 14px;
flex-shrink: 0;
position: relative;
background: var(--thelis-light);
}
.cs-panel-photo img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
display: block;
filter: brightness(0.88) saturate(0.85);
transition: transform 0.7s ease;
}
.cs-panel.is-active:hover .cs-panel-photo img {
transform: scale(1.04);
} .cs-panel-photo::after {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(to right, transparent 55%, rgba(255,255,255,0.22) 100%);
pointer-events: none;
}  .td-card {
background: #111118;
overflow: hidden;
border-color: rgba(255,255,255,0.08);
}
.td-card:hover {
border-color: transparent;
box-shadow: 0 24px 64px rgba(0,0,0,0.32);
} .td-card-bg {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
filter: brightness(0.28) saturate(0.38);
transition: transform 0.80s ease, filter 0.60s ease;
z-index: 0;
}
.td-card:hover .td-card-bg {
transform: scale(1.06);
filter: brightness(0.46) saturate(0.55);
} .td-card::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
155deg,
rgba(17,17,24,0.38) 0%,
rgba(17,17,24,0.72) 55%,
rgba(17,17,24,0.92) 100%
);
z-index: 1;
pointer-events: none;
transition: opacity 0.55s ease;
}
.td-card:hover::before {
opacity: 0.82;
} .td-card-inner {
position: relative;
z-index: 2;
} .td-card .td-icon-wrap {
background: rgba(255,255,255,0.06);
border-color: rgba(255,255,255,0.13);
}
.td-card:hover .td-icon-wrap {
background: rgba(232,41,74,0.10);
border-color: rgba(232,41,74,0.38);
} .td-card .td-num {
color: rgba(255,255,255,0.055);
}
.td-card:hover .td-num {
color: rgba(232,41,74,0.10);
} .td-card .td-title {
color: rgba(255,255,255,0.92);
}
.td-card:hover .td-title::after {
width: 32px; } .td-card .td-desc {
color: rgba(255,255,255,0.58) !important;
} .td-card .td-caps {
border-top-color: rgba(255,255,255,0.10);
}
.td-card .td-caps li {
color: rgba(255,255,255,0.46) !important;
} .thelis-footer {
background: #0c0c10;
position: relative;
overflow: hidden;
} .thelis-footer::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 1px;
background: rgba(232, 41, 74, 0.18);
z-index: 3;
} .tf-dot-grid {
position: absolute;
inset: 0;
background-image: radial-gradient(circle, rgba(232,41,74,0.04) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
z-index: 0;
} .tf-body {
position: relative;
z-index: 2;
padding: 88px 0 72px;
border-bottom: 1px solid rgba(255,255,255,0.055);
} .tf-grid {
display: grid;
grid-template-columns: 1.5fr 1fr 1fr 1fr;
gap: 56px;
align-items: start;
} .tf-brand-col {
display: flex;
flex-direction: column;
gap: 22px;
}
.tf-logo {
display: inline-block;
text-decoration: none !important;
line-height: 1;
}
.tf-logo-img {
display: block;
height: 36px;
width: auto;
opacity: 0.88;
transition: opacity 0.25s ease;
}
.tf-logo:hover .tf-logo-img {
opacity: 1;
}
.tf-tagline {
font-family: var(--thelis-ff-display);
font-size: 14px;
font-weight: 300;
line-height: 1.7;
color: rgba(255,255,255,0.40) !important;
max-width: 210px;
margin: 0;
}
.tf-location {
display: inline-flex;
align-items: center;
gap: 7px;
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
letter-spacing: 2.5px;
text-transform: uppercase;
color: rgba(255,255,255,0.24) !important;
} .tf-nav-col {
display: flex;
flex-direction: column;
gap: 18px;
}
.tf-col-label {
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red) !important;
opacity: 0.72;
padding-bottom: 14px;
border-bottom: 1px solid rgba(255,255,255,0.055);
display: block;
}
.tf-links {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 10px;
}
.tf-links li a,
.tf-links li span {
font-family: var(--thelis-ff-display);
font-size: 14px;
font-weight: 400;
color: rgba(255,255,255,0.42) !important;
text-decoration: none !important;
transition: color 0.22s ease;
}
.tf-links li a:hover {
color: rgba(255,255,255,0.80) !important;
} .tf-links--contact li a {
font-family: var(--thelis-ff-mono) !important;
font-size: 11px !important;
letter-spacing: 0.3px;
display: inline-flex;
align-items: center;
gap: 6px;
} .tf-bottom {
position: relative;
z-index: 2;
padding: 20px 0;
}
.tf-bottom .container {
display: flex;
align-items: center;
justify-content: space-between;
gap: 24px;
}
.tf-copyright {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 1.5px;
color: rgba(255,255,255,0.18) !important;
}
.tf-legal {
display: flex;
align-items: center;
gap: 14px;
}
.tf-legal a {
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
letter-spacing: 1.5px;
text-transform: uppercase;
color: rgba(255,255,255,0.18) !important;
text-decoration: none !important;
transition: color 0.2s ease;
}
.tf-legal a:hover {
color: rgba(255,255,255,0.48) !important;
}
.tf-legal-sep {
color: rgba(255,255,255,0.10) !important;
font-size: 11px;
} .tf-wordmark {
position: absolute;
bottom: -0.12em;
left: 50%;
transform: translateX(-50%);
font-family: var(--thelis-ff-display);
font-size: clamp(96px, 17vw, 252px);
font-weight: 800;
letter-spacing: 0.18em;
color: rgba(255,255,255,0.028);
white-space: nowrap;
user-select: none;
pointer-events: none;
z-index: 1;
line-height: 1;
} @media (max-width: 1024px) {
.tf-grid {
grid-template-columns: 1fr 1fr;
gap: 44px;
}
.tf-brand-col {
grid-column: 1 / -1;
flex-direction: row;
flex-wrap: wrap;
gap: 28px 40px;
align-items: flex-start;
}
.tf-tagline { max-width: 260px; }
}
@media (max-width: 640px) {
.tf-grid {
grid-template-columns: 1fr 1fr;
gap: 36px;
}
.tf-brand-col {
grid-column: 1 / -1;
flex-direction: column;
gap: 18px;
}
.tf-body { padding: 64px 0 52px; }
.tf-bottom .container {
flex-direction: column;
align-items: flex-start;
gap: 10px;
}
.tf-wordmark {
font-size: clamp(72px, 22vw, 130px);
}
} .clients-section {
position: relative;
background: var(--thelis-light);
display: flex;
align-items: stretch;
overflow: hidden; padding: 0 !important; margin: 0 !important;
} .clients-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
z-index: 2;
pointer-events: none;
} .clients-label-col {
flex-shrink: 0;
width: 210px;
padding: 0 40px;
display: flex;
flex-direction: column;
justify-content: center;
gap: 7px;
border-right: 1px solid rgba(17,17,24,0.07);
position: relative;
z-index: 1; background: var(--thelis-light);
} .clients-label-col.fade-in-up {
clip-path: none;
opacity: 0;
transform: translateX(-14px);
transition:
opacity   0.7s cubic-bezier(0.22, 1, 0.36, 1)    0s,
transform 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0s;
}
.clients-label-col.fade-in-up.animated {
opacity: 1;
transform: translateX(0);
clip-path: none;
}
.clients-eyebrow {
font-family: 'JetBrains Mono', monospace;
font-size: 9px;
font-weight: 500;
letter-spacing: 5px;
text-transform: uppercase;
color: var(--thelis-red);
white-space: nowrap;
display: block;
}
.clients-eyebrow::before { display: none; }
.clients-count {
font-family: 'JetBrains Mono', monospace;
font-size: 9px;
font-weight: 400;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(17,17,24,0.32);
margin: 0;
padding: 0;
} .clients-marquee-outer {
flex: 1;
min-width: 0; overflow: hidden;
background: rgba(17,17,24,0.018); -webkit-mask-image: linear-gradient(90deg, black 0%, black 80%, transparent 100%);
mask-image: linear-gradient(90deg, black 0%, black 80%, transparent 100%);
} .clients-marquee-outer.fade-in-up {
opacity: 0;
transform: translateY(10px);
clip-path: none;
transition:
opacity   0.7s cubic-bezier(0.22, 1, 0.36, 1)    0.14s,
transform 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) 0.14s;
}
.clients-marquee-outer.fade-in-up.animated {
opacity: 1;
transform: translateY(0);
clip-path: none;
} .clients-ticker {
display: flex;
align-items: center;
width: max-content;
} .clients-ticker--fwd {
animation: clientsMarquee 48s linear infinite;
animation-play-state: paused;
padding: 12px 0;
} .clients-marquee-outer.animated .clients-ticker { animation-play-state: running; } .clients-marquee-outer.animated:hover .clients-ticker { animation-play-state: paused; }
@keyframes clientsMarquee {
from { transform: translateX(0); }
to   { transform: translateX(-50%); }
} .clients-logo {
display: flex;
align-items: center;
justify-content: center;
padding: 0 44px;
flex-shrink: 0;
position: relative;
background: transparent;
} .clients-logo--dark {
background: #0f0f16;
border-radius: 3px;
padding: 16px 40px;
margin: 0 6px;
}
.clients-logo--dark::before {
content: '';
position: absolute;
inset: 0;
border-radius: 3px;
background: rgba(232,41,74,0.05);
opacity: 0;
transition: opacity 0.4s ease;
pointer-events: none;
}
.clients-logo--dark:hover::before { opacity: 1; } .clients-logo img {
max-height: 72px;
max-width: 200px;
width: auto;
height: auto;
object-fit: contain;
display: block;
opacity: 0.58;
filter: none;
transition:
opacity   0.45s ease,
transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.clients-logo--dark img { opacity: 0.80; }
.clients-logo:hover img { opacity: 1; transform: scale(1.07); }
.clients-logo--dark:hover img { opacity: 1; transform: scale(1.06); }
@media (prefers-reduced-motion: reduce) {
.clients-ticker--fwd { animation: none; }
} @media (max-width: 1024px) {
.clients-label-col { width: 175px; padding: 0 28px; }
.clients-logo { padding: 0 32px; }
.clients-logo--dark { padding: 12px 28px; }
.clients-logo img { max-height: 46px; max-width: 135px; }
.clients-ticker--fwd { padding: 7px 0; }
}
@media (max-width: 768px) { .clients-section { flex-direction: column; }
.clients-label-col {
width: 100%;
flex-direction: row;
align-items: center;
justify-content: space-between;
padding: 18px 24px;
border-right: none;
border-bottom: 1px solid rgba(17,17,24,0.07);
gap: 0;
} .clients-marquee-outer {
-webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.clients-logo { padding: 0 24px; }
.clients-logo--dark { padding: 8px 20px; margin: 0 3px; }
.clients-logo img { max-height: 32px; max-width: 96px; }
.clients-ticker--fwd { padding: 12px 0; }
}.thelis-secnav {
position: fixed;
left: 0;
top: 50%;
transform: translateY(-50%);
z-index: 900;
width: 272px; display: flex;
flex-direction: column;
gap: 5px; perspective: 1000px;
perspective-origin: 0% 50%; opacity: 0;
pointer-events: none;
transition:
opacity   0.7s  cubic-bezier(0.22, 1, 0.36, 1),
transform 0.52s cubic-bezier(0.22, 1, 0.36, 1);
}
.thelis-secnav.is-visible {
opacity: 1;
pointer-events: auto;
} .thelis-secnav__item {
position: relative;
width: 272px;
height: 46px;
flex-shrink: 0;
display: flex;
align-items: center;
gap: 0;
padding: 0;
overflow: hidden;
background: rgba(8, 8, 13, 0.86);
border-left: 3px solid rgba(255, 255, 255, 0.07);
border-top: 1px solid rgba(255, 255, 255, 0.05);
border-bottom: 1px solid rgba(0, 0, 0, 0.35);
border-right: 1px solid rgba(255, 255, 255, 0.04);
text-decoration: none !important;
cursor: pointer; transform: translateX(-16px) rotateY(-10deg);
transform-origin: right center;
transform-style: preserve-3d; box-shadow:
3px 0 12px rgba(0, 0, 0, 0.45),
inset -1px 0 0 rgba(255, 255, 255, 0.03);
transition:
transform   0.56s cubic-bezier(0.34, 1.56, 0.64, 1),
height      0.46s cubic-bezier(0.22, 1, 0.36, 1),
background  0.28s ease,
border-left-color 0.28s ease,
box-shadow  0.28s ease;
will-change: transform, height;
} .thelis-secnav__item:hover:not(.is-active) {
transform: translateX(-6px) rotateY(-4deg);
background: rgba(12, 12, 18, 0.94);
} .thelis-secnav__item.is-active {
transform: translateX(0) rotateY(0deg) translateZ(6px);
height: 68px;
background: rgba(10, 10, 14, 0.97);
border-left-color: #E8294A;
box-shadow:
0  0  0  1px rgba(232, 41, 74, 0.12),
6px 0  28px rgba(232, 41, 74, 0.18),
0   8px 32px rgba(0, 0, 0, 0.55),
inset 1px 0 0 rgba(255, 255, 255, 0.05);
} .thelis-secnav__num {
flex-shrink: 0;
width: 70px; padding: 0 10px 0 14px;
font-family: 'JetBrains Mono', monospace;
font-size: 10px;
font-weight: 500;
letter-spacing: 1.5px;
color: rgba(255, 255, 255, 0.38) !important;
line-height: 1;
transition: color 0.28s ease, font-size 0.28s ease;
text-align: right;
}
.thelis-secnav__item.is-active .thelis-secnav__num {
color: #E8294A !important;
font-size: 11px;
} .thelis-secnav__sep {
width: 1px;
height: 22px;
background: rgba(255, 255, 255, 0.08);
flex-shrink: 0;
transition: background 0.28s ease, height 0.46s ease;
}
.thelis-secnav__item.is-active .thelis-secnav__sep {
background: rgba(232, 41, 74, 0.30);
height: 32px;
} .thelis-secnav__label {
flex: 1;
padding: 0 14px;
font-family: 'Syne', sans-serif;
font-size: 12px;
font-weight: 600;
letter-spacing: -0.2px;
color: rgba(255, 255, 255, 0.58) !important; white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
line-height: 1;
transition: color 0.28s ease, font-size 0.46s cubic-bezier(0.22, 1, 0.36, 1);
}
.thelis-secnav__item:hover:not(.is-active) .thelis-secnav__label {
color: rgba(255, 255, 255, 0.78) !important;
}
.thelis-secnav__item.is-active .thelis-secnav__label {
color: rgba(255, 255, 255, 0.92) !important;
font-size: 13px;
white-space: normal;
overflow: visible;
text-overflow: clip;
line-height: 1.3;
} .thelis-secnav__item::after {
content: '';
position: absolute;
right: 0;
top: 50%;
transform: translateY(-50%) scaleY(0);
width: 2px;
height: 60%;
background: linear-gradient(to bottom, transparent, #E8294A, transparent);
transform-origin: center;
transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
opacity: 0;
}
.thelis-secnav__item.is-active::after {
transform: translateY(-50%) scaleY(1);
opacity: 0.6;
} .thelis-secnav__item::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
90deg,
rgba(232, 41, 74, 0.06) 0%,
transparent 50%
);
opacity: 0;
transition: opacity 0.28s ease;
pointer-events: none;
}
.thelis-secnav__item.is-active::before {
opacity: 1;
} .thelis-secnav--compact .thelis-secnav__item {
height: 36px;
}
.thelis-secnav--compact .thelis-secnav__item.is-active {
height: 58px;
}
.thelis-secnav--compact .thelis-secnav__label {
font-size: 10.5px;
}
.thelis-secnav--compact .thelis-secnav__item.is-active .thelis-secnav__label {
font-size: 12px;
}
.thelis-secnav--compact {
gap: 3px;
} .thelis-secnav--on-dark .thelis-secnav__item {
background: rgba(248, 246, 243, 0.97);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border-left-color: rgba(17, 17, 24, 0.12);
border-top-color: rgba(17, 17, 24, 0.07);
border-bottom-color: rgba(17, 17, 24, 0.16);
border-right-color: rgba(17, 17, 24, 0.07);
box-shadow:
4px 0 24px rgba(0, 0, 0, 0.42),
inset -1px 0 0 rgba(17, 17, 24, 0.06);
}
.thelis-secnav--on-dark .thelis-secnav__item:hover:not(.is-active) {
background: rgba(255, 255, 255, 0.99);
}
.thelis-secnav--on-dark .thelis-secnav__item.is-active {
background: #ffffff;
backdrop-filter: none;
-webkit-backdrop-filter: none;
border-left-color: #E8294A;
box-shadow:
0  0  0  1px rgba(232, 41, 74, 0.18),
6px 0  28px rgba(232, 41, 74, 0.26),
0   8px 28px rgba(0, 0, 0, 0.35),
inset 1px 0 0 rgba(17, 17, 24, 0.06);
} .thelis-secnav--on-dark .thelis-secnav__num {
color: rgba(17, 17, 24, 0.38) !important;
}
.thelis-secnav--on-dark .thelis-secnav__item.is-active .thelis-secnav__num {
color: #E8294A !important;
} .thelis-secnav--on-dark .thelis-secnav__sep {
background: rgba(17, 17, 24, 0.14);
}
.thelis-secnav--on-dark .thelis-secnav__item.is-active .thelis-secnav__sep {
background: rgba(232, 41, 74, 0.35);
} .thelis-secnav--on-dark .thelis-secnav__label {
color: rgba(17, 17, 24, 0.65) !important; }
.thelis-secnav--on-dark .thelis-secnav__item:hover:not(.is-active) .thelis-secnav__label {
color: rgba(17, 17, 24, 0.84) !important; }
.thelis-secnav--on-dark .thelis-secnav__item.is-active .thelis-secnav__label {
color: rgba(17, 17, 24, 0.92) !important; } .thelis-secnav--on-dark .thelis-secnav__item::after {
background: linear-gradient(to bottom, transparent, #E8294A, transparent);
} .thelis-secnav--on-dark .thelis-secnav__item.is-active::before {
background: linear-gradient(90deg, rgba(232, 41, 74, 0.07) 0%, transparent 55%);
opacity: 1;
} .thelis-secnav__toggle {
position: absolute;
right: -28px;
top: 50%;
transform: translateY(-50%);
width: 28px;
height: 52px;
display: flex;
align-items: center;
justify-content: center;
background: rgba(8, 8, 13, 0.86);
border: 1px solid rgba(255, 255, 255, 0.06);
border-left: none;
border-radius: 0 4px 4px 0;
box-shadow: 3px 0 12px rgba(0, 0, 0, 0.45);
cursor: pointer;
color: rgba(255, 255, 255, 0.45) !important;
font-family: 'JetBrains Mono', monospace;
font-size: 14px;
line-height: 1;
padding: 0;
transition:
color      0.25s ease,
background 0.25s ease,
right      0.52s cubic-bezier(0.22, 1, 0.36, 1);
}
.thelis-secnav__toggle:hover {
background: rgba(14, 14, 20, 0.97);
color: var(--thelis-red, #E8294A) !important;
} .thelis-secnav__toggle-arrow {
display: inline-block;
transition: transform 0.42s cubic-bezier(0.34, 1.56, 0.64, 1);
} .thelis-secnav--collapsed {
transform: translateX(-272px) translateY(-50%);
} .thelis-secnav--collapsed .thelis-secnav__item {
pointer-events: none;
}
.thelis-secnav--collapsed .thelis-secnav__toggle {
pointer-events: auto;
}
.thelis-secnav--collapsed .thelis-secnav__toggle-arrow {
transform: rotate(180deg);
} .thelis-secnav--on-dark .thelis-secnav__toggle {
background: rgba(248, 246, 243, 0.97);
border-color: rgba(17, 17, 24, 0.10);
color: rgba(17, 17, 24, 0.55) !important;
}
.thelis-secnav--on-dark .thelis-secnav__toggle:hover {
color: #E8294A !important;
} @media (max-width: 1023px) {
.thelis-secnav { display: none !important; }
} .thelis-secstrip {
display: none; position: fixed;
bottom: 0;
left: 0;
right: 0;
z-index: 900;
background: rgba(7, 7, 11, 0.97);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-top: 2px solid #E8294A; padding-bottom: env(safe-area-inset-bottom, 0px);
opacity: 0;
transform: translateY(100%);
transition:
opacity   0.5s cubic-bezier(0.22, 1, 0.36, 1),
transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
will-change: transform, opacity;
}
.thelis-secstrip.is-visible {
opacity: 1;
transform: translateY(0);
} .thelis-secstrip__inner {
display: flex;
flex-direction: row;
align-items: center;
height: 64px;
overflow-x: auto;
scroll-behavior: smooth;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
padding: 0 12px;
gap: 0;
}
.thelis-secstrip__inner::-webkit-scrollbar { display: none; } .thelis-secstrip::before,
.thelis-secstrip::after {
content: '';
position: absolute;
top: 0;
bottom: 0;
width: 28px;
z-index: 1;
pointer-events: none;
}
.thelis-secstrip::before {
left: 0;
background: linear-gradient(to right, rgba(7, 7, 11, 0.90), transparent);
}
.thelis-secstrip::after {
right: 0;
background: linear-gradient(to left, rgba(7, 7, 11, 0.90), transparent);
} .thelis-secstrip__item {
flex-shrink: 0;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 5px;
padding: 8px 10px;
min-width: 52px;
background: transparent;
border: none;
border-radius: 3px;
cursor: pointer;
-webkit-tap-highlight-color: transparent;
user-select: none;
position: relative;
transition: background 0.25s ease;
}
.thelis-secstrip__item:active {
background: rgba(255, 255, 255, 0.04);
} .thelis-secstrip__item::after {
content: '';
position: absolute;
bottom: 4px;
left: 50%;
transform: translateX(-50%) scaleX(0);
width: 20px;
height: 2px;
background: #E8294A;
border-radius: 1px;
transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.thelis-secstrip__item.is-active::after {
transform: translateX(-50%) scaleX(1);
} .thelis-secstrip__num {
font-family: 'JetBrains Mono', monospace;
font-size: 9px;
font-weight: 500;
letter-spacing: 1.5px;
color: rgba(255, 255, 255, 0.22) !important;
line-height: 1;
transition: color 0.25s ease;
}
.thelis-secstrip__item.is-active .thelis-secstrip__num {
color: #E8294A !important;
} .thelis-secstrip__label {
font-family: 'Syne', sans-serif;
font-size: 11px;
font-weight: 600;
letter-spacing: 0;
color: rgba(255, 255, 255, 0.32) !important;
white-space: nowrap;
line-height: 1;
max-width: 80px;
overflow: hidden;
text-overflow: ellipsis;
transition: color 0.25s ease, max-width 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.thelis-secstrip__item.is-active .thelis-secstrip__label {
color: rgba(255, 255, 255, 0.90) !important;
max-width: 120px;
font-size: 12px;
} .thelis-secstrip__conn {
flex-shrink: 0;
width: 10px;
height: 1px;
background: rgba(255, 255, 255, 0.07);
display: block;
margin: 0 1px;
position: relative;
top: -4px; } @media (min-width: 1024px) {
.thelis-secstrip { display: none !important; }
}
@media (max-width: 1023px) {
.thelis-secstrip { display: block; }
}.hero-section[data-type=type-1]{text-align:var(--alignment);margin-bottom:var(--margin-bottom, 40px)}.hero-section[data-type=type-1] .page-description{display:inline-block;max-width:var(--description-max-width, 100%)}.hero-section[data-type=type-2]{position:relative;padding-top:calc(var(--has-transparent-header)*var(--header-height))}.hero-section[data-type=type-2]>[class*=ct-container]{display:flex;flex-direction:column;justify-content:var(--vertical-alignment, center);text-align:var(--alignment, center);position:relative;z-index:2;padding:var(--container-padding, 50px 0);min-height:var(--min-height, 250px)}.hero-section[data-type=type-2]>figure{position:absolute;overflow:hidden;z-index:1;inset:0;background-color:inherit}.hero-section[data-type=type-2]>figure .ct-media-container{height:100%;vertical-align:top}.hero-section[data-type=type-2]>figure .ct-media-container img{height:100%}.hero-section[data-type=type-2] .ct-title-label{display:block;font-size:12px;text-transform:uppercase;margin-bottom:.5em}.entry-header>*:not(:first-child){margin-top:var(--itemSpacing, 20px)}.entry-header .page-title{margin-bottom:0}.entry-header .page-description{color:var(--theme-text-color)}.entry-header .page-description>*:last-child{margin-bottom:0}.wpcf7 p:after{content:"";clear:both;display:table}.wpcf7 p:last-of-type{--theme-content-spacing: 0}.wpcf7 label:not(.wpcf7-form-control-wrap){display:block;font-size:15px;font-weight:600}.wpcf7 .wpcf7-submit{float:left}.wpcf7 .wpcf7-submit+.ajax-loader{float:left;margin-left:20px}.wpcf7 .wpcf7-not-valid-tip{font-size:.9em;font-style:italic;margin-top:5px}.wpcf7 .wpcf7-response-output{margin-left:0;margin-right:0;margin-bottom:0;font-style:italic}.wpcf7 .wpcf7-list-item:first-child{margin-left:0}