@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; }
}@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400;1,600&family=Syne:wght@300;400;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap"); .thelis-project { --thelis-ff-display: 'Syne', sans-serif;
--thelis-ff-mono:    'JetBrains Mono', monospace;
--thelis-ff-title:   'Cormorant Garamond', Georgia, serif; --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-gray:       rgba(17, 17, 24, 0.50);
--thelis-border:     rgba(17, 17, 24, 0.08); --thelis-spring:     cubic-bezier(0.34, 1.56, 0.64, 1);
--thelis-ease-out:   cubic-bezier(0.22, 1, 0.36, 1);
overflow-x: hidden;
max-width: none !important;
padding: 0 !important;
margin-top: 0 !important;
font-family: var(--thelis-ff-display);
} #primary.thelis-project .pj-hero,
#primary.thelis-project .pj-depth,
#primary.thelis-project .pj-cta,
#primary .pj-hero,
#primary .pj-depth,
#primary .pj-cta {
background: #111118 !important;
} #primary.thelis-project .pj-problem,
#primary.thelis-project .pj-outcome,
#primary .pj-problem,
#primary .pj-outcome {
background: #ffffff !important;
}
#primary.thelis-project .pj-solution,
#primary .pj-solution {
background: #f7f5f1 !important;
} @keyframes pjBlurUp {
from { opacity: 0; transform: translateY(48px); filter: blur(14px); }
to   { opacity: 1; transform: translateY(0);    filter: blur(0);    }
}
@keyframes pjLineGrow {
from { transform: scaleX(0); }
to   { transform: scaleX(1); }
}
@keyframes pjDotDrift {
0%, 100% { background-position: 0 0;    }
50%       { background-position: 10px -8px; }
}
@keyframes pjPulseGlow {
0%, 100% { opacity: 0.45; transform: translate(-50%, -50%) scale(1);    }
50%       { opacity: 1;   transform: translate(-50%, -50%) scale(1.18); }
}
@keyframes pjShimmer {
from { left: -100%; }
to   { left:  200%; }
} #pj-progress {
position: fixed;
top: 0; left: 0;
width: 0%;
height: 3px;
background: var(--thelis-red);
z-index: 99999;
transition: width 0.08s linear;
pointer-events: none;
}  .pj-label {
display: inline-flex;
align-items: center;
gap: 14px;
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 500;
letter-spacing: 4px;
text-transform: uppercase;
color: var(--thelis-red);
}
.pj-label::before {
content: '';
width: 36px;
height: 1px;
background: var(--thelis-red);
opacity: 0.6;
flex-shrink: 0;
}
.pj-label--dim          { color: #E8294A; } .pj-label--dim::before  { opacity: 0.60; } .pj-section-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 48px;
}
.pj-section-num {
font-family: var(--thelis-ff-title);
font-size: 80px;
font-weight: 600;
line-height: 1;
user-select: none;
color: var(--thelis-black);
opacity: 0.04;
transition: opacity 0.5s ease;
}
.pj-section-num--light { color: var(--thelis-white); opacity: 0.06; } .pj-section-title {
font-family: var(--thelis-ff-display) !important;
font-size: clamp(28px, 4vw, 52px);
font-weight: 700;
letter-spacing: -2px;
line-height: 1.08;
color: var(--thelis-black) !important;
margin: 0 0 40px;
}
.pj-section-title--light { color: #ffffff !important; color: var(--thelis-white) !important; } .pj-badges {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-bottom: 32px;
}
.pj-badge {
display: inline-flex;
align-items: center;
font-family: var(--thelis-ff-mono);
font-size: 10px;
font-weight: 500;
letter-spacing: 3px;
text-transform: uppercase;
padding: 6px 14px;
border-radius: 2px;
border: 1px solid rgba(232, 41, 74, 0.65);
color: rgba(255, 255, 255, 0.85) !important; background: rgba(232, 41, 74, 0.10);
} .pj-stack {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.pj-stack span,
.pj-hero-stack span {
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 500;
letter-spacing: 2px;
text-transform: uppercase;
padding: 5px 12px;
border-radius: 2px;
border: 1px solid var(--thelis-border);
color: var(--thelis-gray);
background: var(--thelis-white);
transition: border-color 0.2s, color 0.2s;
}
.pj-stack span:hover {
border-color: rgba(232, 41, 74, 0.40);
color: var(--thelis-red);
} .pj-callout {
border-left: 3px solid var(--thelis-red);
background: rgba(232, 41, 74, 0.04);
border-radius: 2px;
padding: 36px 52px;
margin: 0;
font-family: var(--thelis-ff-title);
font-style: italic;
font-size: clamp(20px, 2.5vw, 28px);
font-weight: 600;
color: var(--thelis-black);
line-height: 1.45;
} .pj-hero {
background: #111118;
background: var(--thelis-black);
position: relative;
padding: 148px 0 108px;
overflow: hidden;
}  .thelis-project .pj-hero,
.thelis-project .pj-hero * {
color: inherit;
}
.pj-hero::before {
content: '';
position: absolute;
inset: -5%;
background-image: radial-gradient(circle, rgba(232, 41, 74, 0.07) 1.2px, transparent 1.2px);
background-size: 32px 32px;
pointer-events: none;
z-index: 0;
animation: pjDotDrift 22s ease-in-out infinite;
} .pj-hero::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 1px;
background: linear-gradient(90deg, transparent 0%, var(--thelis-red) 40%, transparent 100%);
opacity: 0.35;
z-index: 1;
}
.pj-hero .container { position: relative; z-index: 2; } .pj-breadcrumb {
display: flex;
align-items: center;
gap: 10px;
font-family: var(--thelis-ff-mono);
font-size: 11px;
letter-spacing: 3px;
text-transform: uppercase;
margin-bottom: 72px;
animation: pjBlurUp 0.7s var(--thelis-ease-out) 0.05s both;
}
.pj-breadcrumb a {
color: rgba(255, 255, 255, 0.65) !important; text-decoration: none !important;
transition: color 0.2s;
}
.pj-breadcrumb a:hover { color: rgba(255, 255, 255, 0.88) !important; }
.pj-breadcrumb__sep    { color: rgba(255, 255, 255, 0.32) !important; }
.pj-breadcrumb__current { color: var(--thelis-red) !important; }
.pj-hero__content { max-width: 880px; } .pj-badges { animation: pjBlurUp 0.8s var(--thelis-ease-out) 0.12s both; } .pj-hero__title {
font-family: 'Syne', sans-serif !important;
font-family: var(--thelis-ff-display) !important;
font-size: clamp(72px, 11vw, 152px);
font-weight: 700;
font-style: normal;
letter-spacing: -3px;
line-height: 1.0;
color: #ffffff !important;
color: var(--thelis-white) !important;
margin: 0 0 28px;
animation: pjBlurUp 1.3s var(--thelis-ease-out) 0.22s both;
}
.pj-hero__subtitle {
font-family: var(--thelis-ff-display);
font-size: clamp(16px, 2vw, 22px);
font-weight: 300;
color: rgba(255, 255, 255, 0.78) !important; margin: 0 0 20px;
letter-spacing: 0.3px;
animation: pjBlurUp 0.9s var(--thelis-ease-out) 0.42s both;
}
.pj-hero__desc {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: rgba(255, 255, 255, 0.72) !important; max-width: 520px;
line-height: 1.75;
margin: 0;
animation: pjBlurUp 0.9s var(--thelis-ease-out) 0.56s both;
} .pj-hero__footer {
margin-top: 80px;
padding-top: 40px;
border-top: 1px solid rgba(255, 255, 255, 0.07);
display: flex;
flex-direction: column;
gap: 24px;
animation: pjBlurUp 0.9s var(--thelis-ease-out) 0.70s both;
}
.pj-hero__meta-row {
display: flex;
align-items: center;
gap: 24px;
}
.pj-meta-label {
font-family: var(--thelis-ff-mono);
font-size: 11px;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.58) !important; white-space: nowrap;
flex-shrink: 0;
width: 90px;
} .pj-sector-pills {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.pj-sector-pills span {
font-family: var(--thelis-ff-mono);
font-size: 11px;
letter-spacing: 2px;
text-transform: uppercase;
padding: 5px 12px;
border-radius: 2px;
border: 1px solid rgba(255, 255, 255, 0.22);
color: rgba(255, 255, 255, 0.68) !important; transition: border-color 0.2s, color 0.2s;
}
.pj-sector-pills span:hover {
border-color: rgba(232, 41, 74, 0.50);
color: var(--thelis-red);
} .pj-hero-stack {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.pj-hero-stack span {
border: 1px solid rgba(255, 255, 255, 0.20);
color: rgba(255, 255, 255, 0.60) !important; background: transparent;
}
.pj-hero-stack span:hover {
border-color: rgba(232, 41, 74, 0.40);
color: rgba(232, 41, 74, 0.85);
} .pj-problem {
background: #ffffff;
background: var(--thelis-white);
padding: 120px 0;
position: relative;
} .pj-problem::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
transform: scaleX(0);
transform-origin: left center;
transition: transform 1s var(--thelis-ease-out);
}
.pj-problem.pj-line-revealed::after { transform: scaleX(1); } .pj-problem__grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 80px;
align-items: start;
margin-bottom: 64px;
}
.pj-problem__left .pj-section-title { margin-bottom: 0; }
.pj-problem__right p {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.85;
margin: 0 0 24px;
}
.pj-problem__right p:last-child { margin-bottom: 0; } .pj-solution {
background: #f7f5f1;
background: var(--thelis-light);
padding: 120px 0;
position: relative;
}
.pj-solution::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
transform: scaleX(0);
transform-origin: left center;
transition: transform 1s var(--thelis-ease-out);
}
.pj-solution.pj-line-revealed::after { transform: scaleX(1); } .pj-solution__intro {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 80px;
align-items: start;
margin-bottom: 72px;
}
.pj-solution__intro .pj-section-title { margin-bottom: 0; }
.pj-solution__desc {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.85;
margin: 0;
align-self: center;
} .pj-features {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 20px;
margin-bottom: 64px;
}
.pj-feature-card {
background: #ffffff;
background: var(--thelis-white);
border-radius: 4px;
border-top: 2px solid transparent;
padding: 40px;
position: relative;
overflow: hidden;
transition:
transform 0.45s var(--thelis-spring),
box-shadow 0.25s ease,
border-top-color 0.25s ease;
} .pj-feature-card::after {
content: '';
position: absolute;
top: 0;
left: -120%;
width: 80%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(232, 41, 74, 0.04), transparent);
transition: left 0.55s ease;
pointer-events: none;
}
.pj-feature-card:hover::after  { left: 140%; }
.pj-feature-card:hover          { transform: translateY(-6px); border-top-color: var(--thelis-red); box-shadow: 0 16px 56px rgba(17, 17, 24, 0.09); }
.pj-feature-card__icon {
color: var(--thelis-red);
margin-bottom: 24px;
transition: transform 0.4s var(--thelis-spring);
}
.pj-feature-card:hover .pj-feature-card__icon { transform: scale(1.15) rotate(-4deg); }
.pj-feature-card h3 {
font-family: 'Syne', sans-serif !important;
font-family: var(--thelis-ff-display) !important;
font-size: 18px;
font-weight: 700;
letter-spacing: -0.5px;
color: #111118 !important;
color: var(--thelis-black) !important;
margin: 0 0 14px;
}
.pj-feature-card p {
font-family: var(--thelis-ff-display);
font-size: 15px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.75;
margin: 0;
} .pj-stack-row {
display: flex;
align-items: center;
gap: 24px;
padding-top: 40px;
border-top: 1px solid var(--thelis-border);
flex-wrap: wrap;
} .pj-outcome {
background: #ffffff;
background: var(--thelis-white);
padding: 120px 0;
position: relative;
}
.pj-outcome::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
transform: scaleX(0);
transform-origin: left center;
transition: transform 1s var(--thelis-ease-out);
}
.pj-outcome.pj-line-revealed::after { transform: scaleX(1); } .pj-metrics {
display: grid;
grid-template-columns: repeat(4, 1fr);
border: 1px solid var(--thelis-border);
border-radius: 4px;
overflow: hidden;
margin-bottom: 72px;
}
.pj-metric {
padding: 52px 40px;
border-right: 1px solid var(--thelis-border);
display: flex;
flex-direction: column;
gap: 14px;
position: relative;
overflow: hidden;
transition: background 0.3s ease;
}
.pj-metric:last-child { border-right: none; } .pj-metric::before {
content: '';
position: absolute;
top: 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);
}
.pj-metric:hover::before { transform: scaleX(1); }
.pj-metric:hover          { background: rgba(232, 41, 74, 0.025); } .pj-metric__value {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: clamp(48px, 6vw, 84px);
font-weight: 700;
color: var(--thelis-red);
line-height: 1;
letter-spacing: -3px;
display: block;
}
.pj-metric__unit {
font-size: 0.55em;
vertical-align: top;
margin-top: 10px;
display: inline-block;
letter-spacing: 0;
}
.pj-metric__label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 500;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-gray);
} .pj-metrics--five {
grid-template-columns: repeat(5, 1fr);
} .pj-metrics--six {
grid-template-columns: repeat(3, 1fr);
}
.pj-metrics--six .pj-metric:nth-child(3) { border-right: none; }
.pj-metrics--six .pj-metric:nth-child(4),
.pj-metrics--six .pj-metric:nth-child(5),
.pj-metrics--six .pj-metric:nth-child(6) {
border-top: 1px solid var(--thelis-border);
}
.pj-metrics--six .pj-metric:nth-child(6) { border-right: none; } .pj-metric__value--text {
font-size: clamp(28px, 3.5vw, 52px);
letter-spacing: -1px;
} .pj-outcome__body {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 80px;
}
.pj-outcome__body p {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.85;
margin: 0;
} .pj-depth {
background: #111118;
background: var(--thelis-black);
padding: 120px 0;
position: relative;
overflow: hidden;
} .pj-depth::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;
pointer-events: none;
z-index: 0;
} .pj-depth::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red), transparent);
z-index: 1;
}
.pj-depth .container { position: relative; z-index: 2; }
.pj-depth .pj-section-title { margin-bottom: 64px; } .pj-challenges { display: flex; flex-direction: column; }
.pj-challenge {
display: grid;
grid-template-columns: 72px 1fr;
gap: 48px;
padding: 48px 0;
border-top: 1px solid rgba(255, 255, 255, 0.06);
align-items: start;
position: relative;
transition: padding-left 0.4s var(--thelis-ease-out);
} .pj-challenge::before {
content: '';
position: absolute;
left: 0; top: 0; bottom: 0;
width: 2px;
background: var(--thelis-red);
transform: scaleY(0);
transform-origin: top center;
transition: transform 0.5s var(--thelis-ease-out);
border-radius: 2px;
}
.pj-challenge:hover { padding-left: 20px; }
.pj-challenge:hover::before { transform: scaleY(1); }
.pj-challenge__num {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 11px;
font-weight: 700;
letter-spacing: 3px;
color: var(--thelis-red);
opacity: 1.0; padding-top: 4px;
position: relative;
z-index: 1;
transition: opacity 0.3s;
}
.pj-challenge:hover .pj-challenge__num { opacity: 1; }
.pj-challenge__content { position: relative; z-index: 1; }
.pj-challenge__content h3 {
font-family: 'Syne', sans-serif !important;
font-family: var(--thelis-ff-display) !important;
font-size: 20px;
font-weight: 700;
letter-spacing: -0.5px;
color: #ffffff !important;
color: var(--thelis-white) !important;
margin: 0 0 16px;
transition: color 0.3s;
}
.pj-challenge:hover .pj-challenge__content h3 { color: rgba(255, 255, 255, 0.95) !important; }
.pj-challenge__content p {
font-family: var(--thelis-ff-display);
font-size: 15px;
font-weight: 300;
color: rgba(255, 255, 255, 0.68) !important; line-height: 1.85;
margin: 0;
max-width: 700px;
transition: color 0.3s;
}
.pj-challenge:hover .pj-challenge__content p { color: rgba(255, 255, 255, 0.88) !important; }
.pj-challenge:last-child { border-bottom: 1px solid rgba(255, 255, 255, 0.06); } .pj-cta {
background: #111118 !important;
background: var(--thelis-black) !important;
padding: 80px 0;
position: relative;
border-top: 1px solid rgba(255, 255, 255, 0.06);
overflow: hidden;
} .pj-cta::before {
content: '';
position: absolute;
left: 50%; top: 50%;
transform: translate(-50%, -50%);
width: 700px; height: 350px;
background: radial-gradient(ellipse, rgba(232, 41, 74, 0.11) 0%, transparent 68%);
pointer-events: none;
animation: pjPulseGlow 4.5s ease-in-out infinite;
}
.pj-cta .container {
position: relative;
z-index: 1;
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 28px;
}
.pj-cta__title {
font-family: 'Syne', sans-serif !important;
font-family: var(--thelis-ff-display, 'Syne', sans-serif) !important;
font-size: clamp(28px, 3.5vw, 48px);
font-weight: 700;
color: #ffffff !important;
color: var(--thelis-white) !important;
margin: 0;
letter-spacing: -1.5px;
line-height: 1.08;
max-width: 580px;
text-align: center !important;
} .pj-cta__title em {
font-style: normal;
font-weight: 300;
color: rgba(255, 255, 255, 0.80) !important;
} .pj-cta__inner {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
width: 100%;
} .pj-cta__desc {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 16px;
font-weight: 300;
line-height: 1.70;
color: rgba(255, 255, 255, 0.55) !important;
text-align: center !important;
max-width: 560px;
margin: 0;
} .pj-cta__actions {
display: flex;
align-items: center;
justify-content: center;
gap: 16px;
flex-wrap: wrap;
}
.pj-cta__btn {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: 11px;
font-weight: 700;
letter-spacing: 2.5px;
text-transform: uppercase;
text-decoration: none;
color: #ffffff !important; background: var(--thelis-red);
padding: 16px 40px;
border-radius: 2px;
display: inline-block;
position: relative;
overflow: hidden;
transition:
background 0.22s ease,
transform  0.3s var(--thelis-spring),
box-shadow 0.25s ease;
} .pj-cta__btn::after {
content: '';
position: absolute;
top: 0; left: -60%;
width: 40%; height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.18), transparent);
skewX(-15deg);
transition: none;
}
.pj-cta__btn:hover::after {
animation: pjShimmer 0.55s ease forwards;
}
.pj-cta__btn:hover {
background: var(--thelis-red-dark);
color: #ffffff !important; text-decoration: none !important;
transform: translateY(-3px);
box-shadow: 0 10px 36px rgba(232, 41, 74, 0.38);
} .pj-feature-card--visual {
padding-top: 0;
} .pj-feature-card__visual {
margin: 0 -40px 36px;
padding: 40px 28px 32px;
display: flex;
align-items: center;
justify-content: center;
min-height: 230px;
overflow: hidden;
position: relative;
background: radial-gradient(ellipse at 60% 40%, #ede9e2 0%, #e8e4dc 100%);
}
.pj-feature-card__visual img {
max-width: 210px;
max-height: 210px;
width: auto;
height: auto;
object-fit: contain;
filter: drop-shadow(0 16px 40px rgba(17, 17, 24, 0.13));
transform: rotate(-4deg) scale(1.0);
transform-origin: center bottom;
transition:
transform 0.60s cubic-bezier(0.22, 1, 0.36, 1),
filter     0.40s ease;
will-change: transform;
} .pj-feature-card--visual:nth-child(2) .pj-feature-card__visual img {
transform: rotate(0deg) scale(0.92);
max-width: 170px;
}
.pj-feature-card--visual:hover .pj-feature-card__visual img {
transform: rotate(-1deg) translateY(-10px) scale(1.06) !important;
filter: drop-shadow(0 24px 52px rgba(17, 17, 24, 0.17));
} .pj-outcome__visual {
margin: 72px 0 68px;
display: flex;
align-items: center;
gap: 0;
position: relative;
}
.pj-outcome__visual::before,
.pj-outcome__visual::after {
content: '';
flex: 1;
height: 1px;
background: var(--thelis-border);
}
.pj-outcome__visual::before { margin-right: 72px; }
.pj-outcome__visual::after  { margin-left:  72px; }
.pj-outcome__fig {
flex-shrink: 0;
display: flex;
flex-direction: column;
align-items: center;
gap: 18px;
}
.pj-outcome__fig img {
width: auto;
height: auto;
max-width: 210px;
max-height: 300px;
object-fit: contain;
filter: drop-shadow(0 20px 52px rgba(17, 17, 24, 0.12));
transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1), filter 0.4s ease;
will-change: transform;
}
.pj-outcome__visual:hover .pj-outcome__fig img {
transform: translateY(-10px) scale(1.04);
filter: drop-shadow(0 28px 64px rgba(17, 17, 24, 0.17));
}
.pj-outcome__fig figcaption {
font-family: 'JetBrains Mono', monospace;
font-size: 9.5px;
font-weight: 500;
letter-spacing: 2.5px;
text-transform: uppercase;
color: rgba(17, 17, 24, 0.28) !important;
text-align: center;
line-height: 1;
} @media (max-width: 1024px) {
.pj-hero { padding: 100px 0 72px; }
.pj-problem,
.pj-solution,
.pj-outcome,
.pj-depth { padding: 80px 0; }
.pj-problem__grid,
.pj-solution__intro,
.pj-outcome__body {
grid-template-columns: 1fr;
gap: 40px;
}
.pj-problem__left .pj-section-title,
.pj-solution__intro .pj-section-title { margin-bottom: 0; }
.pj-features { grid-template-columns: 1fr; } .pj-feature-card__visual { margin: 0 -40px 28px; min-height: 190px; }
.pj-feature-card__visual img { max-width: 170px; max-height: 170px; }
.pj-outcome__visual { margin: 52px 0 48px; }
.pj-outcome__visual::before,
.pj-outcome__visual::after { display: none; }
.pj-metrics                            { grid-template-columns: repeat(2, 1fr); }
.pj-metric:nth-child(2)                { border-right: none; }
.pj-metric:nth-child(3),
.pj-metric:nth-child(4)                { border-top: 1px solid var(--thelis-border); }
.pj-metric:nth-child(4)                { border-right: none; } .pj-metrics--five                          { grid-template-columns: repeat(3, 1fr); }
.pj-metrics--five .pj-metric:nth-child(3)  { border-right: none; }
.pj-metrics--five .pj-metric:nth-child(4),
.pj-metrics--five .pj-metric:nth-child(5)  { border-top: 1px solid var(--thelis-border); }
.pj-metrics--five .pj-metric:nth-child(2)  { border-right: 1px solid var(--thelis-border); }
.pj-metrics--five .pj-metric:nth-child(5)  { border-right: none; } .pj-callout { padding: 28px 32px; }
.pj-section-num { font-size: 60px; }
} @media (max-width: 768px) {
.pj-hero__title  { letter-spacing: -2px; }
.pj-hero__footer { margin-top: 48px; }
.pj-hero__meta-row {
flex-direction: column;
align-items: flex-start;
gap: 12px;
}
.pj-meta-label   { width: auto; }
.pj-breadcrumb   { margin-bottom: 48px; }
.pj-challenge {
grid-template-columns: 48px 1fr;
gap: 20px;
padding: 36px 0;
}
.pj-challenge:hover { padding-left: 12px; }
.pj-callout {
font-size: 18px;
padding: 24px 28px;
}
.pj-section-header { margin-bottom: 32px; }
.pj-cta { padding: 60px 0; }
} @media (max-width: 768px) {
.pj-hero--scene .pj-hero__scene-bg {
width: 100%;
opacity: 0.22;
}
.pj-hero--scene .pj-hero__scene-bg::before {
background: linear-gradient(to right, #111118 0%, rgba(17,17,24,0.96) 100%);
width: 100%;
}
.pj-hero--scene .pj-hero__left {
max-width: 100%;
}
} @media (max-width: 480px) {
.pj-metrics,
.pj-metrics--five,
.pj-metrics--six    { grid-template-columns: 1fr 1fr; }
.pj-metric          { padding: 36px 24px; } .pj-feature-card__visual { margin: 0 -28px 24px; min-height: 160px; }
.pj-feature-card__visual img { max-width: 140px; max-height: 140px; }
.pj-outcome__fig img { max-width: 160px; max-height: 220px; }
.pj-outcome__visual { margin: 40px 0 36px; }
.pj-feature-card    { padding: 28px; }
.pj-stack-row       { flex-direction: column; align-items: flex-start; }
} @keyframes pjSceneReveal {
from {
opacity: 0;
transform: scale(1.05);
filter: blur(6px);
}
to {
opacity: 1;
transform: scale(1);
filter: blur(0);
}
} .pj-hero--scene .pj-hero__scene-bg {
position: absolute;
top: 0;
right: 0;
bottom: 0;
width: 58%;
overflow: hidden;
z-index: 0;
} .pj-hero--scene .pj-hero__scene-bg img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: left top;
filter: brightness(0.82) saturate(0.88);
animation: pjSceneReveal 1.8s cubic-bezier(0.22, 1, 0.36, 1) 0.3s both;
} .pj-hero--scene .pj-hero__scene-bg::before {
content: '';
position: absolute;
top: 0; bottom: 0; left: 0;
width: 52%;
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.92) 40%,
rgba(17, 17, 24, 0.50) 72%,
transparent 100%
);
z-index: 1;
pointer-events: none;
} .pj-hero--scene .pj-hero__scene-bg::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 38%;
background: linear-gradient(to bottom, transparent 0%, #111118 100%);
z-index: 1;
pointer-events: none;
} .pj-hero--scene .pj-hero__scene-bg .pj-hero__scene-accent {
position: absolute;
top: 15%; bottom: 15%;
left: 0;
width: 1px;
background: linear-gradient(
to bottom,
transparent 0%,
rgba(232, 41, 74, 0.45) 35%,
rgba(232, 41, 74, 0.45) 65%,
transparent 100%
);
z-index: 2;
pointer-events: none;
} .pj-hero--scene .container {
position: relative;
z-index: 2;
} .pj-hero--scene .pj-hero__left {
max-width: 560px;
} @media (max-width: 1024px) {
.pj-hero--scene .pj-hero__scene-bg {
width: 100%;
}
.pj-hero--scene .pj-hero__scene-bg img {
opacity: 0.55;
filter: brightness(0.60) saturate(0.75);
}
.pj-hero--scene .pj-hero__scene-bg::before {
width: 100%;
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.97) 60%,
rgba(17, 17, 24, 0.85) 100%
);
}
.pj-hero--scene .pj-hero__left {
max-width: 680px;
}
} @keyframes pjRevealFrame {
from {
opacity: 0;
transform: translateY(48px) perspective(1000px) rotateX(5deg);
filter: blur(10px);
}
to {
opacity: 1;
transform: translateY(0) perspective(1000px) rotateX(0deg);
filter: blur(0);
}
}
@keyframes pjFloatIdle {
0%, 100% { transform: translateY(0px); }
50%       { transform: translateY(-7px); }
} .pj-hero--visual .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 72px;
align-items: center;
} .pj-hero--visual .pj-hero__left { } .pj-hero--visual .pj-hero__visual {
position: relative;
animation: pjRevealFrame 1.1s cubic-bezier(0.22, 1, 0.36, 1) 0.65s both;
} .pj-hero--visual .pj-hero__visual::before {
content: '';
position: absolute;
top: 0; bottom: 0;
left: -48px;
width: 120px;
background: linear-gradient(to right, #111118 0%, transparent 100%);
z-index: 3;
pointer-events: none;
} .pj-hero--visual .pj-hero__visual-inner {
animation: pjFloatIdle 7s ease-in-out 1.8s infinite;
} .pj-hero--visual .pj-hero__img-frame {
position: relative;
background: #0c0c14;
border-radius: 8px 8px 4px 4px;
border-top: 2px solid var(--thelis-red);
overflow: hidden;
box-shadow:
0 32px 96px rgba(0, 0, 0, 0.70),
0 0 0 1px rgba(255, 255, 255, 0.04),
0 0 48px rgba(232, 41, 74, 0.10);
transform: perspective(1400px) rotateX(1.5deg);
transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1),
box-shadow 0.8s ease;
}
.pj-hero--visual .pj-hero__img-frame:hover {
transform: perspective(1400px) rotateX(0deg);
box-shadow:
0 48px 120px rgba(0, 0, 0, 0.75),
0 0 0 1px rgba(255, 255, 255, 0.06),
0 0 64px rgba(232, 41, 74, 0.14);
} .pj-hero--visual .pj-hero__img-chrome {
display: flex;
align-items: center;
gap: 10px;
padding: 11px 16px;
background: rgba(255, 255, 255, 0.025);
border-bottom: 1px solid rgba(255, 255, 255, 0.055);
flex-shrink: 0;
} .pj-hero--visual .pj-hero__chrome-dots {
display: flex;
gap: 6px;
flex-shrink: 0;
}
.pj-hero--visual .pj-hero__chrome-dots i {
display: block;
width: 9px;
height: 9px;
border-radius: 50%;
font-style: normal;
}
.pj-hero--visual .pj-hero__chrome-dots i:nth-child(1) { background: rgba(232, 41, 74, 0.75); }
.pj-hero--visual .pj-hero__chrome-dots i:nth-child(2) { background: rgba(255, 195, 50, 0.45); }
.pj-hero--visual .pj-hero__chrome-dots i:nth-child(3) { background: rgba(85, 210, 100, 0.40); } .pj-hero--visual .pj-hero__chrome-label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 2.5px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.28) !important;
flex: 1;
text-align: center;
} .pj-hero--visual .pj-hero__img-wrap {
position: relative;
max-height: 560px;
overflow: hidden;
} .pj-hero--visual .pj-hero__img-wrap::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 120px;
background: linear-gradient(to bottom, transparent 0%, #0c0c14 100%);
z-index: 1;
pointer-events: none;
} .pj-hero--visual .pj-hero__img-wrap img {
display: block;
width: 100%;
height: auto;
object-fit: cover;
object-position: top center;
transition: transform 10s ease-out;
}
.pj-hero--visual .pj-hero__img-frame:hover .pj-hero__img-wrap img {
transform: translateY(-4%);
} .pj-hero--visual {
padding: 120px 0 96px;
} @media (max-width: 1024px) {
.pj-hero--visual .pj-hero__layout {
grid-template-columns: 1fr;
gap: 52px;
} .pj-hero--visual .pj-hero__visual {
order: -1;
} .pj-hero--visual .pj-hero__visual::before {
display: none;
}
.pj-hero--visual .pj-hero__img-wrap {
max-height: 360px;
}
.pj-hero--visual {
padding: 100px 0 80px;
}
} @media (max-width: 768px) {
.pj-hero--visual .pj-hero__img-wrap {
max-height: 260px;
}
.pj-hero--visual .pj-hero__img-frame {
transform: none;
}
.pj-hero--visual .pj-hero__visual-inner {
animation: none;
}
.pj-hero--visual {
padding: 88px 0 72px;
}
}  @keyframes pjDiagonalReveal {
from { clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%); }
to   { clip-path: polygon(22% 0%, 100% 0%, 100% 100%, 0% 100%); }
} .pj-hero--diagonal .pj-hero__scene-bg {
position: absolute;
top: 0; right: 0; bottom: 0;
width: 66%;
clip-path: polygon(22% 0%, 100% 0%, 100% 100%, 0% 100%);
animation: pjDiagonalReveal 1.5s cubic-bezier(0.22, 1, 0.36, 1) 0.45s both;
z-index: 0;
} .pj-hero--diagonal .pj-hero__scene-bg img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: 38% center;
filter: brightness(0.62) contrast(1.12) saturate(0.68);
} .pj-hero--diagonal .pj-hero__scene-bg::before {
content: '';
position: absolute;
top: 0; bottom: 0; left: 0;
width: 55%;
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.88) 28%,
rgba(17, 17, 24, 0.40) 65%,
transparent 100%
);
z-index: 1;
pointer-events: none;
} .pj-hero--diagonal .pj-hero__scene-bg::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 36%;
background: linear-gradient(to bottom, transparent 0%, #111118 100%);
z-index: 1;
pointer-events: none;
} .pj-hero--diagonal .container {
position: relative;
z-index: 2;
} .pj-hero--diagonal .pj-hero__left {
max-width: 520px;
} @media (max-width: 1024px) {
.pj-hero--diagonal .pj-hero__scene-bg {
width: 100%;
clip-path: none;
animation: none;
}
.pj-hero--diagonal .pj-hero__scene-bg img {
filter: brightness(0.40) contrast(1.1) saturate(0.55);
}
.pj-hero--diagonal .pj-hero__scene-bg::before {
width: 100%;
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.97) 55%,
rgba(17, 17, 24, 0.80) 100%
);
}
.pj-hero--diagonal .pj-hero__left {
max-width: 680px;
}
} @media (max-width: 768px) {
.pj-hero--diagonal .pj-hero__scene-bg img {
filter: brightness(0.28) contrast(1.1) saturate(0.50);
}
}  .pj-hero--data .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 72px;
align-items: center;
} .pj-hero__data-right {
position: relative;
padding-top: 16px;
animation: pjBlurUp 0.9s var(--thelis-ease-out) 0.55s both;
}  .pj-hero__ghost-num {
position: absolute;
bottom: 72px; right: 8px;
font-family: 'Cormorant Garamond', Georgia, serif;
font-family: var(--thelis-ff-title);
font-size: clamp(130px, 17vw, 210px);
font-weight: 300;
letter-spacing: -10px;
line-height: 1;
color: #ffffff;
opacity: 0.09;
user-select: none;
pointer-events: none;
z-index: 2; } .pj-hero__photo-inset {
position: relative;
z-index: 1;
width: 100%;
height: 360px;
overflow: hidden;
border-top: 2px solid var(--thelis-red);
animation: pjBlurUp 0.8s var(--thelis-ease-out) 0.72s both;
} .pj-hero__photo-inset::after {
content: '';
position: absolute;
inset: 0;
background:
linear-gradient(to bottom, transparent 50%, rgba(17, 17, 24, 0.45) 100%),
linear-gradient(to right,  transparent 60%, rgba(17, 17, 24, 0.30) 100%);
z-index: 1;
pointer-events: none;
} .pj-hero__photo-inset img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center 40%;
filter: brightness(0.60) contrast(1.2) saturate(0.35) grayscale(0.45);
transition: transform 9s ease-out, filter 0.9s ease;
}
.pj-hero__photo-inset:hover img {
transform: scale(1.05);
filter: brightness(0.68) contrast(1.2) saturate(0.50) grayscale(0.25);
} .pj-hero__data-caption {
display: flex;
align-items: center;
gap: 14px;
margin-top: 18px;
position: relative;
z-index: 1;
animation: pjBlurUp 0.7s var(--thelis-ease-out) 0.88s both;
}
.pj-hero__data-line {
display: block;
width: 32px;
height: 1px;
background: var(--thelis-red);
opacity: 0.65;
flex-shrink: 0;
}
.pj-hero__data-text {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.48) !important;
} .pj-hero__org-count {
margin-top: 10px;
padding-left: 46px; font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 2.5px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.28) !important;
position: relative;
z-index: 1;
animation: pjBlurUp 0.7s var(--thelis-ease-out) 1.0s both;
} @media (max-width: 1024px) {
.pj-hero--data .pj-hero__layout {
grid-template-columns: 1fr;
gap: 48px;
} .pj-hero--data .pj-hero__data-right {
order: -1;
}
.pj-hero__ghost-num {
font-size: 110px;
bottom: 60px;
right: 4px;
}
.pj-hero__photo-inset {
height: 260px;
}
} @media (max-width: 768px) {
.pj-hero--data .pj-hero__data-right {
display: none; }
}  @keyframes pjKenBurns {
from { transform: scale(1.06); }
to   { transform: scale(1.0);  }
} .pj-hero--spotlight .pj-hero__scene-bg {
position: absolute;
inset: 0;
overflow: hidden;
z-index: 0;
} .pj-hero--spotlight .pj-hero__scene-bg img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: 62% center;
filter: brightness(0.78) saturate(0.82);
animation: pjKenBurns 2.8s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
} .pj-hero--spotlight .pj-hero__scene-bg::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(
ellipse 80% 100% at 62% 52%,
transparent          0%,
rgba(17, 17, 24, 0.45) 42%,
rgba(17, 17, 24, 0.82) 68%,
#111118              88%
);
z-index: 1;
pointer-events: none;
} .pj-hero--spotlight .pj-hero__scene-bg::after {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to right,
#111118              0%,
rgba(17, 17, 24, 0.88) 28%,
rgba(17, 17, 24, 0.35) 56%,
transparent          78%
);
z-index: 2;
pointer-events: none;
} .pj-hero--spotlight .container {
position: relative;
z-index: 3;
} .pj-hero--spotlight .pj-hero__left {
max-width: 560px;
} @media (max-width: 1024px) {
.pj-hero--spotlight .pj-hero__scene-bg img {
object-position: 55% center;
filter: brightness(0.60) saturate(0.75);
}
.pj-hero--spotlight .pj-hero__scene-bg::after {
background: linear-gradient(
to right,
#111118              0%,
rgba(17, 17, 24, 0.95) 45%,
rgba(17, 17, 24, 0.75) 100%
);
}
.pj-hero--spotlight .pj-hero__left {
max-width: 680px;
}
} @media (max-width: 768px) {
.pj-hero--spotlight .pj-hero__scene-bg img {
object-position: center center;
filter: brightness(0.40) saturate(0.65);
animation: none;
}
.pj-hero--spotlight .pj-hero__scene-bg::before {
background: radial-gradient(
ellipse 100% 100% at 50% 50%,
transparent          0%,
rgba(17, 17, 24, 0.75) 50%,
#111118              80%
);
}
}  @keyframes pjNetParticle {
0%   { stroke-dashoffset:  0;    opacity: 0; }
6%   { opacity: 1; }
94%  { opacity: 1; }
100% { stroke-dashoffset: -100;  opacity: 0; }
} @keyframes pjNetRingPulse {
0%, 100% { transform: scale(1);   opacity: 0.20; }
50%       { transform: scale(1.5); opacity: 0;    }
} .pj-hero--network .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 64px;
align-items: center;
} .pj-hero__network-vis {
position: relative;
animation: pjBlurUp 1.2s var(--thelis-ease-out) 0.65s both;
} .pj-net-svg {
width: 100%;
height: auto;
display: block;
} .pj-net-p {
animation: pjNetParticle 2.6s linear infinite;
} .pj-net-ring {
transform-box: fill-box;
transform-origin: center;
animation: pjNetRingPulse 2.6s ease-in-out infinite;
}
.pj-net-ring--inner {
animation-duration: 2.6s;
}
.pj-net-ring--outer {
animation-duration: 3.4s;
} @media (max-width: 1024px) {
.pj-hero--network .pj-hero__layout {
grid-template-columns: 1fr;
gap: 44px;
}
.pj-hero__network-vis {
order: -1;
max-width: 400px;
margin: 0 auto;
}
} @media (max-width: 768px) {
.pj-hero__network-vis {
display: none;
}
}  @keyframes pjComputeCell {
0%, 100% { fill: rgba(255, 255, 255, 0.038); }
8%        { fill: rgba(232, 41,  74,  0.52);  }
22%       { fill: rgba(232, 41,  74,  0.06);  }
70%       { fill: rgba(255, 255, 255, 0.038); }
} @keyframes pjComputeCellHot {
0%, 100% { fill: rgba(255, 255, 255, 0.055); }
8%        { fill: rgba(232, 41,  74,  0.78);  }
22%       { fill: rgba(232, 41,  74,  0.14);  }
70%       { fill: rgba(255, 255, 255, 0.055); }
} .pj-hero--compute .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 64px;
align-items: center;
} .pj-hero__compute-vis {
animation: pjBlurUp 1.0s var(--thelis-ease-out) 0.65s both;
} .pj-compute-svg {
width: 100%;
height: auto;
display: block;
overflow: visible;
} .pj-cc {
animation: pjComputeCell 5.8s ease-out infinite;
} .pj-cc--hot {
animation-name: pjComputeCellHot;
} .pj-compute-footer {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: 14px;
padding-top: 12px;
border-top: 1px solid rgba(255, 255, 255, 0.055);
}
.pj-compute-label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.40) !important;
}
.pj-compute-spec {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.22) !important;
} @media (max-width: 1024px) {
.pj-hero--compute .pj-hero__layout {
grid-template-columns: 1fr;
gap: 44px;
}
.pj-hero__compute-vis {
order: -1;
max-width: 380px;
margin: 0 auto;
}
} @media (max-width: 768px) {
.pj-hero__compute-vis {
display: none;
}
}   @keyframes pjVerticalReveal {
from { clip-path: inset(0 0 100% 0); }
to   { clip-path: inset(0 0 0%   0); }
} @keyframes pjClinicalCapIn {
from { opacity: 0; transform: translateY(6px); }
to   { opacity: 1; transform: translateY(0);   }
} @keyframes pjCornerIn {
from { opacity: 0; transform: scale(0.3); }
to   { opacity: 1; transform: scale(1);   }
} .pj-hero--clinical .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 64px;
align-items: center;
}
.pj-hero--clinical .pj-hero__photo-right {
position: relative;
display: flex;
align-items: center;
justify-content: flex-end;
} .pj-clinical-frame {
position: relative;
width: 100%;
max-width: 500px;
border: 1px solid rgba(255, 255, 255, 0.07);
border-top: 2px solid var(--thelis-red, #E8294A);
} .pj-corner {
position: absolute;
width: 20px;
height: 20px;
z-index: 3;
animation: pjCornerIn 0.35s cubic-bezier(0.22, 1, 0.36, 1) both;
} .pj-corner::before {
content: '';
position: absolute;
width: 100%;
height: 2px;
background: var(--thelis-red, #E8294A);
} .pj-corner::after {
content: '';
position: absolute;
width: 2px;
height: 100%;
background: var(--thelis-red, #E8294A);
} .pj-corner--tl {
top: -2px;
left: -1px;
animation-delay: 0.70s;
}
.pj-corner--tl::before { top: 0; left: 0; }
.pj-corner--tl::after  { top: 0; left: 0; }
.pj-corner--tr {
top: -2px;
right: -1px;
animation-delay: 0.76s;
}
.pj-corner--tr::before { top: 0; right: 0; left: auto; }
.pj-corner--tr::after  { top: 0; right: 0; left: auto; }
.pj-corner--bl {
bottom: -1px;
left: -1px;
animation-delay: 0.82s;
}
.pj-corner--bl::before { bottom: 0; left: 0; top: auto; }
.pj-corner--bl::after  { bottom: 0; left: 0; top: auto; }
.pj-corner--br {
bottom: -1px;
right: -1px;
animation-delay: 0.88s;
}
.pj-corner--br::before { bottom: 0; right: 0; left: auto; top: auto; }
.pj-corner--br::after  { bottom: 0; right: 0; left: auto; top: auto; } .pj-clinical-img {
overflow: hidden;
display: block;
clip-path: inset(0 0 100% 0);
animation: pjVerticalReveal 1.05s cubic-bezier(0.22, 1, 0.36, 1) 0.32s both;
}
.pj-clinical-img img {
width: 100%;
height: auto;
display: block;
filter: brightness(0.88) contrast(1.06) saturate(0.78);
} .pj-clinical-cap {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px 14px;
background: rgba(255, 255, 255, 0.03);
border-top: 1px solid rgba(255, 255, 255, 0.06);
opacity: 0;
animation: pjClinicalCapIn 0.5s cubic-bezier(0.22, 1, 0.36, 1) 1.45s both;
}
.pj-clinical-cap-label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 2.5px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.42) !important;
}
.pj-clinical-cap-tag {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
color: var(--thelis-red, #E8294A) !important;
padding: 3px 8px;
border: 1px solid rgba(232, 41, 74, 0.28);
} @media (max-width: 1024px) {
.pj-hero--clinical .pj-hero__layout {
grid-template-columns: 1fr;
gap: 44px;
}
.pj-hero--clinical .pj-hero__photo-right {
order: -1;
justify-content: center;
}
.pj-clinical-frame {
max-width: 460px;
}
} @media (max-width: 768px) {
.pj-hero--clinical .pj-hero__photo-right {
display: none;
}
}   @keyframes pjDosePulse {
0%, 100% {
opacity: calc(0.04 + var(--dose, 0) * 0.10);
transform: scale(0.86);
}
50% {
opacity: calc(0.15 + var(--dose, 0) * 0.68);
transform: scale(1);
}
} @keyframes pjDosePulseHot {
0%, 100% {
opacity: calc(0.08 + var(--dose, 0) * 0.14);
transform: scale(0.88);
}
50% {
opacity: calc(0.32 + var(--dose, 0) * 0.68);
transform: scale(1.12);
}
} @keyframes pjDoseRingPulse {
0%   { transform: scale(1);   opacity: 0.72; }
100% { transform: scale(2.6); opacity: 0;    }
} @keyframes pjDoseCenterPulse {
0%, 100% { opacity: 0.75; }
50%      { opacity: 1;    }
} @keyframes pjDoseScan {
0%   { transform: translateY(0%);   opacity: 0;    }
3%   { opacity: 0.55; }
96%  { opacity: 0.22; }
100% { transform: translateY(100%); opacity: 0;    }
} .pj-hero--dosefield .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 64px;
align-items: center;
}
.pj-hero__dose-vis {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
} .pj-dose-svg {
width: 100%;
max-width: 360px;
height: auto;
overflow: visible;
} .pj-dose-ghost {
font-family: 'Syne', sans-serif;
font-size: 76px;
font-weight: 800;
fill: rgba(232, 41, 74, 0.028);
letter-spacing: 10px;
pointer-events: none;
} .pj-dose-axis {
stroke: rgba(255, 255, 255, 0.055);
stroke-width: 1;
stroke-dasharray: 3 5;
} .pj-dc {
fill: var(--thelis-red, #E8294A);
transform-box: fill-box;
transform-origin: center;
animation: pjDosePulse 2.5s ease-in-out infinite;
}
.pj-dc--hot {
animation-name: pjDosePulseHot;
animation-duration: 1.9s;
filter: url(#pj-dose-glow);
} .pj-dose-ring {
fill: none;
stroke: var(--thelis-red, #E8294A);
stroke-width: 1.5;
transform-box: fill-box;
transform-origin: center;
animation: pjDoseRingPulse 2.4s ease-out infinite;
}
.pj-dose-ring--2 {
animation-delay: -1.2s;
filter: none;
} .pj-dose-center {
fill: var(--thelis-red, #E8294A);
animation: pjDoseCenterPulse 1.6s ease-in-out infinite;
} .pj-dose-scan {
fill: var(--thelis-red, #E8294A);
transform-box: view-box;
transform-origin: 0 0;
animation: pjDoseScan 3.2s ease-in-out infinite;
} @keyframes pjBraggDraw {
from { stroke-dashoffset: 1; }
to   { stroke-dashoffset: 0; }
}
@keyframes pjBraggScan {
0%   { transform: translateX(0%);   opacity: 0; }
4%   { opacity: 0.7; }
92%  { opacity: 0.5; }
100% { transform: translateX(264px); opacity: 0; }
}
@keyframes pjBraggPeakPulse {
0%, 100% { r: 3.5; opacity: 0.85; }
50%      { r: 5;   opacity: 1;    }
}
.pj-bragg-svg {
overflow: visible;
} .pj-bragg-ghost {
font-family: 'Syne', sans-serif;
font-size: 110px;
font-weight: 800;
fill: rgba(232, 41, 74, 0.032);
pointer-events: none;
} .pj-bragg-grid {
stroke: rgba(255, 255, 255, 0.045);
stroke-width: 1;
stroke-dasharray: 3 6;
} .pj-bragg-axis {
stroke: rgba(255, 255, 255, 0.14);
stroke-width: 1;
stroke-linecap: round;
} .pj-bragg-axislabel {
font-family: 'JetBrains Mono', monospace;
font-size: 7px;
font-weight: 500;
letter-spacing: 2px;
text-transform: uppercase;
fill: rgba(255, 255, 255, 0.28) !important;
} .pj-bragg-area {
opacity: 1;
} .pj-bragg-curve {
fill: none;
stroke: #E8294A;
stroke-width: 2px;
stroke-linecap: round;
stroke-linejoin: round;
stroke-dasharray: 1;
stroke-dashoffset: 1;
pathLength: 1;
animation: pjBraggDraw 1.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
} .pj-bragg-peak-line {
stroke: rgba(232, 41, 74, 0.35);
stroke-width: 1;
stroke-dasharray: 3 4;
} .pj-bragg-peak-dot {
fill: #E8294A;
animation: pjBraggPeakPulse 1.8s ease-in-out infinite;
}  .pj-bragg-traveler {
fill: #E8294A; } .pj-bragg-peak-flash {
fill: none;
stroke: #E8294A;
stroke-width: 1.5; } .pj-bragg-ann {
font-family: 'JetBrains Mono', monospace;
font-size: 7.5px;
font-weight: 700;
letter-spacing: 1.5px;
text-transform: uppercase;
fill: rgba(232, 41, 74, 0.75) !important;
} .pj-bragg-scan {
stroke: rgba(232, 41, 74, 0.65);
stroke-width: 1.5;
stroke-linecap: round;
animation: pjBraggScan 3.4s ease-in-out infinite;
} .pj-dose-footer {
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
max-width: 360px;
margin-top: 12px;
padding-top: 11px;
border-top: 1px solid rgba(255, 255, 255, 0.055);
}
.pj-dose-label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 10px;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.40) !important;
}
.pj-dose-spec {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.22) !important;
} @media (max-width: 1024px) {
.pj-hero--dosefield .pj-hero__layout {
grid-template-columns: 1fr;
gap: 44px;
}
.pj-hero__dose-vis {
order: -1;
align-items: center;
}
.pj-dose-svg,
.pj-dose-footer {
max-width: 320px;
}
} @media (max-width: 768px) {
.pj-hero__dose-vis {
display: none;
}
}  .pj-hero--dcaf .pj-hero__scene-bg {
width: 100%;
left: 0;
} .pj-hero--dcaf .pj-hero__scene-bg img {
object-position: 30% center;
filter: brightness(0.72) contrast(1.06) saturate(0.75);
} .pj-hero--dcaf .pj-hero__scene-bg::before {
width: 100%;
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.94) 22%,
rgba(17, 17, 24, 0.60) 44%,
rgba(17, 17, 24, 0.20) 65%,
rgba(17, 17, 24, 0.05) 100%
);
} .pj-hero--dcaf .pj-hero__scene-bg::after {
height: 45%;
background: linear-gradient(to bottom, transparent 0%, #111118 100%);
} .pj-hero--dcaf .pj-hero__left {
max-width: 620px;
} .pj-hero--dcaf .pj-hero__scene-bg .pj-hero__scene-accent {
left: 52%;
} @media (max-width: 1024px) {
.pj-hero--dcaf .pj-hero__scene-bg img {
filter: brightness(0.50) contrast(1.06) saturate(0.70);
object-position: 35% center;
}
.pj-hero--dcaf .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.97) 45%,
rgba(17, 17, 24, 0.90) 100%
);
}
.pj-hero--dcaf .pj-hero__left {
max-width: 100%;
}
}  .pj-solution__intro--dcaf {
display: grid;
grid-template-columns: 1fr 260px;
gap: 64px;
align-items: start;
}
.pj-solution__intro--dcaf .pj-solution__intro-text {
display: flex;
flex-direction: column;
gap: 0;
} .pj-dcaf-portrait {
flex-shrink: 0;
display: flex;
flex-direction: column;
align-items: center;
gap: 14px;
margin-top: 8px;
}
.pj-dcaf-portrait__frame {
position: relative;
width: 100%;
overflow: hidden;
background: #0c0c10;
border: 1px solid rgba(255, 255, 255, 0.07);
} .pj-dcaf-portrait__frame img {
display: block;
width: 100%;
height: auto;
filter:
grayscale(0.72)
contrast(1.18)
brightness(0.82)
sepia(0.08);
transition: filter 0.6s ease, transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
transform: scale(1.02);
transform-origin: center center;
}
.pj-dcaf-portrait:hover .pj-dcaf-portrait__frame img {
transform: scale(1.05);
filter: grayscale(0.40) contrast(1.14) brightness(0.88) sepia(0.04);
} @keyframes pjDocScan {
0%   { top: -2px; opacity: 0; }
5%   { opacity: 1; }
92%  { opacity: 1; }
100% { top: 100%; opacity: 0; }
}
.pj-dcaf-portrait__scan {
position: absolute;
left: 0; right: 0;
height: 2px;
background: linear-gradient(
to right,
transparent 0%,
rgba(255, 255, 255, 0.40) 30%,
rgba(255, 255, 255, 0.65) 50%,
rgba(255, 255, 255, 0.40) 70%,
transparent 100%
);
z-index: 3;
pointer-events: none;
animation: pjDocScan 3.2s cubic-bezier(0.22, 1, 0.36, 1) infinite;
animation-delay: 0.8s;
} .pj-dcaf-portrait__corner {
position: absolute;
width: 12px;
height: 12px;
z-index: 4;
pointer-events: none;
}
.pj-dcaf-portrait__corner--tl { top: 8px;  left: 8px;  border-top: 1.5px solid rgba(255,255,255,0.70); border-left: 1.5px solid rgba(255,255,255,0.70); }
.pj-dcaf-portrait__corner--tr { top: 8px;  right: 8px; border-top: 1.5px solid rgba(255,255,255,0.70); border-right: 1.5px solid rgba(255,255,255,0.70); }
.pj-dcaf-portrait__corner--bl { bottom: 8px; left: 8px;  border-bottom: 1.5px solid rgba(255,255,255,0.70); border-left: 1.5px solid rgba(255,255,255,0.70); }
.pj-dcaf-portrait__corner--br { bottom: 8px; right: 8px; border-bottom: 1.5px solid rgba(255,255,255,0.70); border-right: 1.5px solid rgba(255,255,255,0.70); } .pj-dcaf-ann {
position: absolute;
left: 12px;
z-index: 4;
font-family: 'JetBrains Mono', monospace;
font-size: 7.5px;
font-weight: 500;
letter-spacing: 1.8px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.72) !important;
line-height: 1;
pointer-events: none;
white-space: nowrap; display: flex;
align-items: center;
gap: 6px;
}
.pj-dcaf-ann::before {
content: '';
display: block;
width: 14px;
height: 1px;
background: rgba(255, 255, 255, 0.45);
flex-shrink: 0;
}
.pj-dcaf-ann--top { top: 18%;  }
.pj-dcaf-ann--mid { top: 48%; }
.pj-dcaf-ann--bot { top: 76%; } .pj-dcaf-portrait figcaption {
font-family: 'JetBrains Mono', monospace;
font-size: 8.5px;
font-weight: 500;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(17, 17, 24, 0.32) !important;
text-align: center;
line-height: 1;
} @media (max-width: 1024px) {
.pj-solution__intro--dcaf {
grid-template-columns: 1fr;
gap: 48px;
}
.pj-dcaf-portrait {
width: 220px;
margin: 0 auto;
}
}
@media (max-width: 480px) {
.pj-dcaf-portrait { width: 180px; }
} .pj-outcome__body--dcaf {
display: block; position: relative;
padding: 64px 0 48px;
} .pj-dcaf-vis--bg {
position: absolute;
inset: 0;
pointer-events: none;
overflow: hidden;
opacity: 0.18;
}
.pj-dcaf-vis--bg .pj-bragg-svg,
.pj-dcaf-vis--bg .pj-dose-svg--outcome {
width: 100%;
max-width: 100%;
height: 100%;
position: absolute;
inset: 0; preserveAspectRatio: none;
} .pj-dcaf-vis__text {
position: relative;
z-index: 2;
max-width: 720px;
display: flex;
flex-direction: column;
gap: 28px;
}
.pj-dcaf-vis__text p {
font-family: var(--thelis-ff-display);
font-size: 16px;
font-weight: 300;
color: var(--thelis-gray);
line-height: 1.85;
margin: 0;
} @media (max-width: 1024px) {
.pj-outcome__body--dcaf {
grid-template-columns: 1fr;
gap: 48px;
}
.pj-dcaf-vis {
padding: 32px 24px 24px;
max-width: 320px;
margin: 0 auto;
}
} .pj-dose-footer--inline {
margin-top: 28px;
padding-top: 14px;
border-top: 1px solid rgba(17, 17, 24, 0.10);
max-width: 100%;
}
@media (max-width: 768px) {
.pj-outcome__body--dcaf {
padding: 48px 0 32px;
}
.pj-dcaf-vis--bg {
opacity: 0.12;
}
}  .pj-hero--sentinelles .pj-hero__title {
font-size: clamp(36px, 5.2vw, 78px);
letter-spacing: -2px;
} .pj-hero--sentinelles .pj-hero__scene-bg img {
object-position: 78% center;
filter: brightness(0.68) contrast(1.10) saturate(0.72);
} .pj-hero--sentinelles .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(14, 14, 22, 0.97) 20%,
rgba(14, 14, 22, 0.82) 40%,
rgba(14, 14, 22, 0.38) 62%,
rgba(14, 14, 22, 0.06) 100%
);
} .pj-hero--sentinelles .pj-hero__scene-bg .pj-hero__scene-accent {
left: 42%;
} @media (max-width: 1024px) {
.pj-hero--sentinelles .pj-hero__scene-bg img {
filter: brightness(0.48) contrast(1.10) saturate(0.65);
object-position: 80% center;
}
.pj-hero--sentinelles .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(14, 14, 22, 0.98) 50%,
rgba(14, 14, 22, 0.92) 100%
);
}
}  .pj-solution__intro--sentinelles {
display: grid;
grid-template-columns: 1fr 280px;
gap: 56px;
align-items: start;
}
.pj-solution__intro--sentinelles .pj-solution__intro-text {
display: flex;
flex-direction: column;
gap: 0;
} .pj-sent-unit {
flex-shrink: 0;
display: flex;
flex-direction: column;
gap: 10px;
margin: 0;
} .pj-sent-unit__frame {
position: relative;
border-left: 2px solid var(--thelis-red);
overflow: hidden;
background: #0c0c14;
line-height: 0;
} .pj-sent-unit__frame img {
display: block;
width: 100%;
height: auto;
filter: brightness(0.85) contrast(1.06) saturate(0.60) hue-rotate(-6deg);
transition: filter 0.55s ease;
}
.pj-sent-unit:hover .pj-sent-unit__frame img {
filter: brightness(0.95) contrast(1.10) saturate(0.78) hue-rotate(-6deg);
} .pj-sent-unit__frame::after {
content: '';
position: absolute;
bottom: 0; left: 0; right: 0;
height: 38%;
background: linear-gradient(to bottom, transparent 0%, rgba(12, 12, 20, 0.50) 100%);
pointer-events: none;
}  .pj-sent-unit__pulse {
position: absolute;
top: 14px;
right: 14px;
width: 28px;
height: 28px;
z-index: 2;
}
.pj-sent-unit__dot {
position: absolute;
top: 50%; left: 50%;
transform: translate(-50%, -50%);
width: 6px; height: 6px;
border-radius: 50%;
background: var(--thelis-red);
box-shadow: 0 0 6px rgba(232, 41, 74, 0.80);
}
.pj-sent-unit__ring {
position: absolute;
top: 50%; left: 50%;
border-radius: 50%;
border: 1.5px solid rgba(232, 41, 74, 0.55);
animation: pjSentPulse 2.6s cubic-bezier(0.22, 1, 0.36, 1) infinite;
}
.pj-sent-unit__ring--1 {
width: 18px; height: 18px;
animation-delay: 0s;
}
.pj-sent-unit__ring--2 {
width: 28px; height: 28px;
animation-delay: 0.65s;
border-color: rgba(232, 41, 74, 0.28);
}
@keyframes pjSentPulse {
0%   { transform: translate(-50%, -50%) scale(0.4); opacity: 1; }
100% { transform: translate(-50%, -50%) scale(2.2); opacity: 0; }
} .pj-sent-unit__caption {
display: flex;
justify-content: space-between;
align-items: center;
padding: 0 0 0 10px; gap: 8px;
}
.pj-sent-unit__coord,
.pj-sent-unit__status {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 1.2px;
line-height: 1;
}
.pj-sent-unit__coord {
color: rgba(17, 17, 24, 0.38);
}
.pj-sent-unit__status {
color: var(--thelis-red);
} @media (max-width: 1024px) {
.pj-solution__intro--sentinelles {
grid-template-columns: 1fr;
gap: 40px;
}
.pj-sent-unit {
max-width: 320px;
}
}
@media (max-width: 480px) {
.pj-sent-unit {
max-width: 100%;
}
}  .pj-hero--prona .pj-hero__scene-bg img {
object-position: 52% 40%;
filter: brightness(0.68) contrast(1.08) saturate(0.72);
} .pj-hero--prona .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(13, 16, 14, 0.96) 22%,
rgba(13, 16, 14, 0.72) 44%,
rgba(13, 16, 14, 0.28) 68%,
rgba(13, 16, 14, 0.04) 100%
);
} .pj-hero--prona .pj-hero__scene-bg .pj-hero__scene-accent {
left: 44%;
} @media (max-width: 1024px) {
.pj-hero--prona .pj-hero__scene-bg img {
filter: brightness(0.44) contrast(1.10) saturate(0.62);
object-position: 55% 40%;
}
.pj-hero--prona .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(13, 16, 14, 0.98) 50%,
rgba(13, 16, 14, 0.93) 100%
);
}
} .pj-prona-screen {
margin: 0 0 64px;
border-radius: 6px;
overflow: hidden;
box-shadow:
0 2px 0 rgba(232, 41, 74, 0.60), 0 8px 40px rgba(17, 17, 24, 0.14),
0 24px 72px rgba(17, 17, 24, 0.08);
transition: box-shadow 0.45s ease, transform 0.55s var(--thelis-ease-out);
will-change: transform;
}
.pj-prona-screen:hover {
box-shadow:
0 2px 0 rgba(232, 41, 74, 0.80),
0 16px 64px rgba(17, 17, 24, 0.20),
0 40px 100px rgba(17, 17, 24, 0.12);
transform: translateY(-3px);
} .pj-prona-screen__chrome {
display: flex;
align-items: center;
gap: 12px;
background: #1a1a24;
padding: 0 16px;
height: 36px;
border-bottom: 1px solid rgba(255, 255, 255, 0.06);
flex-shrink: 0;
} .pj-prona-screen__dots {
display: flex;
gap: 5px;
flex-shrink: 0;
}
.pj-prona-screen__dots i {
display: block;
width: 9px; height: 9px;
border-radius: 50%;
background: rgba(255, 255, 255, 0.12);
font-style: normal;
}
.pj-prona-screen__dots i:first-child  { background: rgba(232, 41,  74, 0.65); }
.pj-prona-screen__dots i:nth-child(2) { background: rgba(255, 171,  0, 0.45); }
.pj-prona-screen__dots i:last-child   { background: rgba(35,  197, 88, 0.40); } .pj-prona-screen__url {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9.5px;
font-weight: 500;
color: rgba(255, 255, 255, 0.32);
letter-spacing: 0.3px;
flex: 1;
text-align: center;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
} .pj-prona-screen__rec {
display: flex;
align-items: center;
gap: 5px;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 8px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1.5px;
color: rgba(232, 41, 74, 0.70);
flex-shrink: 0;
}
.pj-prona-screen__rec-dot {
display: block;
width: 6px; height: 6px;
border-radius: 50%;
background: var(--thelis-red);
box-shadow: 0 0 5px rgba(232, 41, 74, 0.70);
animation: pjRecPulse 1.8s ease-in-out infinite;
}
@keyframes pjRecPulse {
0%, 100% { opacity: 1; }
50%       { opacity: 0.25; }
} .pj-prona-screen__viewport {
overflow: hidden;
line-height: 0;
position: relative;
background: #f0f0f2;
height: 330px; } .pj-prona-screen__viewport video {
display: block;
width: 100%;
height: auto;
object-fit: cover;
object-position: top center;
} @media (max-width: 768px) {
.pj-prona-screen { margin-bottom: 48px; }
}  .pj-hero--grcp .pj-hero__scene-bg img {
object-position: 55% center;
filter: brightness(0.66) contrast(1.08) saturate(0.65);
} .pj-hero--grcp .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(15, 15, 20, 0.96) 22%,
rgba(15, 15, 20, 0.70) 44%,
rgba(15, 15, 20, 0.24) 68%,
rgba(15, 15, 20, 0.04) 100%
);
} .pj-hero--grcp .pj-hero__scene-bg .pj-hero__scene-accent {
left: 44%;
} @media (max-width: 1024px) {
.pj-hero--grcp .pj-hero__scene-bg img {
filter: brightness(0.42) contrast(1.10) saturate(0.58);
object-position: 60% center;
}
.pj-hero--grcp .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(15, 15, 20, 0.98) 50%,
rgba(15, 15, 20, 0.93) 100%
);
}
} .pj-grcp-fieldstrip {
position: relative;
overflow: hidden;
height: 240px;
margin: 48px 0 56px;
border-radius: 3px;
} .pj-grcp-fieldstrip__img {
position: absolute;
inset: 0;
}
.pj-grcp-fieldstrip__img img {
width: 100%;
height: 100%;
object-fit: cover; object-position: center 72%; filter: brightness(0.58) contrast(1.08) saturate(0.18) blur(0.4px);
transform: scale(1.04);
transition: transform 7s ease, filter 0.6s ease;
will-change: transform;
}
.pj-grcp-fieldstrip:hover .pj-grcp-fieldstrip__img img {
transform: scale(1.0);
filter: brightness(0.65) contrast(1.08) saturate(0.22) blur(0.4px);
} .pj-grcp-fieldstrip::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to right,
rgba(17, 17, 24, 0.92) 0%,
rgba(17, 17, 24, 0.70) 28%,
rgba(17, 17, 24, 0.22) 56%,
rgba(17, 17, 24, 0.0)  100%
);
z-index: 1;
pointer-events: none;
} .pj-grcp-fieldstrip::after {
content: '';
position: absolute;
top: 0; bottom: 0; left: 0;
width: 2px;
background: var(--thelis-red);
z-index: 2;
} .pj-grcp-fieldstrip__stat {
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
z-index: 2;
display: flex;
flex-direction: column;
gap: 6px;
padding: 0 40px 0 32px;
} .pj-grcp-fieldstrip__num {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: clamp(44px, 5.5vw, 72px);
font-weight: 700;
color: #ffffff;
letter-spacing: -2px;
line-height: 1;
} .pj-grcp-fieldstrip__label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 2px;
color: rgba(232, 41, 74, 0.85);
line-height: 1;
} @media (max-width: 768px) {
.pj-grcp-fieldstrip { height: 180px; margin: 36px 0 44px; }
.pj-grcp-fieldstrip__stat { padding: 0 28px 0 24px; }
}
@media (max-width: 480px) {
.pj-grcp-fieldstrip { height: 150px; }
}  .pj-hero--levelstream .pj-hero__title {
font-size: clamp(46px, 7.0vw, 96px);
letter-spacing: -2px;
} @keyframes pjKenBurnsLS {
from { transform: scale(1.04); }
to   { transform: scale(1.0);  }
} @keyframes pjLSGlowPulse {
0%, 100% { opacity: 0.70; }
50%      { opacity: 0.28; }
} .pj-hero--levelstream .pj-hero__scene-bg img {
filter: brightness(0.74) saturate(0.76);
animation: pjKenBurnsLS 4.5s cubic-bezier(0.22, 1, 0.36, 1) 0.3s both;
} .pj-hero--levelstream .pj-hero__scene-bg::before {
background: radial-gradient(
ellipse 62% 82% at 62% 52%,
transparent            0%,
rgba(17, 17, 24, 0.34) 35%,
rgba(17, 17, 24, 0.78) 60%,
#111118                84%
);
} .pj-ls-glow {
position: absolute;
inset: 0;
background: radial-gradient(
ellipse 36% 48% at 62% 52%,
rgba(232, 41, 74, 0.11) 0%,
rgba(232, 41, 74, 0.05) 50%,
transparent             78%
);
z-index: 3;
pointer-events: none;
animation: pjLSGlowPulse 3.8s ease-in-out 1.0s infinite;
} @media (max-width: 1024px) {
.pj-ls-glow { display: none; }
}  .pj-ls-fieldstrip {
position: relative;
overflow: hidden;
height: 240px;
margin: 48px 0 56px;
border-radius: 3px;
}
.pj-ls-fieldstrip__img {
position: absolute;
inset: 0;
}
.pj-ls-fieldstrip__img img {
width: 100%;
height: 100%;
object-fit: cover;
transform: scale(1.04);
transition: transform 7s ease, filter 0.6s ease;
will-change: transform;
}
.pj-ls-fieldstrip:hover .pj-ls-fieldstrip__img img {
transform: scale(1.0);
} .pj-ls-fieldstrip::after {
content: '';
position: absolute;
top: 0; bottom: 0; left: 0;
width: 2px;
background: var(--thelis-red);
z-index: 2;
} .pj-ls-fieldstrip__stat {
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
z-index: 3;
display: flex;
flex-direction: column;
gap: 6px;
padding: 0 40px 0 32px;
}
.pj-ls-fieldstrip__num {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: clamp(44px, 5.5vw, 72px);
font-weight: 700;
color: #ffffff;
letter-spacing: -2px;
line-height: 1;
}
.pj-ls-fieldstrip__num sup {
font-size: 0.42em;
vertical-align: super;
letter-spacing: 0;
font-weight: 600;
} .pj-ls-fieldstrip__num--word {
font-size: clamp(32px, 4.0vw, 54px);
letter-spacing: -1px;
}
.pj-ls-fieldstrip__label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 2px;
color: rgba(232, 41, 74, 0.85);
line-height: 1;
} .pj-ls-fieldstrip--install .pj-ls-fieldstrip__img img { object-position: 48% 45%; filter: brightness(0.50) contrast(1.15) saturate(0.16);
}
.pj-ls-fieldstrip--install:hover .pj-ls-fieldstrip__img img {
filter: brightness(0.58) contrast(1.15) saturate(0.20);
} .pj-ls-fieldstrip--install::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to right,
rgba(11, 12, 17, 0.96) 0%,
rgba(11, 12, 17, 0.74) 28%,
rgba(11, 12, 17, 0.20) 56%,
rgba(11, 12, 17, 0.0)  100%
);
z-index: 1;
pointer-events: none;
} .pj-ls-fieldstrip--context .pj-ls-fieldstrip__img img { object-position: center 32%; filter: brightness(0.46) contrast(1.08) saturate(0.55);
}
.pj-ls-fieldstrip--context:hover .pj-ls-fieldstrip__img img {
filter: brightness(0.54) contrast(1.08) saturate(0.62);
} .pj-ls-fieldstrip--context::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to left,
rgba(11, 12, 17, 0.96) 0%,
rgba(11, 12, 17, 0.74) 28%,
rgba(11, 12, 17, 0.18) 56%,
rgba(11, 12, 17, 0.0)  100%
);
z-index: 1;
pointer-events: none;
} .pj-ls-fieldstrip--context::after {
left: auto;
right: 0;
} .pj-ls-fieldstrip--context .pj-ls-fieldstrip__stat {
left: auto;
right: 0;
padding: 0 32px 0 40px;
text-align: right;
} @media (max-width: 768px) {
.pj-ls-fieldstrip         { height: 180px; margin: 36px 0 44px; }
.pj-ls-fieldstrip__stat   { padding: 0 28px 0 24px; }
.pj-ls-fieldstrip--context .pj-ls-fieldstrip__stat { padding: 0 24px 0 28px; }
}
@media (max-width: 480px) {
.pj-ls-fieldstrip { height: 150px; }
}  .pj-hero--vanda .pj-hero__title {
font-size: clamp(58px, 8.8vw, 120px);
letter-spacing: -3px;
} .pj-hero--vanda .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 56px;
align-items: center;
} .pj-hero--vanda .pj-hero__left {
max-width: none;
} .pj-hero--vanda .pj-hero__network-vis {
opacity: 1;
animation: pjBlurUp 1.2s var(--thelis-ease-out) 0.65s both;
position: relative;
z-index: 1; filter: brightness(3.2) contrast(1.1)
drop-shadow(0 0 14px rgba(232, 41, 74, 0.60))
drop-shadow(0 0 4px  rgba(232, 41, 74, 0.40));
} @media (max-width: 1024px) {
.pj-hero--vanda .pj-hero__layout {
grid-template-columns: 1fr;
gap: 40px;
}
.pj-hero--vanda .pj-hero__network-vis {
display: none;
}
.pj-hero--vanda .pj-hero__left {
max-width: 680px;
}
} .pj-hero--vanda .pj-hero__scene-bg {
width: 100%;
} .pj-hero--vanda .pj-hero__scene-bg img {
object-position: 50% 55%;
filter: brightness(0.54) contrast(1.10) saturate(0.32);
} .pj-hero--vanda .pj-hero__scene-bg::before {
width: 100%;
background: linear-gradient(
to right,
rgba(13,13,18,0.88) 0%,
rgba(13,13,18,0.72) 35%,
rgba(13,13,18,0.66) 65%,
rgba(13,13,18,0.80) 100%
);
} .pj-hero--vanda .pj-hero__scene-bg .pj-hero__scene-accent {
left: 42%;
} @media (max-width: 1024px) {
.pj-hero--vanda .pj-hero__scene-bg img {
filter: brightness(0.48) contrast(1.10) saturate(0.28);
object-position: 55% center;
}
.pj-hero--vanda .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
rgba(13, 13, 18, 0.94) 0%,
rgba(13, 13, 18, 0.88) 50%,
rgba(13, 13, 18, 0.84) 100%
);
}
} .pj-vanda-fieldstrip {
position: relative;
overflow: hidden;
height: 240px;
margin: 48px 0 56px;
border-radius: 3px;
}
.pj-vanda-fieldstrip__img {
position: absolute;
inset: 0;
}
.pj-vanda-fieldstrip__img img {
width: 100%;
height: 100%;
object-fit: cover; object-position: center 50%;
filter: brightness(0.48) contrast(1.14) saturate(0.22);
transform: scale(1.04);
transition: transform 7s ease, filter 0.6s ease;
will-change: transform;
}
.pj-vanda-fieldstrip:hover .pj-vanda-fieldstrip__img img {
transform: scale(1.0);
filter: brightness(0.56) contrast(1.14) saturate(0.28);
} .pj-vanda-fieldstrip::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to right,
rgba(11, 12, 17, 0.96) 0%,
rgba(11, 12, 17, 0.74) 30%,
rgba(11, 12, 17, 0.20) 58%,
rgba(11, 12, 17, 0.0)  100%
);
z-index: 1;
pointer-events: none;
} .pj-vanda-fieldstrip::after {
content: '';
position: absolute;
top: 0; bottom: 0; left: 0;
width: 2px;
background: var(--thelis-red);
z-index: 2;
} .pj-vanda-fieldstrip__stat {
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
z-index: 3;
display: flex;
flex-direction: column;
gap: 6px;
padding: 0 40px 0 32px;
} .pj-vanda-fieldstrip__num {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: clamp(44px, 5.5vw, 72px);
font-weight: 700;
color: #ffffff;
letter-spacing: -2px;
line-height: 1;
}
.pj-vanda-fieldstrip__num sup {
font-size: 0.44em;
vertical-align: super;
letter-spacing: 0;
font-weight: 600;
} .pj-vanda-fieldstrip__label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 2px;
color: rgba(232, 41, 74, 0.85);
line-height: 1;
} @media (max-width: 768px) {
.pj-vanda-fieldstrip { height: 180px; margin: 36px 0 44px; }
.pj-vanda-fieldstrip__stat { padding: 0 28px 0 24px; }
}
@media (max-width: 480px) {
.pj-vanda-fieldstrip { height: 150px; }
}  .pj-depth--vanda {
position: relative;
overflow: hidden;
} .pj-vanda-topo-bg {
position: absolute;
right: -80px;
top: 50%;
transform: translateY(-50%);
width: 720px;
max-width: 62%;
opacity: 0.09;
pointer-events: none;
z-index: 0;
}
.pj-vanda-topo-bg svg {
width: 100%;
height: auto;
display: block;
} .pj-depth--vanda .container {
position: relative;
z-index: 1;
} @media (max-width: 1024px) {
.pj-vanda-topo-bg {
right: -120px;
width: 560px;
opacity: 0.07;
}
} @media (max-width: 768px) {
.pj-vanda-topo-bg {
display: none;
}
}  .pj-hero--zharis .pj-hero__layout {
display: grid;
grid-template-columns: 55fr 45fr;
gap: 56px;
align-items: center;
}
.pj-hero--zharis .pj-hero__left {
max-width: none;
} .pj-hero--zharis .pj-hero__scene-bg {
width: 100%;
} .pj-hero--zharis .pj-hero__scene-bg img {
object-position: 50% 45%;
filter: brightness(0.30) contrast(1.18) saturate(0.40);
} .pj-hero--zharis .pj-hero__scene-bg::before {
width: 100%;
background: linear-gradient(
to right,
rgba(11,12,17,0.97) 0%,
rgba(11,12,17,0.88) 38%,
rgba(11,12,17,0.80) 60%,
rgba(11,12,17,0.90) 100%
);
} .pj-hero__blueprint-vis {
animation: pjBlurUp 1.0s var(--thelis-ease-out) 0.65s both;
position: relative;
z-index: 1;
}
.pj-blueprint-svg {
width: 100%;
height: auto;
display: block;
overflow: visible;
} @keyframes zhLedBlink {
0%, 100% { opacity: 0.50; }
50%       { opacity: 1.00; }
}
.zh-led { animation: zhLedBlink 2.4s ease-in-out infinite; } @keyframes zhStatusPulse {
0%, 100% { opacity: 0.80; }
50%       { opacity: 0.25; }
}
.zh-status { animation: zhStatusPulse 2.0s ease-in-out infinite; } @media (max-width: 1024px) {
.pj-hero--zharis .pj-hero__layout {
grid-template-columns: 1fr;
gap: 40px;
}
.pj-hero__blueprint-vis {
display: none;
}
.pj-hero--zharis .pj-hero__left {
max-width: 680px;
}
.pj-hero--zharis .pj-hero__scene-bg img {
object-position: 55% center;
filter: brightness(0.32) contrast(1.16) saturate(0.42);
}
.pj-hero--zharis .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#0b0c11 0%,
rgba(11,12,17,0.99) 55%,
rgba(11,12,17,0.96) 100%
);
}
} .pj-zh-fieldstrip {
position: relative;
overflow: hidden;
height: 240px;
margin: 48px 0 56px;
border-radius: 3px;
} .pj-zh-fieldstrip__img {
position: absolute;
inset: 0;
}
.pj-zh-fieldstrip__img img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: 50% 38%; filter: brightness(0.38) contrast(1.22) saturate(0.12);
transform: scale(1.02);
transition: transform 1.1s cubic-bezier(0.22, 1, 0.36, 1);
}
.pj-zh-fieldstrip:hover .pj-zh-fieldstrip__img img {
transform: scale(1.0);
} .pj-zh-fieldstrip::before {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(
to left,
rgba(247,245,241,0.97) 0%,
rgba(247,245,241,0.78) 28%,
rgba(247,245,241,0.18) 56%,
rgba(247,245,241,0.0)  100%
);
z-index: 1;
} .pj-zh-fieldstrip::after {
content: '';
position: absolute;
top: 0; bottom: 0; right: 0;
width: 2px;
background: #E8294A;
z-index: 2;
} .pj-zh-fieldstrip__stat {
position: absolute;
top: 50%;
right: 0;
transform: translateY(-50%);
padding: 0 36px 0 48px;
text-align: right;
z-index: 2;
}
.pj-zh-fieldstrip__num {
display: block;
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display);
font-size: clamp(52px, 6.5vw, 88px);
font-weight: 700;
line-height: 1;
letter-spacing: -3px;
color: #111118;
}
.pj-zh-fieldstrip__sub {
display: block;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono);
font-size: 9px;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(17,17,24,0.50);
margin-top: 6px;
} @media (max-width: 768px) {
.pj-zh-fieldstrip { height: 180px; }
.pj-zh-fieldstrip__num { font-size: clamp(40px, 8vw, 64px); }
.pj-zh-fieldstrip__stat { padding: 0 20px 0 28px; }
}   .pj-hero--zharis-ai .pj-hero__title {
font-size: clamp(44px, 5.2vw, 78px);
letter-spacing: -1.5px;
}
.pj-hero--zharis-ai .pj-hero__scene-bg img {
filter: brightness(0.30) saturate(0.60) contrast(1.06);
object-position: center center;
}
.pj-hero--zharis-ai .pj-hero__scene-bg::before {
background: linear-gradient(
to right,
#111118 0%,
rgba(17, 17, 24, 0.96) 22%,
rgba(17, 17, 24, 0.72) 46%,
rgba(17, 17, 24, 0.14) 100%
);
} .za-hero__accent {
left: 56%;
} .za-hero__layout {
display: grid;
grid-template-columns: 1fr 420px;
gap: 48px;
align-items: center;
} .za-hero__vis {
display: flex;
align-items: center;
justify-content: center;
}
.za-net-svg {
width: 100%;
max-width: 380px;
height: auto;
overflow: visible;
} .za-why__vis-wrap {
display: block;
margin-top: 36px;
}
.za-why__vis-wrap .za-net-svg {
width: 100%;
max-width: 100%;
opacity: 0.92;
} .thelis-ai-bundle .pj-problem__left {
display: flex;
flex-direction: column;
} .thelis-ai-bundle .pj-problem__grid {
margin-bottom: 80px;
align-items: stretch;
} .za-why-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 20px;
margin-top: 48px;
} .za-why-card {
position: relative;
overflow: hidden;
background: #0f0f14;
border: 1px solid rgba(255, 255, 255, 0.07);
border-top: 2px solid transparent;
border-radius: 4px;
min-height: 320px;
transition:
border-top-color 0.3s ease,
transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1),
box-shadow 0.25s ease;
}
.za-why-card:hover {
border-top-color: var(--thelis-red, #E8294A);
transform: translateY(-6px);
box-shadow: 0 28px 72px rgba(0, 0, 0, 0.35);
} .za-why-card__bg {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
opacity: 0.26;
filter: saturate(0.40) brightness(0.55);
transition: opacity 0.5s ease, transform 0.7s ease;
pointer-events: none;
z-index: 0;
}
.za-why-card:hover .za-why-card__bg {
opacity: 0.42;
transform: scale(1.05);
} .za-why-card__overlay {
position: absolute;
inset: 0;
background: linear-gradient(
165deg,
rgba(8, 8, 14, 0.70) 0%,
rgba(8, 8, 14, 0.30) 55%,
rgba(8, 8, 14, 0.58) 100%
);
z-index: 1;
pointer-events: none;
} .za-why-card__content {
position: relative;
z-index: 2;
padding: 36px 32px;
height: 100%;
display: flex;
flex-direction: column;
}
.za-why-card__icon {
width: 48px;
height: 48px;
display: flex;
align-items: center;
justify-content: center;
background: rgba(232, 41, 74, 0.15);
border-radius: 4px;
color: var(--thelis-red, #E8294A);
margin-bottom: 22px;
flex-shrink: 0;
transition: background 0.3s ease, transform 0.3s ease;
}
.za-why-card:hover .za-why-card__icon {
background: rgba(232, 41, 74, 0.24);
transform: scale(1.06);
}
.za-why-card h3 {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 20px;
font-weight: 700;
letter-spacing: -0.4px;
color: #ffffff !important;
margin: 0 0 12px;
flex-shrink: 0;
}
.za-why-card p {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 15px;
font-weight: 300;
line-height: 1.68;
color: rgba(255, 255, 255, 0.68) !important;
margin: 0;
flex: 1;
} .za-bundle-section {
padding: 120px 0;
background: #0c0c14;
position: relative;
overflow: hidden;
} .za-bundle-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;
} .za-bundle-section::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 3px;
background: linear-gradient(90deg, var(--thelis-red, #E8294A), transparent);
} .za-bundle-section .pj-label {
color: var(--thelis-red, #E8294A) !important;
}
.za-bundle-section .pj-label::before {
background: var(--thelis-red, #E8294A) !important;
}
.za-bundle-section .pj-section-num {
color: rgba(255, 255, 255, 0.04) !important;
}
.za-bundle__intro {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 48px;
align-items: start;
margin-bottom: 72px;
}
.za-bundle__intro .pj-section-title {
margin: 0;
color: #ffffff !important;
}
.za-bundle__lead {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 16px;
font-weight: 300;
line-height: 1.72;
color: rgba(255, 255, 255, 0.52) !important;
margin: 0;
padding-top: 12px;
} .za-timeline {
position: relative;
} .za-timeline__rail {
position: relative;
height: 44px;
margin-bottom: 28px;
display: flex;
align-items: center;
} .za-timeline__line {
position: absolute;
top: 50%;
left:  calc(16.666% + 22px);
right: calc(16.666% + 22px);
height: 1.5px;
background: linear-gradient(
90deg,
#E8294A 0%,
rgba(232, 41, 74, 0.45) 60%,
rgba(232, 41, 74, 0.12) 100%
);
transform-origin: left center;
transform: scaleX(0);
transition: transform 1.1s cubic-bezier(0.22, 1, 0.36, 1) 0.25s;
}
.za-timeline__rail.za-line-active .za-timeline__line {
transform: scaleX(1);
} .za-timeline__nodes {
display: grid;
grid-template-columns: repeat(3, 1fr);
width: 100%;
position: relative;
z-index: 2;
} @keyframes zaBundlePulse {
0%   { box-shadow: 0 0 0 0    rgba(232, 41, 74, 0.55); }
60%  { box-shadow: 0 0 0 10px rgba(232, 41, 74, 0);    }
100% { box-shadow: 0 0 0 0    rgba(232, 41, 74, 0);    }
}
.za-timeline__node {
display: flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border-radius: 50%;
margin: 0 auto;
background: #0c0c14;
border: 1.5px solid rgba(255, 255, 255, 0.12);
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 11px;
font-weight: 700;
letter-spacing: 1px;
color: rgba(255, 255, 255, 0.25) !important;
transition: border-color 0.35s ease, color 0.35s ease, background 0.35s ease,
box-shadow 0.35s ease;
} .za-timeline__node--active,
.za-timeline__rail.za-line-active .za-timeline__node:first-child {
background: var(--thelis-red, #E8294A);
border-color: var(--thelis-red, #E8294A);
color: #fff !important;
animation: zaBundlePulse 2.4s ease-out infinite;
} .za-timeline__rail.za-line-active .za-timeline__node:nth-child(2) {
border-color: rgba(232, 41, 74, 0.65);
color: var(--thelis-red, #E8294A) !important;
transition-delay: 0.55s;
}
.za-timeline__rail.za-line-active .za-timeline__node:nth-child(3) {
border-color: rgba(232, 41, 74, 0.65);
color: var(--thelis-red, #E8294A) !important;
transition-delay: 1.0s;
} .za-timeline__phases {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 1px;
background: rgba(255, 255, 255, 0.055);
counter-reset: za-phase;
} .za-phase-card {
background: #0e0e18;
padding: 40px 32px;
position: relative;
overflow: hidden;
counter-increment: za-phase;
transition: background 0.35s ease;
} .za-phase-card::before {
content: counter(za-phase, decimal-leading-zero);
position: absolute;
top: -20px;
right: 12px;
font-family: 'Cormorant Garamond', Georgia, serif;
font-size: 168px;
font-weight: 600;
line-height: 1;
color: rgba(232, 41, 74, 0.055);
pointer-events: none;
transition: color 0.45s ease;
z-index: 0;
user-select: none;
}
.za-phase-card:hover::before {
color: rgba(232, 41, 74, 0.10);
} .za-phase-card:not(:first-child)::after {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: linear-gradient(90deg, #E8294A 0%, rgba(232, 41, 74, 0.28) 100%);
transform: scaleX(0);
transform-origin: left center;
transition: transform 0.52s cubic-bezier(0.22, 1, 0.36, 1);
}
.za-phase-card:not(:first-child):hover::after {
transform: scaleX(1);
} .za-phase-card:first-child {
border-top: 2px solid var(--thelis-red, #E8294A);
}
.za-phase-card:hover {
background: #111122;
} .za-phase-card > * {
position: relative;
z-index: 1;
}
.za-phase-card__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: 20px;
}
.za-phase-tag {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red, #E8294A) !important;
display: inline-flex;
align-items: center;
gap: 8px;
}
.za-phase-tag::before {
content: '';
display: inline-block;
width: 20px;
height: 1px;
background: var(--thelis-red, #E8294A);
opacity: 0.55;
}
.za-phase-icon {
color: rgba(255, 255, 255, 0.20);
transition: color 0.3s ease;
flex-shrink: 0;
}
.za-phase-card:hover .za-phase-icon {
color: var(--thelis-red, #E8294A);
}
.za-phase-title {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 20px;
font-weight: 700;
letter-spacing: -0.4px;
color: #ffffff !important;
margin: 0 0 12px;
}
.za-phase-desc {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 14px;
font-weight: 300;
line-height: 1.65;
color: rgba(255, 255, 255, 0.48) !important;
margin: 0 0 20px;
}
.za-phase-list {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 8px;
border-top: 1px solid rgba(255, 255, 255, 0.07);
padding-top: 20px;
}
.za-phase-list li {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 10px;
font-weight: 500;
letter-spacing: 0.5px;
color: rgba(255, 255, 255, 0.36) !important;
padding-left: 16px;
position: relative;
line-height: 1.5;
}
.za-phase-list li::before {
content: '—';
position: absolute;
left: 0;
color: var(--thelis-red, #E8294A);
opacity: 0.55;
} .za-stack-row {
display: flex;
align-items: center;
gap: 20px;
margin-top: 48px;
padding-top: 32px;
border-top: 1px solid rgba(255, 255, 255, 0.07);
flex-wrap: wrap;
}
.za-stack-label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.28) !important;
white-space: nowrap;
}
.za-stack-pills {
display: flex;
flex-wrap: wrap;
gap: 8px;
}
.za-stack-pills span {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 500;
letter-spacing: 1px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.38) !important;
border: 1px solid rgba(255, 255, 255, 0.10);
border-radius: 2px;
padding: 5px 10px;
transition: border-color 0.25s, color 0.25s;
}
.za-stack-pills span:hover {
border-color: rgba(232, 41, 74, 0.45);
color: var(--thelis-red, #E8294A) !important;
}  .za-metrics .pj-metrics-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
margin: 56px 0 72px;
border: 1px solid rgba(17, 17, 24, 0.07);
border-radius: 4px;
overflow: hidden;
}
.za-metrics .pj-metric {
padding: 36px 32px 32px;
position: relative;
display: flex;
flex-direction: column;
gap: 0;
border-right: 1px solid rgba(17, 17, 24, 0.07);
background: #ffffff;
transition: background 0.32s ease;
overflow: hidden;
}
.za-metrics .pj-metric:last-child {
border-right: none;
} .za-metrics .pj-metric::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0;
height: 2px;
background: linear-gradient(90deg, #E8294A, rgba(232, 41, 74, 0.30));
transform: scaleX(0);
transform-origin: left center;
transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.za-metrics .pj-metric:hover::before {
transform: scaleX(1);
}
.za-metrics .pj-metric:hover {
background: rgba(232, 41, 74, 0.025);
} .pj-metric__cat {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 700;
letter-spacing: 3.5px;
text-transform: uppercase;
color: var(--thelis-red, #E8294A);
margin-bottom: 20px;
display: flex;
align-items: center;
gap: 8px;
}
.pj-metric__cat::before {
content: '';
display: inline-block;
width: 16px;
height: 1px;
background: var(--thelis-red, #E8294A);
opacity: 0.50;
flex-shrink: 0;
} .za-metrics .pj-metric__val {
font-family: 'Cormorant Garamond', Georgia, serif;
font-family: var(--thelis-ff-title, 'Cormorant Garamond', Georgia, serif);
font-size: 62px;
font-weight: 600;
line-height: 0.95;
letter-spacing: -1.5px;
color: var(--thelis-black, #111118);
margin-bottom: 18px;
display: block;
} .za-metrics .pj-metric__label {
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 10px;
font-weight: 500;
letter-spacing: 0.5px;
text-transform: uppercase;
color: rgba(17, 17, 24, 0.38);
line-height: 1.6;
margin-top: auto;
} .za-outcome-body {
display: grid;
grid-template-columns: 1fr 340px;
gap: 64px;
margin-top: 64px;
align-items: start;
} .za-compliance-box {
background: rgba(232, 41, 74, 0.04);
border: 1px solid rgba(232, 41, 74, 0.14);
border-left: 3px solid var(--thelis-red, #E8294A);
border-radius: 2px;
padding: 28px 28px;
}
.za-compliance-label {
display: block;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: var(--thelis-red, #E8294A);
margin-bottom: 18px;
}
.za-compliance-list {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: 10px;
}
.za-compliance-list li {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 13px;
font-weight: 400;
color: rgba(17, 17, 24, 0.68);
padding-left: 18px;
position: relative;
line-height: 1.5;
}
.za-compliance-list li::before {
content: '✓';
position: absolute;
left: 0;
color: var(--thelis-red, #E8294A);
font-size: 11px;
font-weight: 700;
}  .za-zharis-opt {
position: relative;
}
.za-zharis-opt__grid {
display: grid;
grid-template-columns: 1fr 440px;
gap: 80px;
align-items: center;
padding-top: 48px;
}
.za-zharis-opt__intro {
font-family: 'Syne', sans-serif;
font-family: var(--thelis-ff-display, 'Syne', sans-serif);
font-size: 15px;
font-weight: 300;
line-height: 1.75;
color: rgba(255, 255, 255, 0.62) !important;
margin: 0 0 40px;
} .za-specs-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1px;
background: rgba(255, 255, 255, 0.08);
border: 1px solid rgba(255, 255, 255, 0.08);
border-radius: 4px;
overflow: hidden;
margin-bottom: 36px;
}
.za-spec {
background: rgba(255, 255, 255, 0.025);
padding: 20px 22px;
transition: background 0.25s ease;
}
.za-spec:hover {
background: rgba(232, 41, 74, 0.07);
}
.za-spec__val {
display: block;
font-family: 'Cormorant Garamond', Georgia, serif;
font-family: var(--thelis-ff-title, 'Cormorant Garamond', Georgia, serif);
font-size: 32px;
font-weight: 600;
letter-spacing: -1px;
line-height: 1.1;
color: var(--thelis-red, #E8294A);
margin-bottom: 4px;
}
.za-spec__label {
display: block;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 8px;
font-weight: 500;
letter-spacing: 2px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.38) !important;
} .za-btn-outline {
display: inline-flex;
align-items: center;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 10px;
font-weight: 700;
letter-spacing: 3px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.72) !important;
border: 1px solid rgba(255, 255, 255, 0.22);
border-radius: 2px;
padding: 12px 20px;
text-decoration: none;
transition: color 0.25s, border-color 0.25s, background 0.25s;
}
.za-btn-outline:hover {
color: #ffffff !important;
border-color: rgba(232, 41, 74, 0.70);
background: rgba(232, 41, 74, 0.07);
} .za-hw-frame {
position: relative;
border-radius: 4px;
overflow: hidden;
background: rgba(255, 255, 255, 0.03);
border: 1px solid rgba(255, 255, 255, 0.10);
}
.za-hw-frame img {
display: block;
width: 100%;
height: auto;
filter: brightness(0.88) contrast(1.04) saturate(0.75);
transition: filter 0.45s ease;
}
.za-hw-frame:hover img {
filter: brightness(1.0) contrast(1.05) saturate(0.85);
} .za-hw-badge {
position: absolute;
bottom: 16px;
left: 16px;
display: flex;
align-items: center;
gap: 6px;
background: rgba(17, 17, 24, 0.82);
backdrop-filter: blur(6px);
border: 1px solid rgba(255, 255, 255, 0.12);
border-radius: 2px;
padding: 7px 12px;
font-family: 'JetBrains Mono', monospace;
font-family: var(--thelis-ff-mono, 'JetBrains Mono', monospace);
font-size: 9px;
font-weight: 700;
letter-spacing: 1.5px;
text-transform: uppercase;
color: rgba(255, 255, 255, 0.82) !important;
}
.za-hw-badge__sep {
color: var(--thelis-red, #E8294A) !important;
opacity: 0.7;
} @media (max-width: 1200px) {
.za-hero__layout { grid-template-columns: 1fr 340px; gap: 32px; }
.za-zharis-opt__grid { grid-template-columns: 1fr 360px; gap: 56px; }
}
@media (max-width: 1024px) {
.za-hero__layout { grid-template-columns: 1fr; }
.za-hero__vis { display: none; } .za-why__vis-wrap { margin-top: 28px; }
.thelis-ai-bundle .pj-problem__grid { align-items: start; }
.za-why-grid { grid-template-columns: 1fr 1fr; }
.za-why-card { min-height: 280px; }
.za-bundle__intro { grid-template-columns: 1fr; gap: 16px; }
.za-timeline__phases { grid-template-columns: 1fr; gap: 1px; }
.za-phase-card { padding: 32px 24px; }
.za-timeline__rail { display: none; } .za-metrics .pj-metrics-grid { grid-template-columns: repeat(2, 1fr); }
.za-metrics .pj-metric:nth-child(2) { border-right: none; }
.za-metrics .pj-metric:nth-child(3),
.za-metrics .pj-metric:nth-child(4) { border-top: 1px solid rgba(17, 17, 24, 0.07); }
.za-metrics .pj-metric:nth-child(4) { border-right: none; }
.za-outcome-body { grid-template-columns: 1fr; gap: 40px; }
.za-zharis-opt__grid { grid-template-columns: 1fr; gap: 48px; }
.za-specs-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 768px) {
.za-why__vis-wrap { display: none; } .za-why-grid { grid-template-columns: 1fr; }
.za-why-card { min-height: 260px; }
.za-why-card__content { padding: 28px 24px; }
.za-specs-grid { grid-template-columns: repeat(2, 1fr); }
.za-bundle-section { padding: 80px 0; } .za-metrics .pj-metrics-grid { grid-template-columns: 1fr; margin: 40px 0 56px; }
.za-metrics .pj-metric { border-right: none !important; border-top: 1px solid rgba(17, 17, 24, 0.07); }
.za-metrics .pj-metric:first-child { border-top: none; }
.za-metrics .pj-metric__val { font-size: 52px; }
}.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}